@import url(https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap);*{margin:0;padding:0;box-sizing:border-box}body{font-family:'DM Sans',system-ui,sans-serif;background:linear-gradient(160deg,#0a0a0f 0,#12101f 40%,#1a0e2e 100%);color:#e8e4f0;min-height:100vh;overflow:hidden}#lobby{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.lobby-box{width:100%;max-width:460px;text-align:center}.lobby-box-inner{margin-bottom:40px}.logo-row{display:inline-flex;align-items:center;gap:12px;margin-bottom:12px}.logo-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#ff4d6a,#c34cff);display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 0 30px rgba(195,76,255,.3)}.logo-text{font-size:28px;font-weight:700;letter-spacing:-.5px;background:linear-gradient(90deg,#ff4d6a,#c34cff);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.lobby-sub{color:#8a819e;font-size:15px;letter-spacing:.3px;margin-bottom:36px}.input-field{width:100%;padding:14px 18px;border-radius:12px;border:1px solid #2d2744;background:rgba(255,255,255,.04);color:#e8e4f0;font-size:16px;outline:0;font-family:inherit;transition:border-color .2s}.input-field:focus{border-color:#c34cff}.input-field::placeholder{color:#554e6a}.input-field.error{border-color:#ff4d6a}#nicknameInput{text-align:center;letter-spacing:.5px;margin-bottom:28px}.btn-create{width:100%;padding:16px;border-radius:14px;border:none;background:linear-gradient(135deg,#ff4d6a,#c34cff);color:#fff;font-size:16px;font-weight:600;cursor:pointer;letter-spacing:.3px;box-shadow:0 4px 24px rgba(195,76,255,.25);transition:opacity .2s;font-family:inherit;margin-bottom:20px}.btn-create:hover{opacity:.9}.divider{display:flex;align-items:center;gap:14px;margin-bottom:20px}.divider-line{flex:1;height:1px;background:#2d2744}.divider-text{color:#554e6a;font-size:13px;text-transform:uppercase;letter-spacing:2px}.join-row{display:flex;gap:10px}#joinCodeInput{flex:1;text-align:center;letter-spacing:4px;font-weight:600}.btn-join{padding:14px 28px;border-radius:12px;border:1px solid #c34cff;background:0 0;color:#c34cff;font-size:15px;font-weight:600;cursor:pointer;transition:.2s;font-family:inherit}.btn-join:hover{background:rgba(195,76,255,.1)}.status-msg{margin-top:18px;font-size:13px;color:#8a819e;min-height:20px;transition:color .2s}.status-msg.error{color:#ff4d6a}.status-msg.ok{color:#4dff8f}#room{display:none;flex-direction:column;height:100vh}.room-header{padding:12px 20px;border-bottom:1px solid #1e1a2e;display:flex;align-items:center;justify-content:space-between;background:rgba(10,10,15,.95);flex-shrink:0;flex-wrap:wrap;gap:8px}.room-header-left{display:flex;align-items:center;gap:10px}.room-logo-sm{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,#ff4d6a,#c34cff);display:flex;align-items:center;justify-content:center;font-size:16px}.room-logo-text{font-size:16px;font-weight:700;background:linear-gradient(90deg,#ff4d6a,#c34cff);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.room-header-right{display:flex;align-items:center;gap:16px}.conn-status{display:flex;align-items:center;gap:6px}.conn-dot{width:8px;height:8px;border-radius:50%;background:#ff4d6a}.conn-dot.connected{background:#4dff8f;box-shadow:0 0 8px rgba(77,255,143,.4)}.conn-label{font-size:12px;color:#8a819e}.sync-badge{font-size:11px;color:#c34cff;background:rgba(195,76,255,.1);padding:4px 10px;border-radius:20px;font-weight:600;display:none}.sync-badge.active{display:inline-block}.room-code{background:rgba(195,76,255,.1);border:1px solid #2d2744;padding:6px 14px;border-radius:8px;font-size:14px;font-weight:700;letter-spacing:2px;color:#c34cff;cursor:pointer;user-select:all}.room-code:hover{background:rgba(195,76,255,.18)}.room-body{flex:1;display:flex;overflow:hidden}.video-col{flex:1;display:flex;flex-direction:column;min-width:0}.url-bar{padding:12px 20px;display:flex;gap:10px;border-bottom:1px solid #1e1a2e}#videoUrlInput{flex:1;padding:10px 16px;border-radius:10px;font-size:14px}.btn-load{padding:10px 22px;border-radius:10px;border:none;background:linear-gradient(135deg,#ff4d6a,#c34cff);color:#fff;font-weight:600;font-size:14px;cursor:pointer;font-family:inherit}.player-area{flex:1;display:flex;align-items:center;justify-content:center;background:#000;position:relative;flex-direction:column}.player-placeholder{text-align:center;color:#554e6a}.player-placeholder .emoji{font-size:56px;margin-bottom:16px;opacity:.4}.player-placeholder p{font-size:16px}.player-placeholder .sub{font-size:13px;margin-top:8px;color:#3d3656}.player-wrapper{flex:1;width:100%;position:relative;display:none}.join-overlay{position:absolute;inset:0;z-index:10;background:#000;display:none;align-items:center;justify-content:center;flex-direction:column;gap:14px}.join-overlay.active{display:flex}.join-spinner{width:36px;height:36px;border-radius:50%;border:3px solid #2d2744;border-top-color:#c34cff;animation:.8s linear infinite spin}.join-overlay-text{font-size:14px;color:#8a819e}@keyframes spin{to{transform:rotate(360deg)}}.custom-controls{display:none;width:100%;padding:8px 16px;background:rgba(10,10,15,.9);border-top:1px solid #1e1a2e;flex-shrink:0;gap:12px;align-items:center}.custom-controls.visible{display:flex}.ctrl-btn{background:0 0;border:none;color:#e8e4f0;font-size:18px;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .15s;flex-shrink:0;width:36px;height:36px}.ctrl-btn:hover{background:rgba(255,255,255,.08)}.ctrl-btn:active{background:rgba(255,255,255,.15)}.seek-bar-container{flex:1;display:flex;align-items:center;gap:8px;min-width:0}.time-label{font-size:11px;color:#8a819e;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:36px}.seek-bar,.volume-slider{-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;outline:0;cursor:pointer;background:#2d2744}.seek-bar{flex:1;min-width:0}.volume-slider{width:80px;flex-shrink:0}.seek-bar::-webkit-slider-thumb,.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#c34cff;cursor:pointer;border:none}.seek-bar::-moz-range-thumb,.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#c34cff;cursor:pointer;border:none}.volume-group{display:flex;align-items:center;gap:4px;flex-shrink:0}.chat-col{width:280px;border-left:1px solid #1e1a2e;display:flex;flex-direction:column;background:rgba(10,10,15,.6);flex-shrink:0}.chat-header{padding:14px 16px;border-bottom:1px solid #1e1a2e;font-size:13px;font-weight:600;color:#8a819e;text-transform:uppercase;letter-spacing:1.5px}.chat-messages{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.chat-empty{color:#3d3656;font-size:13px;text-align:center;margin-top:40px}.chat-msg{padding:8px 12px;border-radius:10px;background:rgba(255,255,255,.03)}.chat-msg.mine{background:rgba(195,76,255,.1);border-top-right-radius:2px}.chat-msg:not(.mine){border-top-left-radius:2px}.chat-nick{font-size:11px;font-weight:700;margin-bottom:3px}.chat-nick.mine{color:#c34cff}.chat-nick:not(.mine){color:#ff4d6a}.chat-text{font-size:13px;line-height:1.4;color:#ccc;word-break:break-word}.chat-system{text-align:center;font-size:11px;color:#554e6a;padding:4px 0;font-style:italic}.chat-input-row{padding:12px 14px;border-top:1px solid #1e1a2e;display:flex;gap:8px}#chatInput{flex:1;padding:10px 14px;border-radius:10px;font-size:13px}.btn-send{padding:10px 14px;border-radius:10px;border:none;background:#2d2744;color:#c34cff;font-size:16px;cursor:pointer}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}.pulsing{animation:1.5s ease-in-out infinite pulse}.btn-leave{padding:6px 14px;border-radius:8px;border:1px solid #3d3656;background:0 0;color:#8a819e;font-size:12px;font-weight:600;cursor:pointer;transition:.2s;font-family:inherit;letter-spacing:.3px}.btn-leave:hover{border-color:#ff4d6a;color:#ff4d6a;background:rgba(255,77,106,.07)}.speed-btn{background:rgba(195,76,255,.1);border:1px solid #2d2744;color:#c34cff;font-size:11px;font-weight:700;padding:4px 8px;border-radius:6px;cursor:pointer;font-family:inherit;transition:.15s;flex-shrink:0;letter-spacing:.5px;height:36px;min-width:36px}.speed-btn:hover{background:rgba(195,76,255,.2)}.now-playing{padding:6px 20px;background:rgba(10,10,15,.7);border-bottom:1px solid #1e1a2e;font-size:12px;color:#8a819e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:none}.now-playing.visible{display:block}.now-playing span{color:#c34cff;font-weight:600}.qr-modal-backdrop{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center}.qr-modal-backdrop.active{display:flex}.qr-modal{background:#12101f;border:1px solid #2d2744;border-radius:16px;padding:28px 32px;text-align:center;width:280px}.qr-modal h3{font-size:15px;font-weight:600;margin-bottom:6px;color:#e8e4f0}.qr-modal p{font-size:12px;color:#554e6a;margin-bottom:20px}#qrCanvas{margin:0 auto 20px;display:block;border-radius:8px}.qr-container{margin:0 auto 20px;width:180px;height:180px;border-radius:8px;overflow:hidden}.qr-code-big{font-size:28px;font-weight:700;letter-spacing:6px;color:#c34cff;margin-bottom:6px}.qr-close{width:100%;padding:10px;border-radius:10px;border:1px solid #2d2744;background:0 0;color:#8a819e;font-size:13px;cursor:pointer;font-family:inherit;transition:.2s;margin-top:4px}.qr-close:hover{border-color:#c34cff;color:#c34cff}.yt-player-host{width:100%;height:100%;position:absolute;top:0;left:0}.yt-player-inner{width:100%;height:100%}.qr-canvas-hidden{display:none}.chat-toggle-btn{display:none;background:rgba(195,76,255,.15);border:1px solid #2d2744;color:#c34cff;font-size:16px;cursor:pointer;border-radius:8px;padding:0 12px;height:36px;font-family:inherit;transition:.15s;flex-shrink:0}.chat-toggle-btn:hover{background:rgba(195,76,255,.25)}@media (max-width:700px){.volume-group{display:none}.chat-toggle-btn{display:flex;align-items:center;gap:6px;font-size:13px}.chat-col{position:fixed;bottom:0;left:0;right:0;width:100%;height:65vh;z-index:50;border-left:none;border-top:1px solid #2d2744;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.chat-col.open{transform:translateY(0)}.chat-header{display:flex;align-items:center;justify-content:space-between}.chat-close-btn{background:0 0;border:none;color:#8a819e;font-size:18px;cursor:pointer;padding:0 4px;line-height:1}}@media (min-width:701px){.chat-close-btn{display:none}}