body{margin:0;padding:0}#root{flex-direction:column;width:100%;min-height:100svh;display:flex}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0b0c14;--surface:#13141f;--surface2:#1c1e2e;--surface3:#252840;--accent:#e8415a;--gold:#f5a623;--text:#dde1f0;--text-dim:#6b7199;--border:#282b45;--radius:12px;--radius-sm:8px}.app{background:var(--bg);height:100svh;color:var(--text);flex-direction:column;font-family:Segoe UI,system-ui,sans-serif;display:flex;overflow:hidden}.error-banner{border-bottom:1px solid var(--accent);color:#ffdfe4;background:#e8415a2e;padding:.55rem 1rem;font-size:.85rem}.main{flex:1;display:flex;overflow:hidden}.header{background:var(--surface);border-bottom:2px solid var(--accent);flex-shrink:0;padding:.9rem 1.5rem}.header-inner{align-items:center;gap:.6rem;display:flex}.header-icon{font-size:1.4rem}.header h1{letter-spacing:.3em;color:var(--accent);text-transform:uppercase;font-size:1.5rem;font-weight:800;line-height:1}.header-logo{letter-spacing:.3em;color:var(--accent);text-transform:uppercase;font-size:1.5rem;font-weight:800;line-height:1;text-decoration:none;transition:opacity .15s}.header-logo:hover{opacity:.8}.sidebar{background:var(--surface);border-right:1px solid var(--border);scrollbar-width:none;flex-direction:column;flex-shrink:0;width:360px;min-width:320px;max-width:420px;display:flex;overflow-y:auto}.sidebar::-webkit-scrollbar{display:none}.sidebar-hidden{border-right:none;overflow:hidden;width:0!important;min-width:0!important}.section{border-bottom:1px solid var(--border);padding:1.2rem}.songs-section{flex-direction:column;flex:1;min-height:0;display:flex}.songs-content{flex-direction:column;flex:1;min-height:0;padding:0 1.2rem 1.2rem;display:flex}.section-title-row{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;justify-content:space-between;align-items:center;margin:-.2rem -.4rem 0;padding:.2rem .4rem;transition:background .12s;display:flex}.section-title-row:hover{background:var(--surface2)}.section-title-row+*{margin-top:.8rem}.section-title{letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:0;font-size:.72rem;font-weight:700;line-height:1}.section-arrow{color:var(--text-dim);flex-shrink:0;margin-left:auto;font-size:.6rem;transition:color .12s}.section-title-row:hover .section-arrow{color:var(--accent)}.panel-title-row{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:.5rem;margin:-.2rem -.4rem 0;padding:.2rem .4rem;transition:background .12s;display:flex}.panel-title-row:hover{background:#ffffff0f}.panel-title-row:hover .section-arrow{color:var(--accent)}.panel-title-row+*{margin-top:.6rem}.panel-title-with-setting{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.panel-header-setting{background:var(--surface3);border-radius:20px;flex-shrink:0;align-items:center;gap:.4rem;margin-left:auto;padding:.2rem .6rem .2rem .5rem;display:flex}.panel-header-label{color:var(--text-dim);white-space:nowrap;font-size:.72rem}.note-picker-sm .note-btn{width:auto;min-width:1.6rem;height:1.5rem;padding:0 .35rem;font-size:.75rem}.playlist-list{flex-direction:column;gap:.35rem;margin-bottom:.8rem;display:flex}.playlist-item{background:var(--surface2);border-radius:var(--radius-sm);border:1px solid #0000;align-items:center;gap:.4rem;padding:.35rem .5rem;transition:border-color .15s;display:flex}.playlist-item.active{border-color:var(--accent);background:var(--surface3)}.playlist-item.playing,.playlist-item.active.playing{border-color:var(--gold)}.playing-dot{color:var(--gold);font-size:.85rem;animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.playlist-name-btn{color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;flex:1;justify-content:space-between;align-items:center;gap:.5rem;padding:.25rem 0;font-size:.9rem;display:flex}.playlist-name-btn:hover{color:var(--gold)}.count{color:var(--text-dim);background:var(--surface3);border-radius:20px;flex-shrink:0;padding:.1rem .45rem;font-size:.75rem}.playlist-actions{flex-shrink:0;gap:.2rem;display:flex}.edit-input{background:var(--surface3);border:1px solid var(--accent);color:var(--text);border-radius:6px;flex:1;padding:.25rem .5rem;font-size:.9rem}.edit-input:focus{outline:none}button{cursor:pointer;border:none;transition:all .15s}.btn-icon{color:var(--text-dim);background:0 0;border-radius:5px;padding:.25rem .35rem;font-size:.85rem;line-height:1}.btn-icon:hover{background:var(--surface3);color:var(--text)}.btn-icon.danger:hover{color:var(--accent);background:#e8415a26}.btn-icon.play{color:var(--gold)}.btn-icon.play:hover{color:var(--gold);background:#f5a6231f}.btn-icon.play:disabled{color:var(--text-dim);opacity:.4;cursor:not-allowed}.btn-accent{background:var(--accent);color:#fff;border-radius:var(--radius-sm);flex-shrink:0;padding:.45rem .75rem;font-size:1.1rem;font-weight:700;line-height:1}.btn-accent:hover{opacity:.85}.btn-primary{background:var(--surface3);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;padding:.55rem 1rem;font-size:.875rem;font-weight:600}.btn-primary:hover{border-color:var(--accent);color:var(--accent)}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);flex:1;padding:.55rem .8rem;font-size:.8rem;font-weight:600}.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-file{text-align:center;justify-content:center;align-items:center;display:inline-flex;position:relative;overflow:hidden}.btn-file input{opacity:0;cursor:pointer;position:absolute;inset:0}.btn-start{background:linear-gradient(135deg, var(--accent), var(--gold));color:#fff;letter-spacing:.12em;border-radius:30px;padding:.7rem 2rem;font-size:1rem;font-weight:800;box-shadow:0 4px 18px #e8415a59}.btn-start:hover:not(:disabled){transform:scale(1.04);box-shadow:0 6px 24px #e8415a8c}.btn-start:disabled{opacity:.35;cursor:not-allowed;transform:none}.btn-stop{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border);letter-spacing:.1em;border-radius:30px;padding:.7rem 2rem;font-size:.95rem;font-weight:600}.btn-stop:hover{border-color:var(--accent);color:var(--accent)}.player-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;display:flex}.btn-ctrl{background:var(--surface2);color:var(--text);border:1px solid var(--border);white-space:nowrap;letter-spacing:.03em;border-radius:20px;justify-content:center;align-items:center;height:2.4rem;padding:0 1.1rem;font-size:.9rem;font-weight:600;transition:all .15s;display:inline-flex}.btn-ctrl:hover{border-color:var(--gold);color:var(--gold)}.btn-ctrl:disabled{opacity:.35;cursor:not-allowed}.btn-ctrl-play,.btn-ctrl-skip,.btn-ctrl-stop{min-width:5.5rem}.btn-ctrl-play{color:#4ade80}.btn-ctrl-play:hover{color:#4ade80;border-color:#4ade80}.btn-ctrl-skip{color:var(--gold)}.btn-ctrl-skip:hover{border-color:var(--gold);color:var(--gold)}.btn-ctrl-stop{color:var(--accent)}.btn-ctrl-start{background:linear-gradient(135deg, var(--accent), var(--gold));color:#fff;letter-spacing:.1em;border-color:#0000}.btn-ctrl-start:hover:not(:disabled){opacity:.88;color:#fff;border-color:#0000}.btn-ctrl-stop:hover{border-color:var(--accent);color:var(--accent)}.volume-row{align-items:center;gap:.5rem;width:100%;padding:0 .25rem;display:flex}.volume-icon{color:var(--text-dim);flex-shrink:0;font-size:.9rem}.volume-slider{appearance:none;background:var(--surface3);cursor:pointer;border:none;border-radius:2px;outline:none;flex:1;width:auto;height:4px;padding:0}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--gold);cursor:pointer;border-radius:50%;width:14px;height:14px}.volume-slider::-moz-range-thumb{background:var(--gold);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.play-controls{justify-content:center;margin-top:auto;padding:1rem 0 .2rem;display:flex}input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);width:100%;padding:.5rem .75rem;font-size:.875rem;transition:border-color .15s}input::placeholder{color:var(--text-dim)}input:focus{border-color:var(--accent);outline:none}input.input-error{border-color:var(--accent)}.error-msg{color:var(--accent);margin-top:-.25rem;font-size:.78rem}.add-row{gap:.5rem;display:flex}.playlist-import-export{gap:.5rem;margin-top:.5rem;display:flex}.add-song-form{flex-direction:column;gap:.45rem;margin-bottom:.5rem;display:flex}.song-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;flex:1;gap:.35rem;display:flex;overflow-y:auto}.song-item{background:var(--surface2);border-radius:var(--radius-sm);border:1px solid #0000;align-items:center;gap:.5rem;padding:.35rem .5rem;display:flex}.song-item.song-playing{border-color:var(--gold)}.song-item-clickable{cursor:pointer}.song-item-clickable:hover{border-color:var(--accent);background:var(--surface3)}.song-thumb{object-fit:cover;background:var(--surface3);border-radius:4px;flex-shrink:0;width:44px;height:33px}.song-title{text-overflow:ellipsis;white-space:nowrap;color:var(--text);flex:1;font-size:.82rem;overflow:hidden}.empty-hint{color:var(--text-dim);text-align:center;padding:.5rem 0;font-size:.82rem}.player-area{flex-direction:column;flex:1;gap:1.5rem;padding:1.5rem;display:flex;overflow-y:auto}.player-area-admin{flex-direction:column;padding:0;display:flex;overflow:hidden}.admin-scroll-area{flex-direction:column;flex:1;gap:1rem;padding:1rem;display:flex;overflow-y:auto}.admin-top-row{grid-template-columns:1fr auto;align-items:start;gap:1rem;display:grid}.admin-col{flex-direction:column;gap:1rem;min-width:0;display:flex}.admin-queue-qr{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.admin-qr-panel{flex-direction:column;flex-shrink:0;align-items:center;gap:.5rem;display:flex}.admin-qr-panel .section-title{margin:0}.admin-qr-panel svg{background:#000;border-radius:6px;padding:8px}.qr-clickable{cursor:pointer;border-radius:6px;position:relative;overflow:hidden}.qr-clickable:hover svg{opacity:.8}.qr-copied-overlay{color:#fff;background:#000000b3;border-radius:6px;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex;position:absolute;inset:0}.qr-hint{color:var(--text-dim);text-align:center;margin:0;font-size:.7rem}.admin-qr-panel .qr-url{color:var(--text-dim);word-break:break-all;text-align:center;max-width:166px;margin:0;font-size:.6rem}.voting-panel-bottom{background:var(--surface);border-top:2px solid var(--accent);flex-direction:column-reverse;flex-shrink:0;display:flex}.voting-bottom-bar{cursor:pointer;-webkit-user-select:none;user-select:none;border-top:1px solid var(--border);align-items:center;gap:.5rem;padding:1.1rem 1rem;transition:background .12s;display:flex}.voting-bottom-bar:hover{background:#ffffff0d}.voting-bottom-bar:hover .section-arrow{color:var(--accent)}.voting-bottom-bar .section-title{flex:1}.voting-bottom-content{flex-direction:column;gap:.5rem;max-height:55vh;padding:.5rem 0;display:flex;overflow-y:auto}body.disco-mode .admin-scroll-area{padding-bottom:4rem}body.disco-mode .voting-panel-bottom{padding-bottom:3.5rem}body.disco-mode .sidebar{padding-bottom:4rem}.admin-col-center{flex-shrink:0}.player-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:1rem;padding:1.25rem;display:flex}.yt-wrapper{aspect-ratio:16/9;border-radius:var(--radius-sm);background:#000;width:320px;max-width:100%;position:relative;overflow:hidden}.yt-wrapper>div,.yt-wrapper>div>div,.yt-wrapper>div>iframe{border:0;position:absolute;top:0;left:0;width:100%!important;height:100%!important}.player-overlay{background:var(--surface2);color:var(--text-dim);z-index:2;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;font-size:.9rem;display:flex;position:absolute;inset:0}.yt-click-blocker{z-index:1;position:absolute;inset:0}.vinyl-icon{font-size:3rem;animation:3s linear infinite spin;display:block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.now-playing{text-align:center;flex-direction:column;align-items:center;gap:.3rem;display:flex}.now-label{letter-spacing:.22em;color:var(--accent);text-transform:uppercase;font-size:.68rem;font-weight:700}.load-pct{letter-spacing:.05em;color:var(--text-dim);font-weight:600}.now-title{color:var(--text);font-size:1.05rem;font-weight:700}.voting-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.voting-title{margin-bottom:1rem;color:var(--gold)!important}.candidates{flex-wrap:wrap;gap:1rem;display:flex}.candidate{background:var(--surface2);border:2px solid var(--border);border-radius:var(--radius);flex-direction:column;flex:1;gap:.6rem;min-width:180px;padding:.9rem;transition:border-color .2s,box-shadow .2s;display:flex;position:relative}.candidate.winning{border-color:var(--gold);box-shadow:0 0 16px #f5a62340}.candidate.voted{border-color:var(--accent);box-shadow:0 0 14px #e8415a33}.candidate-thumb{aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius-sm);background:var(--surface3);width:100%;display:block}.candidate-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:.85rem;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.candidate-footer{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.vote-count{color:var(--gold);min-width:2ch;font-size:1.6rem;font-weight:900;line-height:1}.btn-vote{background:var(--surface3);color:var(--text);border:1px solid var(--border);border-radius:20px;padding:.4rem .8rem;font-size:.8rem;font-weight:600}.btn-vote:hover{border-color:var(--accent);color:var(--accent)}.btn-vote.active{background:var(--accent);color:#fff;border-color:var(--accent)}.winning-badge{background:var(--gold);color:#000;letter-spacing:.1em;white-space:nowrap;border-radius:20px;padding:.2rem .6rem;font-size:.62rem;font-weight:900;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.splash{background:var(--bg);min-height:100svh;color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:1rem;display:flex}.splash-icon{font-size:3rem;animation:2s linear infinite spin}.login-title{color:var(--text);margin-top:.25rem;font-size:1.8rem;font-weight:700}.login-subtitle{color:var(--text-dim);margin-bottom:.5rem;font-size:.9rem}.btn-google-login{color:#1f1f1f;border-radius:var(--radius-sm);cursor:pointer;background:#fff;border:none;align-items:center;gap:.6rem;padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;transition:box-shadow .15s;display:flex}.btn-google-login:hover{box-shadow:0 2px 12px #fff3}.google-icon{flex-shrink:0}.header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.header-add-song{flex:1;align-items:center;gap:.4rem;min-width:0;display:flex}.header-song-input{background:var(--surface2);border:1px solid var(--border);min-width:0;color:var(--text);border-radius:20px;flex:1;padding:.35rem .9rem;font-size:.82rem}.header-song-input:focus{border-color:var(--accent);outline:none}.header-song-input::placeholder{color:var(--text-dim)}.btn-header-add{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;width:2rem;height:2rem;font-size:1.2rem;line-height:1}.btn-header-add:disabled{opacity:.35;cursor:default}.btn-qr-copy{background:var(--surface3);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:20px;margin-top:6px;padding:.35rem .9rem;font-size:.8rem;font-weight:600}.visitor-badge{letter-spacing:.1em;text-transform:uppercase;background:var(--surface3);color:var(--gold);border:1px solid var(--gold);border-radius:20px;margin-left:.8rem;padding:.2rem .6rem;font-size:.7rem;font-weight:700}.header-actions{align-items:center;gap:.5rem;display:flex}.btn-share{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border);text-align:center;cursor:pointer;white-space:nowrap;border-radius:20px;min-width:2.2rem;padding:.4rem .9rem;font-size:.8rem;font-weight:600;transition:all .15s}.btn-share:hover{border-color:var(--gold);color:var(--gold)}.btn-share-voter:hover,.btn-share-qr:hover{border-color:var(--accent);color:var(--accent)}.qr-overlay{z-index:1000;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.qr-modal{background:var(--surface1);border:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:center;gap:1rem;width:90%;max-width:320px;padding:2rem;display:flex;position:relative}.qr-modal h2{color:var(--text);margin:0;font-size:1.1rem}.qr-url{color:var(--text-dim);word-break:break-all;text-align:center;margin:0;font-size:.65rem}.qr-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;font-size:1.1rem;line-height:1;position:absolute;top:.6rem;right:.8rem}.qr-close:hover{color:var(--text)}.btn-sidebar-toggle{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border);cursor:pointer;border-radius:8px;margin-right:.25rem;padding:.3rem .55rem;font-size:.8rem;transition:border-color .15s,color .15s}.btn-sidebar-toggle:hover{border-color:var(--accent);color:var(--accent)}.header-join-row{align-items:center;gap:.3rem;display:flex}.header-join-input{background:var(--surface2);border:1px solid var(--border);width:130px;color:var(--text);border-radius:8px;padding:.3rem .6rem;font-size:.8rem}.header-join-input:focus{border-color:var(--accent);outline:none}.btn-view-toggle{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:20px;padding:.4rem .9rem;font-size:.8rem;font-weight:600;transition:all .15s}.btn-view-toggle:hover{border-color:var(--accent);color:var(--accent)}.now-timer{font-variant-numeric:tabular-nums;color:var(--gold);letter-spacing:.05em;font-size:1.4rem;font-weight:900}.guest-view{flex-direction:column;gap:.75rem;width:100%;max-width:540px;margin:0 auto;padding:.75rem;display:flex}.guest-now-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.guest-now-info{align-items:center;gap:.6rem;min-width:0;display:flex}.guest-now-label{letter-spacing:.08em;color:var(--gold);flex-shrink:0;font-size:.6rem;font-weight:700}.guest-now-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.guest-now-right{flex-shrink:0;align-items:center;gap:.6rem;display:flex}.guest-now-timer{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:.82rem}.guest-queue-toggle{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:6px;align-items:center;gap:.3rem;padding:.2rem .5rem;font-size:.75rem;display:flex}.guest-queue-toggle:hover{border-color:var(--accent);color:var(--accent)}.guest-queue{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.guest-queue-item{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:.4rem .8rem;display:flex}.guest-queue-item:last-child{border-bottom:none}.guest-queue-pos{color:var(--text-dim);text-align:center;flex-shrink:0;width:1rem;font-size:.7rem}.guest-queue-thumb{object-fit:cover;border-radius:3px;flex-shrink:0;width:40px;height:30px}.guest-queue-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.guest-voting{flex-direction:column;gap:.6rem;display:flex}.guest-voting-label{letter-spacing:.07em;color:var(--text-dim);text-transform:uppercase;margin:0;font-size:.65rem;font-weight:700}.guest-vote-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);transition:border-color .15s;overflow:hidden}.guest-vote-card.winning{border-color:var(--gold)}.guest-vote-card.voted{border-color:var(--accent)}.guest-vote-songs{flex-direction:column;gap:0;display:flex}.guest-vote-song{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:.5rem .75rem;display:flex}.guest-vote-thumb{object-fit:cover;border-radius:4px;flex-shrink:0;width:48px;height:36px}.guest-vote-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.guest-vote-btn{background:var(--surface2);width:100%;color:var(--text-dim);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.85rem 1rem;font-size:.9rem;font-weight:600;transition:background .15s,color .15s;display:flex}.guest-vote-btn:hover{background:var(--surface3);color:var(--text)}.guest-vote-btn.active{color:var(--accent);background:#63b3ed26}.guest-vote-card.winning .guest-vote-btn{background:#f5a6231a}.guest-vote-count{background:var(--surface3);color:var(--text-dim);border-radius:10px;padding:.1rem .45rem;font-size:.75rem}.guest-vote-btn.active .guest-vote-count{color:var(--accent);background:#63b3ed33}.guest-skip-row{justify-content:center;padding-top:.25rem;display:flex}.guest-skip-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:20px;padding:.5rem 1.2rem;font-size:.8rem;transition:all .15s}.guest-skip-btn:hover{border-color:var(--gold);color:var(--gold)}.guest-skip-btn.active{border-color:var(--gold);color:var(--gold);background:#f5a6231a}.guest-waiting{color:var(--text-dim);text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1rem;display:flex}.guest-waiting-icon{font-size:2.5rem}.guest-waiting p{margin:0;font-size:.9rem}.guest-footer{justify-content:center;gap:.6rem;margin-top:auto;padding:1rem 0 .5rem;display:flex}.guest-footer-btn{border:1px solid var(--border);color:var(--text-dim);cursor:not-allowed;opacity:.5;background:0 0;border-radius:20px;padding:.45rem .9rem;font-size:.78rem}.btn-header-share{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:8px;padding:.3rem .65rem;font-size:1rem;transition:border-color .15s,color .15s}.btn-header-share:hover{border-color:var(--accent);color:var(--accent)}.guest-suggest{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;margin:0 16px 12px;padding:14px 16px;display:flex}.guest-suggest-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);font-size:.7rem;font-weight:700}.guest-suggest-input{background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);width:100%;padding:8px 12px;font-size:.9rem}.guest-suggest-input:focus{border-color:var(--accent);outline:none}.guest-suggest-hint{color:var(--text-dim);font-size:.85rem}.guest-suggest-err{color:var(--accent);font-size:.82rem}.guest-suggest-ok{color:#4caf50;text-align:center;padding:8px 0;font-size:.9rem;font-weight:600}.guest-suggest-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;align-self:flex-end;padding:9px 16px;font-size:.9rem;font-weight:600}.guest-suggest-btn:disabled{opacity:.4;cursor:default}.queue-size-row{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:.4rem 1rem;display:flex}.queue-size-label{color:var(--text-dim);white-space:nowrap;font-size:.78rem}.note-picker-notes{gap:.15rem;display:flex}.note-icon-btn{color:var(--surface3);cursor:pointer;background:0 0;border:none;padding:0 .05rem;font-size:1.4rem;line-height:1;transition:color .1s,transform .1s}.note-icon-btn.active{color:var(--gold)}.note-icon-btn:hover{transform:scale(1.15)}.guest-rating{border-top:1px solid var(--border);flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.5rem;display:flex}.guest-rating-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem}.guest-rating-stars{gap:.3rem;display:flex}.rating-star{color:var(--surface3);cursor:pointer;background:0 0;border:none;padding:0;font-size:2rem;line-height:1;transition:color .1s,transform .1s}.rating-star:hover,.rating-star.active{color:var(--gold)}.rating-star:hover{transform:scale(1.15)}.guest-rating-value{color:var(--gold);font-size:.78rem}.playlist-stats-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;justify-content:center;align-items:center;gap:1.2rem;width:100%;padding:.45rem .9rem;display:flex}.playlist-stat{color:var(--text);white-space:nowrap;font-size:.82rem;font-weight:600}.playlist-stat-sub{color:var(--text-dim);font-size:.78rem;font-weight:400}.playlist-stat-dim{color:var(--text-dim);font-weight:400}.suggestions-list{flex-direction:column;gap:4px;padding:4px 0;display:flex}.suggestion-item{border-radius:var(--radius-sm);background:var(--surface2);align-items:center;gap:8px;padding:4px 8px;display:flex}.suggestion-actions{flex-shrink:0;gap:4px;margin-left:auto;display:flex}.setting-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;min-width:0;padding:.3rem 0;display:flex}.setting-label{color:var(--text-dim);flex-shrink:0;font-size:.8rem}.setting-toggle-group{gap:.2rem;display:flex}.sidebar-stats{background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);margin-top:.6rem;padding:.6rem .75rem}.sidebar-stats-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem;font-size:.72rem}.sidebar-stats-row{flex-wrap:wrap;gap:.75rem;display:flex}.sidebar-stat{color:var(--text);white-space:nowrap;font-size:.82rem;font-weight:600}.sidebar-stat-sub{color:var(--text-dim);font-size:.78rem;font-weight:400}.sidebar-stat-dim{color:var(--text-dim);font-weight:400}.btn-setting{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border);border-radius:20px;padding:.25rem .6rem;font-size:.72rem;font-weight:600;transition:all .15s}.btn-setting:hover{border-color:var(--accent);color:var(--accent)}.btn-setting.active{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-setting-toggle{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border);border-radius:20px;padding:.25rem .75rem;font-size:.72rem;font-weight:600;transition:all .15s}.btn-setting-toggle:hover{border-color:var(--gold);color:var(--gold)}.btn-setting-toggle.active{background:var(--gold);color:#000;border-color:var(--gold)}.setting-queue-row{align-items:center;gap:.6rem;display:flex}.queue-size-slider{appearance:none;background:var(--surface3);cursor:pointer;border-radius:2px;outline:none;width:7rem;height:4px}.queue-size-slider::-webkit-slider-thumb{appearance:none;background:var(--gold);cursor:pointer;border-radius:50%;width:14px;height:14px}.queue-size-slider::-moz-range-thumb{background:var(--gold);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.note-picker{align-items:center;gap:.25rem;display:flex}.note-btn{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface2);width:2rem;height:2rem;color:var(--text-dim);cursor:pointer;justify-content:center;align-items:center;padding:0;font-size:1rem;line-height:1;transition:background .12s,border-color .12s,color .12s;display:flex}.note-btn.active{background:var(--gold);border-color:var(--gold);color:#1a1000}.note-btn:hover:not(.active){border-color:var(--gold);color:var(--gold)}.queue-list{flex-direction:column;gap:.55rem;list-style:none;display:flex}.queue-item{background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:.7rem;padding:.45rem .6rem;display:flex}.queue-pos{color:var(--text-dim);text-align:center;min-width:1.1rem;font-size:.8rem;font-weight:700}.queue-item:first-child{border-color:var(--gold)}.queue-item:first-child .queue-pos{color:var(--gold)}.queue-thumb{object-fit:cover;border-radius:4px;flex-shrink:0;width:52px;height:38px}.queue-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.87rem;line-height:1.3;overflow:hidden}.skip-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:1rem;padding:.8rem 1.2rem;display:flex}.btn-skip{background:var(--surface2);color:var(--text);border:1.5px solid var(--border);cursor:pointer;border-radius:8px;padding:.45rem 1rem;font-size:.87rem;font-weight:600;transition:all .15s}.btn-skip:hover{border-color:var(--gold);color:var(--gold)}.btn-skip.active{background:var(--gold);color:#000;border-color:var(--gold)}.slot-cands{flex-direction:column;gap:.4rem;display:flex}.slot-cand{border-radius:var(--radius-sm);border:1px solid #0000;align-items:center;gap:.6rem;padding:.35rem .5rem;transition:border-color .15s,background .15s;display:flex}.slot-cand.winning{border-color:var(--gold);background:#f5a62314}.slot-cand.voted{border-color:var(--accent);background:#e8415a1a}.slot-thumb{object-fit:cover;border-radius:4px;flex-shrink:0;width:56px;height:42px}.slot-title{min-width:0;color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.87rem;line-height:1.3;overflow:hidden}.slot-votes{color:var(--gold);text-align:right;min-width:1.2rem;font-size:.78rem;font-weight:700}.btn-vote-sm{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.85rem;transition:all .15s;display:flex}.btn-vote-sm:hover{border-color:var(--accent);color:var(--accent)}.btn-vote-sm.active{background:var(--accent);color:#fff;border-color:var(--accent)}.skip-count{color:var(--text-dim);white-space:nowrap;font-size:.82rem;font-weight:600}.skip-threshold-input{background:var(--surface2);width:4.5rem;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:.28rem .5rem;font-size:.82rem}.skip-threshold-input:focus{border-color:var(--gold);outline:none}.setting-hint{color:var(--text-dim);font-size:.75rem}.room-link-row{align-items:center;gap:.4rem;display:flex}.room-link-input{min-width:0;color:var(--text-dim);cursor:text;text-overflow:ellipsis;flex:1;font-size:.72rem;overflow:hidden}.guest-thumb{object-fit:cover;width:100%;height:100%;display:block}.options-list{flex-direction:column;gap:.75rem;display:flex}.options-list.options-columns{flex-direction:row;align-items:stretch}.options-list.options-columns .vote-option{flex:1;min-width:0}.vote-option{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:border-color .15s;overflow:hidden}.vote-option.winning{border-color:var(--gold)}.vote-option.voted{border-color:var(--accent)}.vote-option-header{background:var(--surface3);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:.4rem;padding:.5rem .75rem;display:flex}.vote-option.winning .vote-option-header{background:#f5a6231a}.vote-option.voted .vote-option-header{background:#e8415a1a}.vote-option-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);flex:1;font-size:.82rem;font-weight:700}.vote-option-count{color:var(--gold);font-size:.78rem;font-weight:700}.btn-vote-option{border:1.5px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;white-space:nowrap;border-radius:20px;padding:.25rem .7rem;font-size:.78rem;font-weight:700;transition:all .15s}.btn-vote-option:hover{border-color:var(--accent);color:var(--accent)}.btn-vote-option.active{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-choose-option{border:1.5px solid var(--gold);background:var(--surface);color:var(--gold);cursor:pointer;white-space:nowrap;border-radius:20px;padding:.25rem .7rem;font-size:.78rem;font-weight:700;transition:all .15s}.btn-choose-option:hover{background:var(--gold);color:#000}.option-songs{flex-direction:column;display:flex}.option-song-item{border-bottom:1px solid var(--border);align-items:center;gap:.5rem;padding:.35rem .6rem;display:flex}.option-song-item:last-child{border-bottom:none}.option-song-pos{color:var(--text-dim);text-align:center;flex-shrink:0;width:1rem;font-size:.72rem;font-weight:700}body.disco-mode .app{background:0 0}.yt-player-disco{z-index:-1;pointer-events:none;background:#000;position:fixed;inset:-30px;overflow:hidden}.yt-player-disco>div{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:max(100%,177.78vh)!important;height:max(100%,56.25vw)!important}.yt-player-disco>div>div,.yt-player-disco>div>iframe{border:0;position:absolute;top:0;left:0;width:100%!important;height:100%!important}.player-card--disco{background:0 0;border:none;height:0;min-height:0;padding:0;overflow:hidden}.disco-bar{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0b0c14e0;border-top:1px solid #ffffff1a;align-items:center;gap:1rem;padding:.65rem 1.5rem;display:flex;position:fixed;bottom:0;left:0;right:0}.disco-bar-info{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex;overflow:hidden}.disco-bar-title{white-space:nowrap;text-overflow:ellipsis;color:var(--text);font-size:.95rem;font-weight:700;overflow:hidden}.disco-bar-controls,.disco-bar-extras{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.disco-slider{flex:none;width:80px}.disco-blur-label{color:var(--text-dim);white-space:nowrap;letter-spacing:.05em;font-size:.72rem}.btn-ctrl-disco{padding:0 .75rem;font-size:1.1rem}.btn-ctrl-disco-exit{border-color:var(--accent);color:var(--accent)}.btn-ctrl-disco-exit:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.homepage{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:3rem;min-height:100svh;padding:2rem;display:flex}.homepage-hero{text-align:center;flex-direction:column;align-items:center;gap:.5rem;display:flex}.homepage-logo{align-items:center;gap:.5rem;display:flex}.homepage-logo-icon{font-size:2.2rem;line-height:1}.homepage-logo .header-logo{font-size:2.2rem}.homepage-actions{flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:420px;display:flex}.homepage-btn{cursor:pointer;border:2px solid #0000;border-radius:12px;justify-content:center;align-items:center;gap:.6rem;width:100%;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;transition:transform .12s,box-shadow .12s;display:flex}.homepage-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #0006}.homepage-btn:active{transform:translateY(0)}.homepage-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent);padding:1.2rem 1.5rem;font-size:1.2rem}.homepage-btn--primary:hover{box-shadow:0 6px 24px rgba(var(--accent-rgb,99, 102, 241), .5)}.homepage-btn-icon{font-size:1.1em}.homepage-btn--secondary{background:var(--surface2);color:var(--text);border-color:var(--border);white-space:nowrap;flex-shrink:0;width:auto}.homepage-btn--secondary:disabled{opacity:.4;cursor:not-allowed;transform:none}.homepage-divider{width:100%;color:var(--text-dim);align-items:center;gap:.75rem;font-size:.85rem;display:flex}.homepage-divider:before,.homepage-divider:after{content:"";background:var(--border);flex:1;height:1px}.homepage-join{flex-direction:column;gap:.6rem;width:100%;display:flex}.homepage-join-label{color:var(--text-dim);text-align:center;font-size:.9rem;font-weight:600}.homepage-join-row{gap:.5rem;display:flex}.homepage-join-input{background:var(--surface2);color:var(--text);border:2px solid var(--border);border-radius:10px;outline:none;flex:1;padding:.9rem 1rem;font-family:monospace;font-size:1rem;transition:border-color .15s}.homepage-join-input:focus{border-color:var(--accent)}.homepage-join-input::placeholder{color:var(--text-dim);font-family:inherit}.guest-player{border-bottom:1px solid var(--border);flex-direction:column;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.guest-player-toggle{border:1.5px solid var(--border);background:var(--surface2);color:var(--text-dim);cursor:pointer;border-radius:999px;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.9rem;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:flex}.guest-player-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent)}.guest-player-toggle:hover:not(.active){border-color:var(--accent);color:var(--text)}.guest-player-yt{aspect-ratio:16/9;background:#000;border-radius:10px;width:100%;max-width:480px;overflow:hidden}.guest-player-yt>div{width:100%;height:100%}.guest-player-yt iframe{display:block;width:100%!important;height:100%!important}
