.queue{padding:16px 20px}.queue--empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;color:var(--text-muted);text-align:center;font-size:.85rem}.queue--empty p{font-weight:500}.queue__title{font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.queue__vote-hint{display:flex;align-items:center;gap:4px;font-size:.65rem;color:var(--accent-light);background:#7c3aed1f;border-radius:20px;padding:2px 8px;text-transform:none;letter-spacing:0;font-weight:500;margin-left:auto}.queue__list{list-style:none;display:flex;flex-direction:column;gap:4px}.queue__item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-card);border-radius:10px;border:1px solid var(--border);transition:background .12s}.queue__item:hover{background:var(--bg-hover)}.queue__position{font-size:.72rem;color:var(--text-muted);width:18px;text-align:center;flex-shrink:0}.queue__art{flex-shrink:0;width:40px;height:40px;border-radius:6px;overflow:hidden;background:var(--bg-hover)}.queue__art img{width:100%;height:100%;object-fit:cover}.queue__art-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.queue__info{flex:1;min-width:0}.queue__song-title{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue__song-meta{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:6px;margin-top:2px}.queue__duration{display:flex;align-items:center;gap:3px}.queue__requester{font-size:.68rem;color:var(--accent);margin-top:2px}.queue__votes{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}.vote-btn{background:none;border:1px solid var(--border);border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:background .12s,color .12s,border-color .12s}.vote-btn--up:hover:not(:disabled){background:#22c55e26;color:#22c55e;border-color:#22c55e}.vote-btn--down:hover:not(:disabled){background:#ef444426;color:#ef4444;border-color:#ef4444}.vote-btn--locked{opacity:.35;cursor:not-allowed}.vote-btn:disabled{cursor:not-allowed}.vote-count{font-size:.78rem;font-weight:700;min-width:22px;text-align:center}.search{padding:16px 20px;background:var(--bg-card);border-top:1px solid var(--border)}.search__title{font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;margin-bottom:10px}.search__source-tabs{display:flex;gap:6px;margin-bottom:12px}.source-tab{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:.78rem;color:var(--text-muted);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.source-tab:hover{border-color:var(--accent);color:var(--accent)}.source-tab--active{background:var(--accent);border-color:var(--accent);color:#fff}.search__form{margin-bottom:8px}.search__input-wrap{display:flex;gap:8px}.search__input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font-size:.88rem;outline:none;transition:border-color .15s}.search__input:focus{border-color:var(--accent)}.search__input::placeholder{color:var(--text-muted)}.search__input:disabled{opacity:.5}.search__btn{background:var(--accent);border:none;border-radius:10px;width:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;flex-shrink:0;transition:background .15s}.search__btn:hover:not(:disabled){background:var(--accent-dim)}.search__btn:disabled{opacity:.5;cursor:not-allowed}.search__error{font-size:.78rem;color:#ef4444;margin-bottom:8px}.search__results{list-style:none;display:flex;flex-direction:column;gap:4px;max-height:260px;overflow-y:auto;margin-top:8px}.search__result-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:10px;transition:background .12s}.search__result-item:hover{background:var(--bg-hover)}.search__result-thumb{width:48px;height:36px;object-fit:cover;border-radius:5px;flex-shrink:0}.search__result-info{flex:1;min-width:0}.search__result-title{font-size:.83rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search__result-artist{font-size:.72rem;color:var(--text-muted)}.search__add-btn{background:var(--accent);border:none;border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;flex-shrink:0;transition:background .12s}.search__add-btn:hover:not(:disabled){background:var(--accent-dim)}.search__add-btn:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.now-playing{padding:20px;background:linear-gradient(160deg,#1a1040 0%,var(--bg) 100%)}.now-playing--empty{display:flex;align-items:center;justify-content:center;padding:40px 20px}.now-playing__placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);text-align:center}.now-playing__placeholder p{font-size:1rem;font-weight:500}.now-playing__placeholder span{font-size:.82rem}.now-playing__label{font-size:.65rem;font-weight:700;letter-spacing:.12em;color:var(--accent-light);margin-bottom:12px}.now-playing__content{display:flex;gap:16px;align-items:center}.now-playing__art{flex-shrink:0;width:72px;height:72px;border-radius:10px;overflow:hidden;background:var(--bg-card)}.now-playing__art img{width:100%;height:100%;object-fit:cover}.now-playing__art-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.now-playing__info{flex:1;min-width:0}.now-playing__title{font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.now-playing__artist{font-size:.85rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.now-playing__meta{font-size:.72rem;color:var(--accent-light)}.register-page{position:relative;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg);overflow:hidden}.register-card{position:relative;z-index:1;width:100%;max-width:420px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:20px;padding:40px 32px;box-shadow:0 8px 40px #00000080,0 0 0 1px #7c3aed14}.rp-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;pointer-events:none;animation:orb-float 10s ease-in-out infinite}.rp-orb--1{width:340px;height:340px;background:var(--accent);top:-80px;right:-80px}.rp-orb--2{width:260px;height:260px;background:var(--neon-cyan);bottom:-60px;left:-60px;animation-delay:-5s}.register-icon{font-size:48px;text-align:center;margin-bottom:12px}.register-card h1{color:var(--accent, #a78bfa);font-size:28px;font-weight:700;text-align:center;margin:0 0 6px}.register-subtitle{color:var(--text-secondary, #94a3b8);font-size:14px;text-align:center;margin:0 0 28px}.form-group{margin-bottom:16px}.form-group label{display:block;color:var(--text-primary, #e2e8f0);font-size:13px;font-weight:600;margin-bottom:6px;letter-spacing:.3px}.form-group input{width:100%;background:var(--bg-tertiary, #0f0f1a);border:1px solid var(--border, #2d2d4e);border-radius:8px;color:var(--text-primary, #e2e8f0);font-size:15px;padding:11px 14px;box-sizing:border-box;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent, #a78bfa)}.form-group input::placeholder{color:var(--text-muted, #475569)}.field-error{display:block;color:#f87171;font-size:12px;margin-top:4px}.form-divider{display:flex;align-items:center;gap:10px;margin:20px 0 16px}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--border, #2d2d4e)}.form-divider span{color:var(--text-muted, #475569);font-size:12px;white-space:nowrap}.btn-primary{width:100%;background:var(--accent, #7c3aed);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;padding:13px;cursor:pointer;margin-top:8px;transition:background .2s,opacity .2s}.btn-primary:hover:not(:disabled){background:#6d28d9}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{width:100%;background:transparent;color:var(--text-secondary, #94a3b8);border:1px solid var(--border, #2d2d4e);border-radius:8px;font-size:14px;padding:11px;cursor:pointer;margin-top:12px;transition:border-color .2s,color .2s}.btn-secondary:hover{border-color:var(--accent, #a78bfa);color:var(--text-primary, #e2e8f0)}.whatsapp-btn{background:#25d366!important;margin-top:20px}.whatsapp-btn:hover:not(:disabled){background:#1ebe5d!important}.tab-switch{display:flex;gap:4px;background:var(--bg-tertiary, #0f0f1a);border-radius:10px;padding:4px;margin-bottom:24px}.tab-btn{flex:1;background:none;border:none;border-radius:7px;color:var(--text-muted, #475569);font-size:13px;font-weight:600;padding:9px 8px;cursor:pointer;transition:background .18s,color .18s}.tab-btn--active{background:var(--accent, #7c3aed);color:#fff}.tab-btn:not(.tab-btn--active):hover{color:var(--text-primary, #e2e8f0)}.register-hint{color:var(--text-secondary, #94a3b8);font-size:14px;text-align:center;margin:0 0 12px;line-height:1.5}.register-hint.secondary{color:var(--text-muted, #475569);font-size:12px}.verify-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg-primary, #0f0f1a)}.verify-card{width:100%;max-width:380px;background:var(--bg-secondary, #1a1a2e);border-radius:16px;padding:48px 32px;text-align:center;box-shadow:0 8px 32px #0006}.verify-icon{font-size:52px;margin-bottom:16px}.verify-spinner{font-size:40px;margin-bottom:16px;animation:spin 1.2s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.verify-card h1{color:var(--accent, #a78bfa);font-size:24px;margin:0 0 12px}.verify-text{color:var(--text-secondary, #94a3b8);font-size:15px;line-height:1.6;margin:0 0 12px}.verify-hint{color:var(--text-muted, #475569);font-size:13px;margin:0}.btn-primary{width:100%;background:var(--accent, #7c3aed);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;padding:13px;cursor:pointer;margin-top:20px;transition:background .2s}.btn-primary:hover{background:#6d28d9}.admin-login-page{position:relative;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg);overflow:hidden}.alp-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;pointer-events:none;animation:orb-float 9s ease-in-out infinite}.alp-orb--1{width:300px;height:300px;background:var(--accent);top:-60px;left:-60px}.alp-orb--2{width:240px;height:240px;background:var(--neon-pink);bottom:-60px;right:-40px;animation-delay:-4.5s}.admin-login-card{position:relative;z-index:1;width:100%;max-width:360px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:20px;padding:40px 32px;text-align:center;box-shadow:0 8px 40px #00000080,0 0 0 1px #7c3aed14}.admin-login-icon{font-size:44px;margin-bottom:12px}.admin-login-card h1{color:var(--accent-light);font-size:22px;margin:0 0 4px}.admin-login-subtitle{color:var(--text-muted);font-size:13px;margin:0 0 28px}.form-group{margin-bottom:16px;text-align:left}.form-group label{display:block;color:var(--text-secondary);font-size:12px;font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-group input{width:100%;background:var(--bg);border:1px solid var(--border-solid);border-radius:8px;color:var(--text);font-size:15px;padding:11px 14px;box-sizing:border-box;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent)}.admin-login-error{color:#f87171;font-size:13px;margin:0 0 12px}.btn-admin{width:100%;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;padding:12px;cursor:pointer;transition:background .2s,opacity .2s;margin-top:4px}.btn-admin:hover:not(:disabled){background:var(--accent-dim)}.btn-admin:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{width:100%;background:transparent;color:var(--text-secondary);border:1px solid var(--border-solid);border-radius:8px;font-size:14px;padding:10px;cursor:pointer;margin-top:8px;transition:border-color .2s}.btn-secondary:hover{border-color:var(--accent);color:var(--accent-light)}.btn-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.btn-link:hover{color:var(--accent-light)}.admin-login-success{color:#4ade80;font-size:13px;margin:0 0 12px;background:#4ade801a;padding:8px 12px;border-radius:6px}.admin-page{min-height:100vh;background:#0a0a14;color:#e2e8f0;font-size:14px}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:#12122a;border-bottom:1px solid #1e1e42;position:sticky;top:0;z-index:10}.admin-header-left{display:flex;align-items:center;gap:10px}.admin-header-icon{font-size:20px}.admin-header-title{color:#c4b5fd;font-size:16px;font-weight:700}.admin-header-sub{color:#475569;font-size:12px;border-left:1px solid #2d2d5e;padding-left:10px}.admin-header-right{display:flex;align-items:center;gap:10px}.btn-icon{background:none;border:1px solid #2d2d5e;border-radius:6px;color:#94a3b8;padding:6px 8px;cursor:pointer;display:flex;align-items:center;transition:border-color .2s,color .2s}.btn-icon:hover{border-color:#7c3aed;color:#c4b5fd}.btn-logout{display:flex;align-items:center;gap:6px;background:none;border:1px solid #3f1d54;border-radius:6px;color:#c084fc;padding:6px 12px;cursor:pointer;font-size:13px;transition:background .2s}.btn-logout:hover{background:#1a0a2e}.admin-body{display:grid;grid-template-columns:360px 1fr;gap:20px;padding:20px 24px;max-width:1280px;margin:0 auto}@media (max-width: 900px){.admin-body{grid-template-columns:1fr}}@media (max-width: 640px){.admin-header{padding:10px 14px}.admin-header-sub{display:none}.admin-header-title{font-size:14px}.admin-body{padding:12px 12px 88px;gap:12px}.admin-left,.admin-right{display:contents}.admin-card{margin-bottom:0}.admin-section--player{order:1}.admin-section--search{order:2}.admin-section--queue{order:3}.admin-section--played{order:4}.admin-section--nowplaying{order:5}.admin-section--stats{order:6}.admin-section--qr{order:7}.admin-section--export{order:8}.admin-page--tab-player .admin-section--search,.admin-page--tab-player .admin-section--queue,.admin-page--tab-player .admin-section--played,.admin-page--tab-player .admin-section--nowplaying,.admin-page--tab-player .admin-section--stats,.admin-page--tab-player .admin-section--qr,.admin-page--tab-player .admin-section--export,.admin-page--tab-queue .admin-section--player,.admin-page--tab-queue .admin-section--nowplaying,.admin-page--tab-queue .admin-section--stats,.admin-page--tab-queue .admin-section--qr,.admin-page--tab-queue .admin-section--export,.admin-page--tab-more .admin-section--player,.admin-page--tab-more .admin-section--nowplaying,.admin-page--tab-more .admin-section--search,.admin-page--tab-more .admin-section--queue,.admin-page--tab-more .admin-section--played{display:none}.ctrl-btn{padding:12px 14px}.ctrl-btn--main{padding:14px 18px}.btn-play-now{padding:8px 12px;font-size:12px}.btn-delete,.btn-played-action{padding:8px 10px}.player-controls{flex-direction:column;align-items:stretch}.player-transport{justify-content:center}.volume-row{min-width:0}.np-title{max-width:100%}.audio-yt-note{display:none}}.mobile-tab-bar{display:none}@media (max-width: 640px){.mobile-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;background:#12122a;border-top:1px solid #1e1e42;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -4px 20px #0006}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 8px;background:none;border:none;color:#475569;font-size:11px;font-family:inherit;cursor:pointer;transition:color .15s;min-height:56px}.mobile-tab--active{color:#c4b5fd}.mobile-tab--active svg{filter:drop-shadow(0 0 6px rgba(196,181,253,.5))}}.admin-card{background:#12122a;border:1px solid #1e1e42;border-radius:12px;padding:18px 20px;margin-bottom:16px}.admin-card--full{height:fit-content}.admin-card-title{display:flex;align-items:center;gap:7px;color:#94a3b8;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin:0 0 16px}.admin-empty{color:#475569;font-size:13px;margin:0}.playing-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#4ade80;margin-left:6px;animation:pulse-dot 1.4s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.player-track-strip{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#0d0d20;border:1px solid #1e1e42;border-radius:8px;margin-bottom:12px}.player-thumb{width:44px;height:44px;border-radius:6px;object-fit:cover;flex-shrink:0}.player-track-info{flex:1;min-width:0}.player-track-title{color:#e2e8f0;font-size:13px;font-weight:600;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-track-artist{color:#64748b;font-size:11px;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-track-remaining{color:#7c3aed;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:38px;text-align:right}.player-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.player-transport{display:flex;align-items:center;gap:6px}.ctrl-btn{background:#1e1e42;border:1px solid #2d2d5e;border-radius:8px;color:#94a3b8;padding:10px 12px;cursor:pointer;display:flex;align-items:center;transition:background .2s,color .2s}.ctrl-btn:hover{background:#2d2d5e;color:#e2e8f0}.ctrl-btn--active{background:#7c3aed;border-color:#7c3aed;color:#fff}.ctrl-btn--main{padding:12px 16px;background:#1e1e42;border-color:#4c2889}.ctrl-btn--main:hover{background:#2d2d5e}.ctrl-btn--main.ctrl-btn--active{background:#7c3aed;border-color:#7c3aed}.ctrl-btn--loop-active{border-color:#7c3aed;color:#c4b5fd;background:#7c3aed2e}.progress-wrap{margin-bottom:14px}.progress-bar{width:100%;height:5px;background:#1e1e42;border-radius:3px;overflow:hidden;transition:height .15s}.progress-bar--seekable{cursor:pointer;height:7px}.progress-bar--seekable:hover{height:9px}.progress-fill{height:100%;background:#7c3aed;border-radius:3px;transition:width .4s linear}.progress-times{display:flex;justify-content:space-between;margin-top:5px;color:#475569;font-size:11px;font-variant-numeric:tabular-nums}.progress-remaining{color:#7c3aed;font-weight:600}.volume-row{display:flex;align-items:center;gap:8px;color:#64748b;flex:1;min-width:140px}.volume-slider{flex:1;accent-color:#7c3aed;cursor:pointer}.volume-label{color:#94a3b8;font-size:12px;min-width:32px}.now-playing-row{display:flex;gap:12px;align-items:flex-start}.np-thumb{width:56px;height:56px;border-radius:6px;object-fit:cover;flex-shrink:0}.np-title{color:#e2e8f0;font-size:14px;font-weight:600;margin:0 0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.np-artist{color:#94a3b8;font-size:12px;margin:0 0 3px}.np-meta{color:#475569;font-size:11px;margin:0}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-item{background:#0f0f22;border-radius:8px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:4px;color:#64748b}.stat-value{color:#c4b5fd;font-size:22px;font-weight:700;line-height:1}.stat-label{color:#475569;font-size:11px}.qr-section{display:flex;gap:16px;align-items:flex-start}.qr-image{width:100px;height:100px;border-radius:8px;border:2px solid #2d2d5e;flex-shrink:0}.qr-info{display:flex;flex-direction:column;gap:8px;min-width:0}.qr-url{color:#64748b;font-size:11px;word-break:break-all;font-family:monospace}.btn-copy,.btn-download{display:inline-flex;align-items:center;gap:5px;background:#1a1a38;border:1px solid #2d2d5e;border-radius:6px;color:#94a3b8;font-size:12px;padding:5px 10px;cursor:pointer;text-decoration:none;text-align:center;transition:border-color .2s,color .2s}.btn-copy:hover,.btn-download:hover{border-color:#7c3aed;color:#c4b5fd}.queue-count{margin-left:auto;color:#475569;font-size:11px;font-weight:400;text-transform:none;letter-spacing:0}.queue-list{list-style:none;margin:0;padding:0}.queue-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #1a1a38}.queue-item:last-child{border-bottom:none}.queue-pos{color:#334155;font-size:12px;min-width:28px;text-align:right}.queue-thumb{width:40px;height:40px;border-radius:4px;object-fit:cover;flex-shrink:0}.queue-info{flex:1;min-width:0}.queue-title{color:#e2e8f0;font-size:13px;font-weight:500;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-meta{color:#475569;font-size:11px;margin:0}.queue-votes{display:flex;align-items:center;gap:4px;color:#7c3aed;font-size:13px;font-weight:600;min-width:36px}.queue-actions{display:flex;gap:6px}.btn-play-now{display:flex;align-items:center;gap:4px;background:#1a2a1a;border:1px solid #166534;border-radius:6px;color:#4ade80;font-size:11px;padding:5px 8px;cursor:pointer;white-space:nowrap;transition:background .2s}.btn-play-now:hover:not(:disabled){background:#14532d}.btn-play-now:disabled{opacity:.5;cursor:not-allowed}.btn-delete{background:#1a0a0a;border:1px solid #7f1d1d;border-radius:6px;color:#f87171;padding:5px 7px;cursor:pointer;display:flex;align-items:center;transition:background .2s}.btn-delete:hover{background:#450a0a}.audio-unlock-btn{display:flex;align-items:center;gap:8px;width:100%;margin-top:14px;padding:10px 14px;background:#1a1a00;border:1px solid #ca8a04;border-radius:8px;color:#fde68a;font-size:13px;font-weight:600;cursor:pointer;text-align:left;transition:background .2s;animation:pulse-border 2s ease-in-out infinite}.audio-unlock-btn:hover{background:#292900;border-color:#eab308}@keyframes pulse-border{0%,to{box-shadow:0 0 #ca8a0400}50%{box-shadow:0 0 0 4px #ca8a0440}}.audio-active-badge{display:flex;align-items:center;gap:7px;margin-top:12px;padding:7px 12px;background:#0d1a0d;border:1px solid #166534;border-radius:8px;color:#4ade80;font-size:12px;font-weight:500}.audio-change-btn{background:none;border:none;color:#4ade80;font-size:11px;cursor:pointer;margin-left:auto;padding:0;text-decoration:underline;opacity:.7;transition:opacity .15s}.audio-change-btn:hover{opacity:1}.export-row{display:flex;gap:10px;flex-wrap:wrap}.btn-export{flex:1;min-width:120px;display:flex;align-items:center;justify-content:center;gap:6px;background:#0f0f22;border:1px solid #2d2d5e;border-radius:8px;color:#94a3b8;font-size:13px;font-weight:500;padding:9px 12px;cursor:pointer;text-decoration:none;transition:border-color .2s,color .2s}.btn-export:hover{border-color:#7c3aed;color:#c4b5fd}.btn-tab{background:#12122a;color:#94a3b8;border:1px solid #2d2d5e;border-radius:8px;padding:8px 16px;font-size:13px;cursor:pointer;transition:border-color .2s,color .2s}.btn-tab:hover{border-color:#7c3aed;color:#c4b5fd}.btn-tab--active{border-color:#7c3aed;color:#c4b5fd;background:#7c3aed1f}.admin-card--search{padding:0;overflow:hidden}.admin-card--search .search{padding:16px 20px}.admin-card--search .search__title{display:none}.admin-card--played{margin-top:0}.played-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.played-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06);opacity:.75}.played-item:last-child{border-bottom:none}.played-thumb{width:36px;height:36px;object-fit:cover;border-radius:4px;flex-shrink:0}.played-info{flex:1;min-width:0}.played-title{font-size:.85rem;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.played-meta{font-size:.75rem;color:#64748b;margin:2px 0 0}.played-status{font-size:.72rem;color:#64748b;flex-shrink:0}.played-status--skipped{color:#f87171;opacity:.6}.played-status--played{color:#4ade80}.played-actions{display:flex;gap:4px;flex-shrink:0}.btn-played-action{background:#1e1e42;border:1px solid #2d2d5e;border-radius:6px;color:#64748b;padding:5px 7px;cursor:pointer;display:flex;align-items:center;transition:background .15s,color .15s,border-color .15s}.btn-played-action:hover{background:#2d2d5e;color:#c4b5fd;border-color:#7c3aed}.master-body{padding:20px 24px;max-width:1400px;margin:0 auto}.master-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}@media (max-width: 800px){.master-kpi-row{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.master-kpi-row{grid-template-columns:1fr}}.kpi-card{background:#12122a;border:1px solid #1e1e42;border-radius:12px;padding:16px 20px;display:flex;flex-direction:column;gap:4px}.kpi-card__icon{font-size:20px;margin-bottom:4px}.kpi-card__value{font-size:28px;font-weight:700;color:#e2e8f0;line-height:1}.kpi-card__label{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.6px}.kpi-card--green{border-color:#166534}.kpi-card--purple{border-color:#4c2889}.kpi-card--blue{border-color:#1e3a5f}.kpi-card--orange{border-color:#7c4a14}.master-toolbar{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap}.master-tabs{display:flex;gap:6px}.master-search{flex:1;min-width:180px;background:#0a0a14;border:1px solid #2d2d5e;border-radius:8px;color:#e2e8f0;padding:8px 12px;font-size:13px;outline:none;transition:border-color .2s}.master-search:focus{border-color:#7c3aed}.master-search::placeholder{color:#334155}.btn-create{background:#7c3aed;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s}.btn-create:hover{background:#6d28d9}.master-section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#64748b;margin:0 0 14px;display:flex;align-items:center}.session-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#334155;flex-shrink:0}.session-dot--active{background:#4ade80;box-shadow:0 0 6px #4ade8088;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.session-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:8px}.session-grid--closed{opacity:.55}@media (max-width: 1100px){.session-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 680px){.session-grid{grid-template-columns:1fr}}.session-card{background:#12122a;border:1px solid #1e1e42;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.session-card--active{border-color:#166534}.session-card--closed{border-color:#1e1e42}.session-card__header{display:flex;align-items:center;gap:8px}.session-card__name{font-size:14px;font-weight:700;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-card__slug{font-size:11px;font-family:monospace}.session-card__slug-link{color:#7c3aed;text-decoration:none}.session-card__slug-link:hover{text-decoration:underline}.session-card__owner{display:flex;flex-direction:column;gap:2px;padding:8px 10px;background:#0a0a14;border-radius:8px;border:1px solid #1e1e42}.session-card__owner-name{font-size:12px;font-weight:600;color:#c4b5fd}.session-card__owner-email{font-size:11px;color:#475569}.session-card__owner-login{font-size:11px;color:#334155}.session-card__duration{font-size:12px;color:#4ade80;font-weight:600}.session-card__duration--closed{color:#475569;font-weight:400}.session-card__stats{display:flex;gap:10px;flex-wrap:wrap;font-size:11px;color:#64748b}.session-card__actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.btn-sc{font-size:11px;font-weight:600;border-radius:6px;padding:5px 10px;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;text-decoration:none;transition:background .2s,border-color .2s}.btn-sc--admin{background:#1a2a1a;border-color:#166534;color:#4ade80}.btn-sc--admin:hover{background:#14532d}.btn-sc--copy{background:#1a1a38;border-color:#2d2d5e;color:#94a3b8}.btn-sc--copy:hover{border-color:#7c3aed;color:#c4b5fd}.btn-sc--close{background:#1a0a0a;border-color:#7f1d1d;color:#f87171}.btn-sc--close:hover:not(:disabled){background:#450a0a}.btn-sc--close:disabled{opacity:.4;cursor:not-allowed}.owners-table-wrap{overflow-x:auto;border:1px solid #1e1e42;border-radius:12px}.owners-table{width:100%;border-collapse:collapse;font-size:13px}.owners-table th{background:#12122a;color:#475569;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:10px 14px;text-align:left;border-bottom:1px solid #1e1e42}.owners-table td{padding:10px 14px;border-bottom:1px solid #0f0f22;vertical-align:middle}.owners-table tbody tr:last-child td{border-bottom:none}.owners-table tbody tr:hover td{background:#0d0d20}.owners-table__row--dim td{opacity:.45}.owners-table__name{font-weight:600;color:#e2e8f0}.owners-table__email{color:#64748b;font-family:monospace;font-size:12px}.owners-table__login{color:#475569;font-size:12px}.owners-table__created{color:#334155;font-size:12px}.badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;border-radius:4px;padding:2px 7px}.badge--ok{background:#0d2010;color:#4ade80;border:1px solid #166534}.badge--warn{background:#1a0a0a;color:#f87171;border:1px solid #7f1d1d}.master-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}.master-modal{background:#12122a;border:1px solid #2d2d5e;border-radius:16px;padding:28px;width:420px;max-width:100%}.master-modal__title{font-size:16px;font-weight:700;color:#e2e8f0;margin:0 0 20px}.master-modal__field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.master-modal__field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#475569}.master-modal__field input,.master-modal__field select{background:#0a0a14;border:1px solid #2d2d5e;border-radius:8px;color:#e2e8f0;padding:9px 12px;font-size:13px;outline:none;transition:border-color .2s}.master-modal__field input:focus,.master-modal__field select:focus{border-color:#7c3aed}.master-modal__field select option{background:#12122a}.master-modal__actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.qr-modal{width:320px;text-align:center}.qr-modal__name{font-size:13px;color:#94a3b8;margin:-12px 0 16px}.qr-modal__canvas{display:flex;justify-content:center;padding:16px;background:#fff;border-radius:12px;margin-bottom:14px}.qr-modal__url{font-size:11px;font-family:monospace;color:#475569;margin:0 0 4px;word-break:break-all}.guests-table__headphone{font-family:monospace;font-size:13px;color:#94a3b8;font-weight:600}.guests-table__sessions{display:flex;gap:4px;flex-wrap:wrap}.guests-table__empty{color:#334155}.badge--session{background:#0a0a14;color:#475569;border:1px solid #1e1e42}.player-page{display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto;background:var(--bg);color:var(--text)}.player-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--bg-card);position:sticky;top:0;z-index:10}.player-header h1{font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.player-back{background:none;border:none;color:var(--accent-light);font-size:.9rem;cursor:pointer;padding:4px 0}.player-back:hover{text-decoration:underline}.player-gate{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 32px;text-align:center}.player-gate__icon{font-size:3rem}.player-gate h2{font-size:1.2rem;font-weight:700}.player-gate p{font-size:.9rem;color:var(--text-secondary)}.player-now-playing{flex-shrink:0}.player-controls{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px 24px}.player-play-btn{background:var(--accent);color:#fff;border:none;border-radius:50px;padding:16px 40px;font-size:1.1rem;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:.02em;transition:background .15s;animation:glow-pulse 3s ease-in-out infinite}.player-play-btn:hover{background:var(--accent-dim)}.player-play-btn:active{transform:scale(.97)}.player-volume{display:flex;align-items:center;gap:12px;width:100%;max-width:320px}.player-volume label{font-size:.82rem;color:var(--text-muted);white-space:nowrap}.player-volume input[type=range]{flex:1;accent-color:var(--accent)}.player-volume__val{font-size:.8rem;color:var(--text-muted);width:36px;text-align:right}.player-idle{font-size:.9rem;color:var(--text-muted);text-align:center;padding:16px}.player-btn{border:none;border-radius:10px;padding:12px 28px;font-size:.95rem;font-weight:600;cursor:pointer;width:100%;max-width:280px}.player-btn--primary{background:var(--accent);color:#fff}.player-btn--primary:hover{background:var(--accent-dim)}.player-btn--secondary{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border)}.player-btn--secondary:hover{background:var(--bg-hover)}.landing{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:24px 20px;overflow:hidden;background:var(--bg)}.landing__orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.16;pointer-events:none;animation:orb-float 8s ease-in-out infinite}.landing__orb--1{width:400px;height:400px;background:var(--accent);top:-100px;right:-80px}.landing__orb--2{width:300px;height:300px;background:var(--neon-cyan);bottom:-80px;left:-80px;animation-delay:-4s}.vinyl{position:absolute;top:-40px;right:-60px;perspective:600px;pointer-events:none;opacity:.22}.vinyl__disc{width:220px;height:220px;border-radius:50%;background:repeating-radial-gradient(circle,#1a1a2e,#0a0a14,#1a1a2e 4px);border:2px solid rgba(124,58,237,.3);display:flex;align-items:center;justify-content:center;animation:vinyl-spin 8s linear infinite;box-shadow:0 0 40px #7c3aed4d}.vinyl__label{width:70px;height:70px;border-radius:50%;background:radial-gradient(circle,var(--accent) 0%,var(--accent-dim) 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px var(--accent-glow)}.vinyl__dot{width:8px;height:8px;border-radius:50%;background:var(--bg)}.landing__card{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:400px;padding:40px 32px 36px}.landing__header{display:flex;align-items:center;gap:16px}.landing__icon{font-size:2.8rem;line-height:1;filter:drop-shadow(0 0 16px rgba(124,58,237,.7))}.eq{display:flex;align-items:flex-end;gap:3px;height:28px}.eq__bar{display:block;width:4px;height:100%;border-radius:2px;background:var(--accent-light);transform-origin:bottom center;animation:eq-bar .9s ease-in-out infinite alternate}.eq__bar:nth-child(2){background:var(--accent);animation-duration:.7s}.eq__bar:nth-child(3){background:var(--neon-cyan);animation-duration:1.1s}.eq__bar:nth-child(4){background:var(--accent);animation-duration:.8s}.landing__title{font-size:2rem;font-weight:800;letter-spacing:-.04em;color:var(--text);text-align:center;margin:0}.landing__sub{font-size:.88rem;color:var(--text-secondary);text-align:center;line-height:1.5;margin-bottom:4px}.landing__status{font-size:.9rem;color:var(--text-muted);text-align:center}.landing__status--error{color:var(--danger)}.landing__select-wrap{position:relative;width:100%}.landing__select{width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:#0a0a14e6;border:1px solid var(--border-solid);border-radius:12px;color:var(--text);font-size:1rem;font-family:inherit;padding:14px 44px 14px 16px;cursor:pointer;outline:none;transition:border-color .2s,box-shadow .2s}.landing__select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.landing__select option{background:#14142a;color:var(--text)}.landing__select-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--accent-light);pointer-events:none;font-size:.85rem}.landing__btn{width:100%;background:var(--accent);color:#fff;border:none;border-radius:12px;padding:15px 24px;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:.01em;transition:background .15s,box-shadow .15s,transform .1s;animation:glow-pulse 3s ease-in-out infinite}.landing__btn:hover:not(:disabled){background:var(--accent-dim);box-shadow:0 6px 28px #7c3aed99}.landing__btn:active:not(:disabled){transform:scale(.98)}.landing__btn:disabled{opacity:.35;cursor:not-allowed;animation:none;box-shadow:none}.landing__footer{position:relative;z-index:1;margin-top:28px;text-align:center}.landing__staff-link{font-size:.8rem;color:var(--text-muted);text-decoration:none;letter-spacing:.02em;transition:color .15s}.landing__staff-link:hover{color:var(--accent-light)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--accent: #7c3aed;--accent-dim: #6d28d9;--accent-light: #a78bfa;--accent-glow: rgba(124, 58, 237, .45);--accent-glow-dim: rgba(124, 58, 237, .18);--neon-cyan: #06b6d4;--neon-pink: #ec4899;--bg: #0a0a14;--bg-primary: #0a0a14;--bg-secondary: #14142a;--bg-card: #14142a;--bg-tertiary: #0a0a14;--bg-hover: #1e1e3a;--border: rgba(124, 58, 237, .2);--border-solid: #2d2d4e;--text: #e2e8f0;--text-primary: #e2e8f0;--text-secondary:#94a3b8;--text-muted: #475569;--success: #22c55e;--danger: #ef4444;--radius: 12px;--shadow: 0 4px 20px rgba(0,0,0,.6);--glass-bg: rgba(20, 20, 42, .75);--glass-border: rgba(124, 58, 237, .25)}html{font-size:16px}body{background:var(--bg);color:var(--text);font-family:Space Grotesk,Inter,system-ui,-apple-system,sans-serif;min-height:100dvh;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--bg-card);position:sticky;top:0;z-index:10}.app-header h1{font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.connection-status{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-muted)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.status-dot.connected{background:var(--success)}.status-dot.disconnected{background:var(--danger)}.app-main{flex:1;display:flex;flex-direction:column;gap:0;overflow-y:auto}.now-playing-section{flex-shrink:0}.queue-section{flex:1;border-top:1px solid var(--border)}.request-section{border-bottom:1px solid var(--border);background:var(--bg-card)}.request-hint{font-size:.72rem;color:var(--text-muted);text-align:center;padding:10px 20px 0;line-height:1.5}.header-right{display:flex;align-items:center;gap:10px}.user-badge{font-size:.75rem;color:var(--accent-light);background:#7c3aed26;border:1px solid rgba(124,58,237,.3);border-radius:20px;padding:3px 10px;white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}.app-footer{padding:12px 20px;border-top:1px solid var(--border);font-size:.72rem;color:var(--text-muted);text-align:center}.vote-hint a,.player-hint a{color:var(--accent-light);text-decoration:none}.vote-hint a:hover,.player-hint a:hover{text-decoration:underline}.install-prompt{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 20px;background:#7c3aed1f;border-bottom:1px solid rgba(124,58,237,.25);font-size:.85rem}.install-prompt p{flex:1;color:var(--accent-light)}.install-prompt button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:6px 16px;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap}.install-prompt button:hover{background:var(--accent-dim)}@keyframes vinyl-spin{0%{transform:rotateY(0) rotate(0)}to{transform:rotateY(10deg) rotate(360deg)}}@keyframes eq-bar{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 40px var(--accent-glow),0 0 80px var(--accent-glow-dim)}}@keyframes orb-float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}.glass-card{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:20px;box-shadow:0 8px 40px #00000080,0 0 0 1px #7c3aed14}
