:root{--bg: #0b0b16;--bg-2: #14142a;--panel: rgba(255, 255, 255, .04);--panel-border: rgba(255, 255, 255, .08);--text: #f3f1ff;--muted: #9a96c4;--pink: #ff3d9a;--purple: #8b5cf6;--cyan: #22d3ee;--gold: #fbbf24;--good: #34d399;--radius: 16px;--shadow: 0 10px 40px rgba(0, 0, 0, .45)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:radial-gradient(1200px 600px at 15% -10%,rgba(139,92,246,.25),transparent 60%),radial-gradient(1000px 500px at 110% 10%,rgba(255,61,154,.22),transparent 55%),radial-gradient(800px 600px at 50% 120%,rgba(34,211,238,.15),transparent 60%),var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}a{color:var(--cyan)}.app-shell{max-width:760px;margin:0 auto;padding:24px 18px 64px}.room-grid{display:flex;flex-direction:column;gap:16px;margin-top:16px}.room-col{display:flex;flex-direction:column;gap:16px;min-width:0}.room-col>*{margin:0}.room-col .card+.card{margin-top:0}@media(min-width:900px){.room-shell{max-width:1080px}.room-grid{flex-direction:row;align-items:flex-start}.room-main{flex:1 1 50%}.room-side{flex:1 1 50%;position:sticky;top:16px;max-height:calc(100vh - 32px)}.room-side .queue-card{display:flex;flex-direction:column;flex:1;min-height:0}.room-side .queue-card .queue-list{max-height:none;flex:1}}.brand{font-weight:800;letter-spacing:-.02em;background:linear-gradient(90deg,var(--pink),var(--purple),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}.brand-link{display:inline-flex;align-items:center;gap:9px;text-decoration:none}.brand-link svg{flex:none}.room-header{position:relative}.room-tagline{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none}.room-tagline-inner{display:inline-block;transform-origin:center;perspective:520px;animation:tagline-beat 1.8s ease-in-out infinite}.tagline-letter{display:inline-block;transform-origin:center;font-weight:700;font-size:1.02rem;letter-spacing:.01em;background:linear-gradient(90deg,var(--pink),var(--purple),var(--cyan),var(--purple),var(--pink));background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:tagline-shine 6s linear infinite,tagline-roll 2.2s ease-in-out infinite}@keyframes tagline-shine{to{background-position:220% center}}@keyframes tagline-roll{0%{transform:rotateY(0)}30%{transform:rotateY(360deg)}to{transform:rotateY(360deg)}}@keyframes tagline-beat{0%{transform:scale(1) rotate(-2.5deg)}14%{transform:scale(1.16) rotate(2.5deg)}28%{transform:scale(1) rotate(-2.5deg)}42%{transform:scale(1.16) rotate(2.5deg)}56%,to{transform:scale(1) rotate(-2.5deg)}}@media(prefers-reduced-motion:reduce){.room-tagline-inner,.tagline-letter{animation:none}}@media(max-width:720px){.room-tagline{display:none}}.search-btn{min-width:92px}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.spinner{animation-duration:1.6s}}.now-badge{flex:none;display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;border:1px solid rgba(52,211,153,.35);background:#34d3991f;color:var(--good);font-size:.82rem;font-weight:700;white-space:nowrap}.now-badge .dot{animation:pulse-dot 1.4s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 #34d39980}50%{opacity:.6;box-shadow:0 0 0 5px #34d39900}}.drag-handle{flex:none;display:inline-flex;align-items:center;justify-content:center;align-self:stretch;padding:0 6px;margin:-4px 0;color:var(--muted);font-size:1.15rem;line-height:1;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none}.drag-handle:active{cursor:grabbing;color:var(--text)}.song-list.reordering .song{transition:transform .16s ease}.song-list.reordering .song.dragging{transition:transform .06s ease}.song.dragging{opacity:.95;border-color:transparent;box-shadow:0 10px 28px #00000080}.song.dragging:after{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;padding:2px;background:linear-gradient(120deg,var(--pink),var(--purple),var(--cyan),var(--pink));background-size:300% 100%;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;animation:drag-shine 1.4s linear infinite;pointer-events:none}@keyframes drag-shine{to{background-position:300% 0}}@media(prefers-reduced-motion:reduce){.song.dragging:after{animation:none}}.song.dropped{animation:drop-settle .5s ease-out}@keyframes drop-settle{0%{transform:translateY(-5px);box-shadow:0 0 0 2px #8b5cf68c,0 8px 20px #8b5cf659}to{transform:translateY(0);box-shadow:0 0 #8b5cf600}}@media(prefers-reduced-motion:reduce){.song.dropped{animation:none}}.stage-ticker.pulse{animation:ticker-pulse .65s ease}@keyframes ticker-pulse{0%{color:var(--cyan);text-shadow:0 0 16px rgba(34,211,238,.75);transform:scale(1.05)}to{transform:scale(1)}}@media(prefers-reduced-motion:reduce){.stage-ticker.pulse{animation:none}}.drop-indicator{height:3px;border-radius:999px;margin:1px 2px;background:linear-gradient(90deg,var(--pink),var(--purple),var(--cyan));box-shadow:0 0 10px #8b5cf699}.hero{text-align:center;padding:52px 0 30px}.logo-lockup{display:inline-flex;align-items:center;justify-content:center;gap:14px;margin-bottom:14px}.logo-mark{flex:none;filter:drop-shadow(0 6px 18px rgba(139,92,246,.45));animation:logo-float 4s ease-in-out infinite}@keyframes logo-float{0%,to{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-5px) rotate(-4deg)}}.wordmark-lockup{display:inline-block;white-space:nowrap;line-height:1}.wordmark-lockup .bmic{height:1.12em;width:auto;vertical-align:-.2em;margin-right:.04em;filter:drop-shadow(0 7px 18px rgba(139,92,246,.5))}.wordmark-lockup .wordmark-rest{letter-spacing:-.01em}.wordmark-lockup.is-floating{animation:wordmark-float 4.2s ease-in-out infinite;transform-origin:center bottom}@keyframes wordmark-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@media(prefers-reduced-motion:reduce){.logo-mark,.wordmark-lockup.is-floating{animation:none}}.wordmark{font-size:clamp(2.6rem,9vw,4rem);line-height:.95;margin:0}.hero .tagline{color:var(--muted);font-size:1.05rem;margin:0 auto;max-width:none;line-height:1.5;white-space:nowrap}.section-title{text-align:center;font-size:1.35rem;font-weight:800;margin:0 0 22px;background:linear-gradient(90deg,var(--pink),var(--purple),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}.hero-badges{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;margin-top:18px}.pill-badge{display:inline-block;padding:5px 14px;border-radius:999px;border:1px solid rgba(139,92,246,.4);background:#8b5cf61f;color:var(--text);font-size:.82rem;font-weight:600}.preview{position:relative;margin:44px auto 8px;max-width:620px}.preview-tv{margin:0 auto;width:100%}.preview-tv-screen{position:relative;aspect-ratio:16 / 9;border-radius:16px;border:1px solid var(--panel-border);background:radial-gradient(120% 120% at 20% 0%,rgba(139,92,246,.35),transparent 55%),radial-gradient(120% 120% at 100% 100%,rgba(34,211,238,.3),transparent 55%),linear-gradient(160deg,#14142a,#0b0b16);box-shadow:0 24px 60px #00000080;overflow:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;text-align:center}.preview-tv-brand{font-size:1.4rem;position:absolute;top:14px;left:16px}.preview-tv-song{font-weight:800;font-size:1.15rem;color:var(--text)}.preview-tv-lyric{font-size:1rem;color:var(--cyan);text-shadow:0 0 18px rgba(34,211,238,.5)}.preview-tv-ticker{position:absolute;bottom:14px;right:16px;font-size:.78rem;color:var(--muted)}.preview-tv-stand{width:90px;height:10px;margin:0 auto;border-radius:0 0 8px 8px;background:linear-gradient(180deg,#2a2a44,#14142a)}.preview-phone{position:absolute;right:-6px;bottom:-10px;width:150px;padding:12px 10px;border-radius:22px;border:1px solid var(--panel-border);background:#0b0b16eb;box-shadow:0 18px 40px #0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.preview-phone-head{font-size:.74rem;color:var(--muted);margin-bottom:8px}.preview-phone-head strong{color:var(--text);letter-spacing:.12em}.preview-q{display:flex;align-items:center;gap:8px;padding:6px;border-radius:8px;background:#ffffff0a;margin-bottom:5px}.preview-q-num{flex:none;width:16px;height:16px;border-radius:50%;font-size:.62rem;font-weight:800;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--cyan),var(--purple))}.preview-q-title{font-size:.7rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-phone-add{margin-top:8px;text-align:center;font-size:.7rem;font-weight:700;padding:6px;border-radius:8px;color:#fff;background:linear-gradient(90deg,var(--pink),var(--purple))}@media(max-width:480px){.preview-phone{width:116px;right:2px}}.how{margin-top:48px}.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}.how-step{position:relative;background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius);padding:22px 18px 18px;text-align:center}.how-num{display:inline-grid;place-items:center;width:40px;height:40px;margin-bottom:12px;border-radius:50%;font-weight:900;font-size:1.1rem;color:#fff;background:linear-gradient(135deg,var(--pink),var(--purple),var(--cyan));box-shadow:0 8px 22px #8b5cf666}.how-step h3{margin:0 0 6px;font-size:1rem}.how-step p{margin:0;color:var(--muted);font-size:.88rem;line-height:1.5}.features{margin-top:48px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.feature-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius);padding:18px;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.feature-card:hover{transform:translateY(-3px);border-color:#8b5cf680;box-shadow:0 10px 30px #8b5cf62e}.feature-icon{display:block;font-size:1.7rem;line-height:1;margin-bottom:10px}.feature-card h3{margin:0 0 6px;font-size:1rem;font-weight:700}.feature-card p{margin:0;color:var(--muted);font-size:.88rem;line-height:1.5}@media(prefers-reduced-motion:reduce){.feature-card:hover{transform:none}}.home-footer{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:12px;margin-top:48px;padding-top:24px;border-top:1px solid var(--panel-border);font-size:1.3rem}.home-footer .muted{font-size:.85rem}.footer-links{display:flex;gap:16px;font-size:.85rem}.footer-copyright{flex-basis:100%;text-align:center;font-size:.8rem}.pricing{margin-top:48px}.pricing-card{position:relative;text-align:center;border-radius:var(--radius);padding:30px 24px;border:1px solid rgba(139,92,246,.4);background:radial-gradient(120% 120% at 0% 0%,rgba(255,61,154,.12),transparent 55%),radial-gradient(120% 120% at 100% 100%,rgba(34,211,238,.12),transparent 55%),var(--panel)}.pricing-badge{display:inline-block;padding:4px 14px;border-radius:999px;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(90deg,var(--pink),var(--purple));margin-bottom:12px}.pricing-card h2{margin:0 0 8px;font-size:1.3rem}.pricing-card p{margin:0 auto 18px;max-width:32rem;line-height:1.6}.tips{margin-top:48px}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.tip-row{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:12px;border:1px solid var(--panel-border);background:var(--panel);font-size:.9rem;line-height:1.5;color:var(--text)}.tip-icon{flex:none;font-size:1.2rem;line-height:1.3}.faq{margin-top:48px}.faq-list{display:flex;flex-direction:column;gap:10px}.faq-item{border:1px solid var(--panel-border);border-radius:12px;background:var(--panel);overflow:hidden}.faq-item summary{cursor:pointer;list-style:none;padding:14px 18px;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:space-between}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary:after{content:"+";color:var(--muted);font-weight:700;font-size:1.2rem;line-height:1;transition:transform .2s ease}.faq-item[open] summary:after{transform:rotate(45deg)}.faq-item p{margin:0;padding:0 18px 16px;color:var(--muted);font-size:.9rem;line-height:1.6}.cta-final{margin-top:52px;text-align:center;padding:36px 24px;border-radius:var(--radius);border:1px solid var(--panel-border);background:radial-gradient(120% 140% at 50% 0%,rgba(139,92,246,.22),transparent 60%),var(--panel)}.cta-final h2{margin:0 0 6px;font-size:1.6rem}.cta-final p{margin:0 0 18px}.cta-final-btn{font-size:1.05rem;padding:14px 28px}.resume-hint{margin:10px 0 0;font-size:.85rem}.resume-fresh{background:none;border:none;padding:0;color:var(--cyan);font-size:inherit;text-decoration:underline;text-underline-offset:2px}.resume-fresh:hover{color:var(--text)}.legal-link{color:var(--muted);text-decoration:none;transition:color .15s ease}.legal-link:hover{color:var(--text)}.legal{line-height:1.6}.legal h1{margin:0 0 4px;font-size:1.8rem}.legal-meta{margin:0 0 20px;color:var(--muted);font-size:.85rem}.legal h2{margin:26px 0 8px;font-size:1.1rem}.legal p,.legal li{color:var(--text);font-size:.94rem}.legal ul{margin:8px 0;padding-left:20px}.legal li{margin:4px 0}.legal a{color:var(--cyan)}.domain-pill{display:inline-block;margin-top:16px;padding:5px 14px;border-radius:999px;border:1px solid var(--panel-border);background:#ffffff0a;color:var(--muted);font-size:.82rem;font-weight:600;letter-spacing:.04em;text-decoration:none;transition:border-color .15s,color .15s,background .15s}.domain-pill:hover{color:var(--text);border-color:#8b5cf680;background:#8b5cf61f}.card{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius);padding:20px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow)}.card+.card{margin-top:16px}.card h2{margin:0 0 14px;font-size:1.05rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.input,.field input{width:100%;padding:13px 15px;border-radius:12px;border:1px solid var(--panel-border);background:#00000040;color:var(--text);font-size:1rem;outline:none;transition:border-color .15s,box-shadow .15s}.input:focus,.field input:focus{border-color:var(--purple);box-shadow:0 0 0 3px #8b5cf640}.input::placeholder{color:#9a96c499}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:12px;border:1px solid var(--panel-border);background:#ffffff0f;color:var(--text);font-weight:600;font-size:.98rem;white-space:nowrap;transition:transform .08s,filter .15s,background .15s}.btn:hover{filter:brightness(1.12)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(90deg,var(--pink),var(--purple));border:none;color:#fff}.btn-ghost{background:transparent}.btn-play{background:linear-gradient(135deg,var(--cyan),#6366f1);border:none;color:#fff}.btn-top{background:#ffffff0f;border-color:var(--panel-border);color:var(--muted)}.btn-top:hover{background:#ffffff24;color:var(--text)}.btn-block{width:100%}.btn-sm{padding:8px 12px;font-size:.85rem;border-radius:10px}.btn-icon{padding:8px;min-width:38px}.btn-queued,.btn-queued:disabled{background:#34d39929;border-color:#34d39980;color:var(--good);opacity:1;cursor:default}.search-btn{background:linear-gradient(90deg,#f97316,#f59e0b);border:none;color:#fff}.search-field{position:relative;display:flex}.search-field .input{width:100%;padding-right:42px}.input-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:50%;background:#ffffff14;color:var(--muted);font-size:.78rem;line-height:1;transition:background .15s,color .15s}.input-clear:hover{background:#ffffff2e;color:var(--text)}.card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}.card-head h2{margin:0}.karaoke-toggle{display:inline-flex;align-items:center;gap:8px;font-size:.88rem;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.karaoke-toggle input{width:16px;height:16px;accent-color:var(--purple);cursor:pointer}.karaoke-toggle:hover{color:var(--text)}.row{display:flex;gap:10px;align-items:center}.row-wrap{flex-wrap:wrap}.grow{flex:1}.muted{color:var(--muted)}.center{text-align:center}.divider{display:flex;align-items:center;gap:12px;color:var(--muted);margin:18px 0;font-size:.85rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--panel-border)}.code-pill{display:inline-block;margin-top:6px;font-size:1.6rem;font-weight:800;letter-spacing:.3em;padding:6px 16px 6px 22px;border-radius:12px;background:#0000004d;border:1px solid var(--panel-border)}.room-code-head{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px}.room-code-info{justify-self:start}.room-code-actions{justify-self:end}.support-coffee{justify-self:center;display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;font-weight:700;font-size:.9rem;text-decoration:none;color:#2a1606;background:linear-gradient(135deg,#ffd277,#f59e0b);border:1px solid rgba(255,210,119,.6);box-shadow:0 6px 18px #f59e0b4d;white-space:nowrap;transition:transform .08s ease,filter .15s ease,box-shadow .15s ease}.support-coffee:hover{filter:brightness(1.06);box-shadow:0 8px 24px #f59e0b6b}.support-coffee:active{transform:scale(.97)}.support-coffee .coffee-emoji{font-size:1.05rem;animation:coffee-steam 2.6s ease-in-out infinite}@keyframes coffee-steam{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-2px) rotate(-6deg)}}@media(prefers-reduced-motion:reduce){.support-coffee .coffee-emoji{animation:none}}.support-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:20px;background:#05050cb8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:support-fade .18s ease}@keyframes support-fade{0%{opacity:0}}.support-modal{position:relative;width:100%;max-width:600px;max-height:calc(100vh - 40px);overflow-y:auto;padding:26px 22px 22px;border-radius:18px;border:1px solid var(--panel-border);background:radial-gradient(120% 120% at 50% 0%,rgba(139,92,246,.18),transparent 60%),#14142a;box-shadow:0 24px 70px #0009;text-align:center;animation:support-pop .2s ease}@keyframes support-pop{0%{transform:translateY(10px) scale(.97);opacity:0}}.support-close{position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;border:none;background:#ffffff14;color:var(--muted);font-size:.85rem;line-height:1;transition:background .15s,color .15s}.support-close:hover{background:#ffffff2e;color:var(--text)}.support-title{margin:0 0 4px;font-size:1.25rem;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.support-title .wordmark-lockup{font-size:1.35rem}.support-sub{margin:0 0 18px;font-size:.88rem;line-height:1.5}.support-methods{display:flex;align-items:stretch;gap:16px;text-align:center}.support-gcash,.support-card{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.support-qr{width:100%;max-width:300px;aspect-ratio:1 / 1;border-radius:14px;background-color:#fff;background-image:url(/support-gcash-account.jfif);background-repeat:no-repeat;background-position:center 37%;background-size:170%}.support-gcash-note,.support-card-note{margin:0;font-size:.84rem}.support-card-icon{font-size:2.4rem;line-height:1}.support-card .btn{margin-top:4px}.support-or{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}.support-or:before,.support-or:after{content:"";width:1px;flex:1;background:var(--panel-border)}@media(max-width:480px){.support-methods{flex-direction:column;gap:14px}.support-or{flex-direction:row;gap:12px}.support-or:before,.support-or:after{width:auto;flex:1;height:1px}}.song-list{display:flex;flex-direction:column;gap:8px}.search-list{max-height:60vh;overflow-y:auto;padding:10px;border:1px solid rgba(139,92,246,.45);border-radius:14px;background:#00000040;box-shadow:inset 0 0 0 1px #ffffff0a}.search-list::-webkit-scrollbar,.queue-list::-webkit-scrollbar{width:8px}.search-list::-webkit-scrollbar-thumb,.queue-list::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:999px}.search-list::-webkit-scrollbar-thumb:hover,.queue-list::-webkit-scrollbar-thumb:hover{background:#ffffff3d}.more-btn{margin-top:2px;justify-content:center;color:var(--muted);font-weight:700}.more-btn:hover{color:var(--text)}.queue-list{max-height:70vh;overflow-y:auto;padding:10px;border:1px solid rgba(139,92,246,.45);border-radius:14px;background:#00000040;box-shadow:inset 0 0 0 1px #ffffff0a}.song{display:flex;gap:12px;align-items:center;padding:8px;border-radius:12px;background:#0003;border:1px solid transparent}.song:hover{border-color:var(--panel-border)}.song img{width:72px;height:48px;object-fit:cover;border-radius:8px;flex-shrink:0;background:#000}.song .meta{flex:1;min-width:0}.song .title{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song .sub{font-size:.8rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-index{min-width:14px;margin-left:-9px;text-align:center;font-weight:800;color:var(--purple);flex-shrink:0}.now-card{position:relative;overflow:hidden;background:linear-gradient(135deg,#ff3d9a29,#8b5cf629);border-color:#ff3d9a4d}.now-card>*{position:relative;z-index:1}.now-card.is-playing:before{content:"";position:absolute;top:-45%;right:-45%;bottom:-45%;left:-45%;z-index:0;background:radial-gradient(40% 55% at 20% 30%,rgba(255,61,154,.55),transparent 60%),radial-gradient(45% 55% at 80% 25%,rgba(34,211,238,.45),transparent 60%),radial-gradient(50% 60% at 50% 85%,rgba(139,92,246,.55),transparent 60%);filter:blur(16px);animation:now-aurora 9s ease-in-out infinite}.now-card.is-playing{animation:now-glow 3.2s ease-in-out infinite}.now-card.is-playing:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;border-radius:inherit;pointer-events:none;border:2px solid rgba(255,61,154,calc(.18 + var(--mic, 0) * .8));box-shadow:0 0 calc(6px + var(--mic, 0) * 48px) calc(var(--mic, 0) * 8px) rgba(255,61,154,calc(var(--mic, 0) * .8)),inset 0 0 calc(var(--mic, 0) * 34px) rgba(34,211,238,calc(var(--mic, 0) * .55));transition:box-shadow .07s linear,border-color .07s linear}@keyframes now-aurora{0%{transform:translate(0) rotate(0) scale(1.05)}33%{transform:translate(6%,-4%) rotate(8deg) scale(1.14)}66%{transform:translate(-5%,5%) rotate(-7deg) scale(1.1)}to{transform:translate(0) rotate(0) scale(1.05)}}@keyframes now-glow{0%,to{box-shadow:var(--shadow),0 0 #ff3d9a00;border-color:#ff3d9a4d}50%{box-shadow:var(--shadow),0 0 26px 2px #ff3d9a4d;border-color:#ff3d9a8c}}@media(prefers-reduced-motion:reduce){.now-card.is-playing:before,.now-card.is-playing{animation:none}}.now-label{color:var(--pink);font-weight:700;letter-spacing:.1em;font-size:.75rem;text-transform:uppercase}.empty{text-align:center;color:var(--muted);padding:24px;font-size:.95rem}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#14142af2;border:1px solid var(--panel-border);padding:12px 18px;border-radius:12px;box-shadow:var(--shadow);z-index:50;max-width:90vw}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#ffffff0f;font-size:.8rem;color:var(--muted)}.dot{width:8px;height:8px;border-radius:50%;background:var(--good);box-shadow:0 0 8px var(--good)}.user-pill{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;border-radius:999px;background:#ffffff0f;border:1px solid var(--panel-border);font-size:.85rem;font-weight:600;white-space:nowrap}.user-pill-avatar{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--cyan),var(--purple))}.queue-actions{display:flex;gap:4px;justify-content:flex-end;flex-shrink:0}.queue-actions .btn-sm{padding:8px 10px;min-width:38px}.stage{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;overflow:hidden}.stage-player{position:absolute;top:0;right:0;bottom:0;left:0}.stage-player iframe{width:100%;height:100%}.stage-idle{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center;padding:24px}.stage-idle h1{font-size:clamp(2rem,6vw,4rem)}.join-code{font-size:clamp(2.5rem,9vw,6rem);font-weight:900;letter-spacing:.25em}.stage-gap{position:absolute;top:0;right:0;bottom:0;left:0;z-index:15;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;text-align:center;padding:24px;background:var(--bg)}.sponsor-card{display:flex;flex-direction:column;align-items:center;gap:12px;text-decoration:none;color:var(--text)}.sponsor-card img{max-width:60vw;max-height:48vh;border-radius:16px;object-fit:contain}.sponsor-tag{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}.sponsor-caption{font-size:1.3rem;font-weight:700}.gap-next{font-size:clamp(1.1rem,2.4vw,1.8rem);color:var(--text)}.gap-next strong{color:var(--pink)}.gap-count{font-size:1rem;color:var(--muted);letter-spacing:.04em}.stage-start{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;text-align:center;padding:24px;cursor:pointer;background:#0b0b16d1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.stage-shield{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3}.stage-paused{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:24px;cursor:pointer;background:radial-gradient(1200px 600px at 15% -10%,rgba(139,92,246,.25),transparent 60%),radial-gradient(1000px 500px at 110% 10%,rgba(255,61,154,.2),transparent 55%),var(--bg)}.paused-title{font-size:clamp(1.2rem,3vw,2.2rem);font-weight:700;max-width:80vw}.paused-hint{font-size:1rem;color:var(--muted);letter-spacing:.04em}.lyrics-overlay{position:absolute;left:0;right:0;bottom:0;padding:40px 6vw 6vh;background:linear-gradient(to top,rgba(0,0,0,.92) 35%,transparent);text-align:center;pointer-events:none}.lyric-line{font-size:clamp(1.4rem,3vw,2.6rem);font-weight:700;line-height:1.25;margin:6px 0;transition:all .2s;color:#fff6;text-shadow:0 2px 20px rgba(0,0,0,.8)}.lyric-line.active{color:#fff;transform:scale(1.06);text-shadow:0 0 24px rgba(255,61,154,.7)}.lyric-line.next{color:#fff9}.stage-topbar{position:absolute;top:0;left:0;right:0;padding:18px 28px;display:flex;justify-content:space-between;align-items:center;gap:18px;background:linear-gradient(to bottom,rgba(0,0,0,.9),rgba(0,0,0,.45) 55%,transparent);z-index:5}.stage-topbar .brand-link{display:inline-flex;align-items:center;gap:12px;text-shadow:0 2px 14px rgba(0,0,0,.9)}.stage-room{font-size:1rem;color:var(--text);background:#ffffff1a;border:1px solid rgba(255,255,255,.22);padding:5px 14px;border-radius:999px;letter-spacing:.06em;font-weight:600;white-space:nowrap}.stage-room strong{color:var(--cyan);letter-spacing:.16em;font-weight:800}.stage-ticker{display:inline-flex;align-items:center;gap:12px;max-width:55vw;font-size:1.3rem;font-weight:700;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.9)}.stage-ticker-label{flex:none;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:800;color:#fff;padding:6px 12px;border-radius:999px;background:linear-gradient(90deg,var(--pink),var(--purple));box-shadow:0 4px 16px #ff3d9a66;white-space:nowrap}.stage-ticker-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fab-row{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:8px;z-index:6;padding:6px;border-radius:14px;background:#0b0b16c7;border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow)}.fab-row .btn{background:#ffffff24;border-color:#ffffff2e}.fab-row .btn:hover{background:#ffffff38}.stage-playlist-tab{position:absolute;right:0;top:50%;z-index:16;writing-mode:vertical-rl;text-orientation:mixed;transform:translateY(-50%) rotate(180deg);display:inline-flex;align-items:center;gap:8px;padding:18px 9px;border:1px solid var(--panel-border);border-right:none;border-radius:14px 0 0 14px;background:#0b0b16d1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text);font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:.82rem;box-shadow:var(--shadow);transition:background .15s,color .15s}.stage-playlist-tab:hover{background:linear-gradient(180deg,var(--pink),var(--purple));color:#fff}.stage-playlist-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:17;background:#00000080}.stage-playlist-panel{position:absolute;top:0;right:0;bottom:0;width:min(420px,88vw);z-index:18;display:flex;flex-direction:column;gap:14px;padding:22px;background:#0e0e1cf7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-left:1px solid var(--panel-border);box-shadow:-24px 0 60px #0000008c;animation:playlist-in .22s ease}@keyframes playlist-in{0%{transform:translate(100%)}to{transform:translate(0)}}@media(prefers-reduced-motion:reduce){.stage-playlist-panel{animation:none}}.stage-playlist-head{display:flex;align-items:center;justify-content:space-between}.stage-playlist-head h2{margin:0;font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.stage-playlist-list{overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:4px}.stage-playlist-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:12px;background:#00000040;border:1px solid var(--panel-border)}.stage-playlist-item .queue-index{margin-left:0}.stage-playlist-item img{width:64px;height:42px;object-fit:cover;border-radius:8px;flex:none;background:#000}.stage-playlist-item .meta{flex:1;min-width:0}.stage-playlist-item .title{font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stage-playlist-item .sub{font-size:.78rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mic-panel{text-align:center;display:flex;flex-direction:column}.now-card{min-height:200px;display:flex;flex-direction:column}.mic-panel .wave-wrap{flex:1}.mic-panel .btn-block{margin-top:auto}.now-combined{display:flex;flex:1}.now-section{flex:1;min-width:0;display:flex;flex-direction:column;position:relative;z-index:1}.mic-bare{display:contents}.wave-canvas.wave-bg{position:absolute;top:-20px;left:-20px;width:calc(100% + 40px);height:calc(100% + 40px);z-index:0;pointer-events:none}.now-controls{margin-top:auto;padding-top:8px;justify-content:center}.now-ctrl-btn{min-width:150px}.mic-icon-btn{position:absolute;right:0;top:0;z-index:2;width:46px;height:46px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--panel-border);background:#ffffff0f;color:var(--muted);transition:background .15s,color .15s,transform .08s;pointer-events:auto}.mic-icon-btn:hover{background:#ffffff24;color:var(--text)}.mic-icon-btn:active{transform:scale(.94)}.mic-icon-btn.is-on{background:linear-gradient(135deg,var(--pink),var(--purple));border:none;color:#fff}.wave-wrap{position:relative;height:100px;margin:14px 0;border-radius:14px;background:radial-gradient(120% 140% at 50% 0%,rgba(34,211,238,.08),transparent 70%),#0006;border:1px solid var(--panel-border);overflow:hidden}.wave-canvas{display:block;width:100%;height:100%}.wave-score{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:radial-gradient(60% 80% at 50% 50%,#0b0b16b8,#0b0b1673);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:wave-score-in .5s cubic-bezier(.2,1.4,.4,1);pointer-events:none}.wave-score .score-top{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.wave-score .score-big{font-size:clamp(3.4rem,8vw,5.5rem);font-weight:900;line-height:.95;filter:drop-shadow(0 0 18px rgba(255,61,154,.55));animation:score-pulse 1.1s ease-in-out infinite}.wave-score .score-rating{font-size:1.1rem;font-weight:800;letter-spacing:.04em;color:#fff;text-shadow:0 0 16px rgba(139,92,246,.7);animation:rating-pop .6s ease .4s both}@keyframes wave-score-in{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}@keyframes score-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes rating-pop{0%{opacity:0;transform:translateY(8px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}@media(prefers-reduced-motion:reduce){.wave-score .score-big{animation:none}}.mic-hint{margin:0 0 14px;font-size:.85rem}.score-big{font-size:3rem;font-weight:900}.note-display{font-size:2.2rem;font-weight:800;letter-spacing:.05em}.now-bar{margin-top:auto;width:100%;height:6px;border-radius:999px;background:#ffffff24;overflow:hidden;position:relative;z-index:1}.now-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--purple));transition:width .25s linear}.fireworks-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:60}.people-list{display:flex;flex-direction:column;gap:6px}.person-row{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:12px;background:#0003;border:1px solid var(--panel-border)}.person-avatar{flex:none;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:#fff;background:linear-gradient(135deg,var(--cyan),var(--purple))}.person-avatar.host{background:linear-gradient(135deg,var(--pink),var(--purple))}.person-avatar.pending{background:#ffffff1f;color:var(--muted)}.person-name{flex:1;min-width:0;font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-badge{flex:none;padding:3px 10px;border-radius:999px;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.role-badge.is-host{color:#fff;background:linear-gradient(90deg,var(--pink),var(--purple))}.role-badge.is-stage{color:var(--cyan);background:#22d3ee24;border:1px solid rgba(34,211,238,.4)}.role-badge.is-dj{color:var(--good);background:#34d39929;border:1px solid rgba(52,211,153,.45)}.control-toggle{flex:none;background:#ffffff0f;border-color:var(--panel-border);color:var(--muted)}.control-toggle:hover{background:#ffffff24;color:var(--text)}.control-toggle.is-on{background:linear-gradient(135deg,var(--good),var(--cyan));border:none;color:#04201a}.pending-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;padding:10px;border-radius:12px;border:1px solid rgba(251,191,36,.4);background:#fbbf2414}.pending-row{display:flex;align-items:center;gap:12px}.pending-meta{flex:1;min-width:0;display:flex;flex-direction:column}.pending-tag{font-size:.74rem;color:var(--gold)}.btn-accept{background:linear-gradient(135deg,var(--good),#22d3ee);border:none;color:#04201a}.join-gate,.waiting-gate{max-width:460px;margin:12vh auto 0}.waiting-gate .spinner{margin:0 auto;border-width:3px}@media(max-width:560px){.app-shell{padding:16px 12px 56px}.hero .tagline{white-space:normal;max-width:22rem}.room-code-head{grid-template-columns:1fr;gap:14px}.room-code-info,.support-coffee{justify-self:start}.room-code-actions{justify-self:stretch;width:100%;flex-wrap:wrap}.room-code-actions .btn{flex:1}.room-code-actions .btn-icon{flex:0 0 auto}.code-pill{font-size:1.3rem;letter-spacing:.22em;padding:6px 12px 6px 16px}.now-controls{gap:8px}.now-ctrl-btn{min-width:0;flex:1}.now-section{padding-right:52px}.queue-list .song,.search-list .song{flex-wrap:wrap;row-gap:8px}.queue-list .song .meta,.search-list .song .meta{order:10;flex-basis:100%}.queue-list .song .queue-actions,.search-list .song>.row,.search-list .song>.now-badge{margin-left:auto}.song .title{font-size:.74rem;line-height:1.25;white-space:normal}.song .sub{font-size:.66rem;white-space:normal}}.sponsor-perks{list-style:none;margin:16px 0 22px;padding:0;display:grid;gap:8px}.sponsor-perks li{padding:10px 14px;border-radius:12px;border:1px solid var(--panel-border);background:var(--panel);font-size:.92rem}.sponsor-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:560px){.sponsor-grid{grid-template-columns:1fr}}.sponsor-grid .field,.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:.82rem;font-weight:600;color:var(--muted)}.sponsor-textarea{min-height:120px;resize:vertical;line-height:1.5}select.input{-moz-appearance:none;appearance:none;-webkit-appearance:none}.sponsor-sent{margin-top:18px;padding:20px;border-radius:14px;border:1px solid rgba(52,211,153,.35);background:#34d3991a}.admin-shell{max-width:1080px}.admin-shell>.card,.admin-shell>.admin-two-col{margin:18px 0 0}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:0}.admin-stat{background:var(--panel);border:1px solid var(--panel-border);border-radius:14px;padding:16px 18px}.admin-stat-value{font-size:1.9rem;font-weight:800;line-height:1.1;background:linear-gradient(90deg,var(--cyan),var(--good));-webkit-background-clip:text;background-clip:text;color:transparent}.admin-stat-label{font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-top:4px}.admin-stat-sub{font-size:.72rem;margin-top:2px}.admin-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.admin-two-col>.card{margin:0}@media(max-width:720px){.admin-two-col{grid-template-columns:1fr}}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{text-align:left;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);padding:6px 10px;border-bottom:1px solid var(--panel-border)}.admin-table td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:middle}.admin-table td.num,.admin-table th.num{text-align:right;font-variant-numeric:tabular-nums}.admin-code{font-size:.85rem;letter-spacing:.12em;padding:2px 8px}.admin-code-sm{font-size:.7rem;letter-spacing:.08em;padding:1px 6px}.admin-now{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-live-text{color:var(--good);font-weight:700}.admin-live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--good);margin-left:6px;box-shadow:0 0 8px var(--good)}.admin-room-row{cursor:pointer}.admin-room-row:hover{background:#ffffff08}.admin-caret{display:inline-block;width:16px;color:var(--muted)}.admin-room-detail td{background:#0000002e;padding:14px 16px}.admin-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:720px){.admin-detail-grid{grid-template-columns:1fr}}.admin-detail-grid h4{margin:0 0 8px;font-size:.85rem;color:var(--muted)}.admin-subtable{width:100%;border-collapse:collapse;font-size:.82rem}.admin-subtable th{text-align:left;color:var(--muted);font-weight:600;padding:3px 8px 3px 0}.admin-subtable td{padding:3px 8px 3px 0}.admin-song-history,.admin-recent,.admin-top-songs{margin:0;padding:0;list-style:none}.admin-song-history{padding-left:18px;list-style:decimal}.admin-song-history li,.admin-recent li{padding:5px 0;border-bottom:1px solid rgba(255,255,255,.05)}.admin-song-title{display:block;font-weight:600}.admin-song-meta{font-size:.76rem}.admin-top-songs li{padding:6px 0}.admin-top-row{display:flex;justify-content:space-between;gap:10px;font-size:.88rem;margin-bottom:4px}.admin-top-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-top-count{font-weight:700;color:var(--gold);flex-shrink:0}.admin-bar{height:6px;border-radius:4px;background:#ffffff0f;overflow:hidden}.admin-bar-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--purple),var(--pink))}.role-badge.is-singer{background:#9a96c42e;color:var(--muted)}
