@font-face{font-family:IQOSFont;src:url(/assets/IQOS-Light-BrD4sYXV.otf) format("opentype");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:IQOSFont;src:url(/assets/IQOS-Regular-BjDIfRuA.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:IQOSFont;src:url(/assets/IQOS-Bold-C7G6o7xA.otf) format("opentype");font-weight:700;font-style:normal;font-display:swap}*{box-sizing:border-box}:root{color:#101114;background:#111;font-family:IQOSFont,Trebuchet MS,Avenir Next,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--accent-green: #08b70e;--accent-yellow: #f9df3d;--accent-red: #ef4136;--surface-dark: rgba(18, 18, 20, .6);--pill-white: rgba(255, 255, 255, .92)}body{margin:0;min-width:320px;min-height:100dvh;background:#111}button{border:0;font:inherit}#app{min-height:100dvh}.app-shell{min-height:100vh;display:grid;place-items:center;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);background:radial-gradient(circle at top right,rgba(255,255,255,.18),transparent 22%),linear-gradient(145deg,#17b445eb,#fbe036b3 42%,#ed4035e6),#151515}.panel{width:min(100vw,460px);min-width:0;min-height:100svh;display:grid;grid-template-rows:auto 1fr auto;gap:24px;padding:max(24px,env(safe-area-inset-top)) 22px max(28px,env(safe-area-inset-bottom));overflow:hidden;position:relative}.label{margin:0 0 10px;color:#ffffffc7;font-size:13px;font-weight:900;letter-spacing:0;text-transform:uppercase}h1,h2{margin:0;max-width:12ch;color:#fff;font-size:clamp(38px,11vw,54px);line-height:.95;letter-spacing:0}h2{font-size:clamp(34px,10vw,48px)}.body-copy{max-width:30ch;margin:14px 0 0;color:#ffffffd1;font-size:16px;line-height:1.45}.brand-lockup{display:grid;grid-template-columns:76px 1fr;gap:16px;align-items:start;padding-top:20px;position:relative;z-index:2}.brand-ball{width:76px;height:76px;object-fit:contain;filter:drop-shadow(0 12px 24px rgba(0,0,0,.35))}.intro-art{position:absolute;top:132px;right:0;bottom:180px;left:0;min-height:0;z-index:0;pointer-events:none;opacity:.82}.entry-stack{display:grid;gap:14px;align-content:end;position:relative;z-index:1;padding-top:150px;padding-bottom:8px}.intro-screen .entry-stack:before{content:"";position:absolute;top:-16px;right:-10px;bottom:-10px;left:-10px;z-index:-1;border-radius:28px 28px 18px 18px;background:linear-gradient(180deg,#ffffff0f,#0f0f1224);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.entry-label{color:#fff;font-size:14px;font-weight:900}.intro-explainer{margin-top:4px;color:#ffffffd1;font-size:13px;font-weight:700;line-height:1.4}.entry-input{min-height:54px;width:100%;border:2px solid rgba(255,255,255,.42);border-radius:12px;padding:0 16px;background:#ffffff24;color:#fff;font:inherit;font-size:17px}.entry-input::placeholder{color:#fff9}.consent-row{display:grid;grid-template-columns:22px 1fr;gap:12px;align-items:start;color:#ffffffe6;font-size:14px;line-height:1.4}.consent-row input{width:20px;height:20px;margin:2px 0 0}.entry-privacy-link{align-self:start;margin:-2px 0 0 34px;color:#ff6ec7;font-size:13px;font-weight:700;text-decoration:underline;text-underline-offset:2px}.intro-mic,.intro-speaker,.intro-headphones{position:absolute;object-fit:contain;filter:drop-shadow(0 18px 28px rgba(0,0,0,.28))}.intro-mic{width:20%;left:-2%;top:60px;bottom:auto;transform:rotate(-12deg);z-index:0;opacity:.6}.intro-speaker{width:36%;right:-2%;top:22%;transform:rotate(8deg)}.intro-headphones{width:18%;left:42%;top:28%;transform:rotate(-4deg)}.intro-screen{position:relative;isolation:isolate}.intro-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:0;pointer-events:none}.intro-screen>*{position:relative;z-index:1}.primary-action,.ghost-action{min-height:58px;border-radius:8px;padding:0 22px;display:inline-grid;place-items:center;color:#101114;background:#fff;font-weight:950;font-size:17px;box-shadow:0 14px 32px #00000038}.primary-action:disabled{opacity:.68}.ghost-action{min-height:44px;color:#fff;background:#0000006b;box-shadow:none;border:1px solid rgba(255,255,255,.36)}.permission-stack{display:grid;gap:12px;align-content:start;margin-top:12px}.permission-copy{position:relative;z-index:1}.permission-step{display:inline-flex;align-items:center;gap:10px;margin:0 0 14px}.permission-step-pill{min-height:30px;display:inline-grid;place-items:center;padding:0 12px;border-radius:999px;background:#ffffffeb;color:#141519;font-size:12px;font-weight:950}.permission-step-copy{color:#ffffffc7;font-size:13px;font-weight:800;text-transform:uppercase}.permission-row{display:flex;justify-content:space-between;gap:16px;padding:18px 20px;border:1px solid rgba(255,255,255,.24);border-radius:18px;background:linear-gradient(180deg,#ffffff2e,#ffffff1f);color:#fff;font-weight:900;box-shadow:0 14px 32px #00000024;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.permission-row span{color:#ffffffad;font-size:13px}.permission-screen{position:relative;grid-template-rows:auto auto 1fr auto}.permission-hero{position:absolute;top:108px;right:14px;width:190px;height:178px;pointer-events:none}.permission-hero-ball,.permission-hero-mic{position:absolute;object-fit:contain;filter:drop-shadow(0 16px 24px rgba(0,0,0,.2))}.permission-hero-ball{width:56px;left:8px;top:10px}.permission-hero-mic{width:124px;right:8px;top:14px;transform:rotate(10deg)}.permission-hero-ring{position:absolute;right:0;bottom:0;width:150px;height:150px;border-radius:999px;border:2px solid rgba(255,255,255,.18);background:radial-gradient(circle at center,rgba(255,255,255,.06) 0 28%,transparent 29%),radial-gradient(circle at center,transparent 0 58%,rgba(255,255,255,.15) 59% 62%,transparent 63%)}.permission-screen:after{content:"";position:absolute;right:-42px;top:190px;width:160px;height:160px;border-radius:999px;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.22) 0 18%,transparent 19%),radial-gradient(circle at 50% 50%,transparent 0 42%,rgba(255,255,255,.32) 43% 48%,transparent 49%),radial-gradient(circle at 50% 50%,transparent 0 68%,rgba(255,255,255,.18) 69% 72%,transparent 73%);opacity:.7;pointer-events:none}.permission-screen .primary-action{position:relative;z-index:1}.error-text{min-height:20px;margin:0;color:#fff;font-weight:800}.zone-card{align-self:start;justify-self:center;width:min(280px,82vw);display:grid;justify-items:center;gap:16px;color:#fff}.calibration-progress{display:flex;justify-content:space-between;gap:16px;align-items:end;color:#fff}.calibration-label{margin-bottom:6px}.calibration-step-copy{margin:0;max-width:24ch;font-size:14px;font-weight:800;line-height:1.35}.calibration-counter{font-size:22px;line-height:1}.zone-name{font-size:42px;font-weight:950}.voice-meter{width:76px;height:260px;display:flex;align-items:end;padding:9px;border:5px solid #fff;border-radius:999px;background:#00000070}.voice-meter span{width:100%;min-height:10%;border-radius:999px;background:linear-gradient(var(--accent-yellow),var(--accent-red) 42%,#42d392)}.pitch-readout{font-size:18px;font-weight:850}.calibration-zones,.zone-legend,.capture-stack{display:grid;gap:10px}.capture-row{min-height:62px;display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:0 18px;border-radius:14px;background:#ffffff24;border:1px solid rgba(255,255,255,.32);color:#fff;text-align:left}.capture-row strong,.capture-row span,.capture-row small{pointer-events:none}.capture-row strong{font-size:17px}.capture-index{min-width:38px;min-height:38px;display:grid;place-items:center;border-radius:999px;background:#ffffff24;font-size:12px;font-weight:950}.capture-copy{display:grid;gap:2px}.capture-copy small{font-size:13px;opacity:.8}.capture-meta{font-size:12px;font-weight:900;text-transform:uppercase;opacity:.88}.capture-row[data-status=active]{border-color:#ffffffeb;background:#ffffff38;transform:translateY(-1px)}.capture-row[data-status=complete]{background:#42d39233;border-color:#42d392d1}.capture-row[data-status=complete] .capture-index{background:#42d3924d}.threshold-readout{font-size:15px;font-weight:800;text-align:center}.zone-legend{position:absolute;left:84px;top:152px;width:min(160px,42vw)}.zone-chip{min-height:34px;display:inline-flex;align-items:center;gap:8px;width:fit-content;padding:8px 12px;border-radius:999px;background:var(--pill-white);color:#151519;box-shadow:0 5px 14px #0000002e;font-size:12px;font-weight:900}.zone-chip i{width:11px;height:11px;border-radius:999px;background:#42d392}.zone-chip.normal i{background:var(--accent-yellow)}.zone-chip.high i{background:var(--accent-red)}.game-screen{position:relative;width:100vw;min-height:100dvh;overflow:hidden;background:#121212}.camera-feed,.camera-fallback{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.camera-feed{z-index:1;transform:scaleX(-1);filter:brightness(.95) contrast(1.05) saturate(.9)}.camera-feed.is-hidden{display:none}.camera-tint{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,#0006,#0000002e 40%,#000000b3)}.camera-fallback{z-index:0;background:radial-gradient(circle at top right,rgba(255,255,255,.18),transparent 22%),linear-gradient(145deg,#17b445eb,#fbe036b3 42%,#ed4035e6),#151515}.game-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;padding:max(16px,env(safe-area-inset-top)) 16px max(18px,env(safe-area-inset-bottom));background:linear-gradient(180deg,rgba(0,0,0,.24),transparent 36%,rgba(0,0,0,.34))}.timer-readout{position:absolute;top:max(16px,env(safe-area-inset-top));right:16px;min-width:62px;height:62px;display:grid;place-items:center;padding:0 18px;border-radius:18px;border:2px solid rgba(255,255,255,.82);background:#1414148a;color:#fff;text-align:center;font-size:28px;font-weight:950;line-height:1;box-shadow:0 8px 18px #0003}.score-readout{position:absolute;top:max(16px,env(safe-area-inset-top));left:50%;transform:translate(-50%);color:#fff;font-size:clamp(38px,11vw,56px);font-weight:950;line-height:1;letter-spacing:-.04em;text-shadow:0 2px 0 rgba(0,0,0,.3),0 0 16px rgba(0,0,0,.34)}.lyric-ticker{position:absolute;left:0;right:0;top:11%;padding:0 20px;pointer-events:none;z-index:3;text-align:center;opacity:0;transition:opacity .4s ease}.lyric-ticker.is-visible{opacity:1}.lyric-title{display:block;margin-bottom:6px;color:#ffffff8c;font-size:clamp(11px,3vw,16px);font-weight:600;letter-spacing:.05em;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.5)}.lyric-lines{display:flex;flex-direction:column;align-items:center;gap:4px}.lyric-line{display:block;white-space:normal;word-wrap:break-word;color:#fff;font-size:clamp(18px,5vw,28px);font-weight:950;line-height:1.3;text-shadow:0 3px 12px rgba(0,0,0,.72)}.lane-scene{position:absolute;left:0;right:0;bottom:88px;height:46%}.lane-back,.lane-main,.lane-front{position:absolute;left:-6%;right:-6%;border-radius:0}.lane-back{bottom:20%;height:10%;background:linear-gradient(90deg,#74e5bbe6,#6edbcee0);opacity:.82}.lane-main{bottom:10%;height:14%;background:linear-gradient(90deg,#53dcb0,#4fd6c7 52%,#4cd0ba);box-shadow:0 12px 24px #00000038}.lane-front{bottom:0;height:10%;background:linear-gradient(90deg,#a469d1db,#fb7961e6)}.actor-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2}.player-ball{position:absolute;left:28%;bottom:18%;z-index:110;width:clamp(58px,18.2vw,83px);aspect-ratio:1;object-fit:contain;transform:translate(-50%,50%);filter:drop-shadow(0 16px 22px rgba(0,0,0,.34));transition:transform .17s ease;will-change:bottom,transform}.player-ball[data-state=stalled]{animation:bonk .3s ease}@keyframes bonk{0%{transform:translate(-50%,50%)}30%{transform:translate(calc(-50% - 12px),50%) scale(.9)}60%{transform:translate(calc(-50% + 4px),50%) scale(1.05)}to{transform:translate(-50%,50%)}}@keyframes idle-bounce{0%,to{transform:translate(-50%,50%) translateY(0)}50%{transform:translate(-50%,50%) translateY(-8px)}}.player-ball.grounded{animation:idle-bounce .6s ease-in-out infinite}.player-shadow{position:absolute;left:28%;bottom:14%;z-index:0;width:96px;height:20px;border-radius:999px;background:#00000057;transform:translate(-50%);filter:blur(5px);transform-origin:center center}.beat-indicator{position:absolute;left:28%;bottom:28%;width:40px;height:40px;border:3px solid rgba(255,255,255,.6);border-radius:50%;z-index:120;pointer-events:none;transform:translate(-50%);animation:beat-pulse .5s ease-in-out infinite}@keyframes beat-pulse{0%,to{transform:translate(-50%) scale(1);opacity:.6}50%{transform:translate(-50%) scale(1.4);opacity:.2}}.obstacle-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.motion-trail{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;width:100%;height:100%;pointer-events:none;overflow:visible}.obstacle{--obstacle-nudge-x: 0px;position:absolute;left:84%;bottom:18%;width:109px;display:grid;place-items:end center;transform:translate(calc(-50% + var(--obstacle-nudge-x)));transition:left .14s linear,bottom .14s ease,width .14s ease,transform .14s ease}.obstacle[data-cleared=true]{opacity:.82}.obstacle[data-cleared=false]{animation:obstacle-pulse .8s ease-in-out infinite}@keyframes obstacle-pulse{0%,to{filter:drop-shadow(0 8px 14px rgba(0,0,0,.22))}50%{filter:drop-shadow(0 0 20px rgba(239,65,54,.6))}}.obstacle.just-cleared{animation:obstacle-cleared-flash .4s ease-out}@keyframes obstacle-cleared-flash{0%{filter:drop-shadow(0 0 22px rgba(66,211,146,.85))}to{filter:drop-shadow(0 8px 14px rgba(0,0,0,.22))}}.obstacle[data-state=stalled]{--obstacle-nudge-x: -6px}.obstacle-icon{width:100%;max-height:182px;object-fit:contain;filter:drop-shadow(0 8px 14px rgba(0,0,0,.22))}.game-actions{position:absolute;left:50%;bottom:16px;display:flex;flex-wrap:wrap;justify-content:center;gap:8px;transform:translate(-50%)}.debug-voice-controls{display:flex;gap:8px}.debug-chip{min-height:38px;padding:0 14px;font-size:12px}.debug-chip.is-active{background:#ffffff38;border-color:#ffffffd1}.result-grid{align-self:center;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.result-grid div{min-height:108px;display:grid;align-content:center;justify-items:center;padding:12px 8px;background:#ffffff29;border:1px solid rgba(255,255,255,.28);color:#fff}.result-grid span{font-size:11px;font-weight:900;text-transform:uppercase}.result-grid strong{font-size:clamp(25px,8vw,34px)}.result-flow{position:relative;min-height:300px}.result-qr-section,.result-leaderboard-section{transition:opacity .4s ease,transform .4s ease}.result-qr-section.hidden{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;pointer-events:none;transform:translateY(-20px)}.result-leaderboard-section.hidden{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;pointer-events:none;transform:translateY(20px)}.result-countdown{margin:12px 0 0;color:#fff9;font-size:clamp(12px,3.5vw,16px);font-weight:800;text-align:center}@media(max-width:390px){.intro-mic{width:16%;top:50px}.entry-stack{padding-top:132px}.calibration-progress{align-items:start}.permission-screen:after{width:132px;height:132px;top:214px;right:-36px}.permission-hero{top:126px;right:10px;width:154px;height:142px}.permission-hero-ball{width:46px}.permission-hero-mic{width:102px}.permission-hero-ring{width:122px;height:122px}}@media(max-height:760px){.lyric-ticker{top:11%}.lane-scene{bottom:84px;height:44%}.game-actions{bottom:14px}}@media(min-width:760px){.entry-stack{padding-top:138px}.game-screen{width:min(430px,100vw);min-height:min(100svh,860px);margin:0 auto;box-shadow:0 24px 70px #0000005c}body{display:grid;place-items:center;background:#232323}}.admin-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:center;padding:24px;background:#08080a9e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.admin-panel[hidden]{display:none}.admin-card{position:relative;width:min(420px,100%);max-height:calc(100svh - 48px);display:grid;gap:10px;padding:20px;border-radius:18px;border:1px solid rgba(255,255,255,.16);background:#141418e0;color:#fff;box-shadow:0 24px 60px #00000080;overflow:hidden}.admin-card h3{margin:0 0 4px;font-size:18px;font-weight:950}.admin-action{min-height:46px;padding:0 16px;border-radius:12px;border:1px solid rgba(255,255,255,.22);background:#ffffff14;color:#fff;font-size:14px;font-weight:800;cursor:pointer}.admin-close{background:#ffffff2e}.admin-danger{background:#ef41362e;border-color:#ef413680;color:#ff6b5e}.admin-danger:active{background:#ef413652}.admin-confirm{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#0009;border-radius:18px;z-index:10}.admin-confirm[hidden]{display:none}.admin-confirm-card{width:100%;display:grid;gap:14px;text-align:center}.admin-confirm-text{margin:0;font-size:15px;font-weight:800;line-height:1.4;color:#fff}.admin-confirm-actions{display:grid;gap:8px}.admin-toggle{display:flex;align-items:center;gap:10px;padding:6px 2px;font-size:14px;font-weight:800}.qr-gallery{min-height:100vh;padding:32px clamp(16px,4vw,48px) 48px;background:radial-gradient(circle at top right,rgba(255,255,255,.12),transparent 24%),linear-gradient(145deg,#17b445d9,#fbe03699 42%,#ed4035d9),#111;color:#fff;font-family:inherit}.qr-gallery-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.qr-gallery-header h1{margin:0 0 4px;font-size:clamp(22px,4vw,32px);font-weight:950}.qr-gallery-header p{margin:0;color:#ffffffd1;font-size:14px}.qr-gallery-refresh{align-self:flex-start;padding:10px 16px;border:1px solid rgba(255,255,255,.45);border-radius:999px;background:#00000047;color:#fff;font-size:14px;font-weight:800;cursor:pointer}.qr-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.qr-gallery-status{grid-column:1 / -1;padding:40px 0;color:#ffffffd9;font-size:16px;text-align:center}.qr-gallery-card{display:flex;flex-direction:column;gap:12px;padding:16px;border-radius:16px;background:#0000006b;box-shadow:0 12px 28px #00000040}.qr-gallery-qr{display:flex;align-items:center;justify-content:center;aspect-ratio:1 / 1;border-radius:12px;background:#fff;color:#111;overflow:hidden}.qr-gallery-qr img{width:100%;height:100%;object-fit:contain}.qr-gallery-no-qr{padding:12px;font-size:12px;font-weight:700;text-align:center}.qr-gallery-meta{display:flex;flex-direction:column;gap:4px;font-size:13px}.qr-gallery-meta strong{font-size:15px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-gallery-time{color:#ffffffb3;font-size:12px}.qr-gallery-link{margin-top:4px;color:#fff;font-weight:800;text-decoration:underline}.game-toast{position:absolute;top:40%;left:50%;transform:translate(-50%);font-size:clamp(28px,8vw,42px);font-weight:950;pointer-events:none;z-index:50;animation:toast-float .8s ease-out forwards}.toast-perfect{color:#f9df3d;text-shadow:0 0 20px rgba(249,223,61,.5)}.toast-good{color:#42d392;text-shadow:0 0 20px rgba(66,211,146,.5)}.toast-miss{color:#ef4136;text-shadow:0 0 20px rgba(239,65,54,.5)}@keyframes toast-float{0%{opacity:1;transform:translate(-50%) scale(.8)}20%{transform:translate(-50%,-10px) scale(1.1)}to{opacity:0;transform:translate(-50%,-60px) scale(1)}}.game-screen.shake{animation:screen-shake .3s ease}@keyframes screen-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.pause-btn{position:absolute;bottom:16px;right:16px;z-index:50;width:40px;height:40px;border:none;border-radius:50%;background:#ffffff1f;color:#ffffff4d;font-size:18px;cursor:pointer;display:grid;place-items:center;transition:opacity .2s,background .2s;opacity:.3;padding:0}.pause-btn:hover{opacity:.7}.pause-btn:active{opacity:.7;background:#ffffff38}.pause-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:180;display:grid;place-items:center;padding:24px;background:#08080abf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.pause-overlay[hidden]{display:none}.pause-card{width:min(300px,100%);display:grid;gap:12px;padding:24px;border-radius:18px;border:1px solid rgba(255,255,255,.16);background:#141418eb;color:#fff;box-shadow:0 24px 60px #00000080;text-align:center}.pause-card h3{margin:0 0 8px;font-size:20px;font-weight:950}.pause-action{min-height:48px;padding:0 16px;border-radius:12px;border:1px solid rgba(255,255,255,.22);background:#ffffff14;color:#fff;font-size:15px;font-weight:800;cursor:pointer}.pause-action:active{background:#ffffff2e}.mic-bar{position:absolute;right:12px;top:15%;bottom:20%;width:36px;z-index:40;display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none}.mic-bar-track{flex:1;width:14px;border-radius:7px;background:#ffffff1f;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end}.mic-bar-fill{width:100%;border-radius:7px;background:linear-gradient(to top,#e8836a,#f0a0a0,#f5c5d0,#fff);transition:height .08s ease-out;height:0%}.mic-bar-icon{font-size:20px;color:#e8836a;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));line-height:1}.result-actions{display:grid;gap:10px}.leaderboard-title{margin:0;color:#fff;font-size:clamp(34px,10vw,48px);font-weight:950;line-height:.95}.leaderboard-list{display:grid;grid-auto-rows:1fr;gap:6px;overflow:hidden;min-height:0;padding:4px 0}.leaderboard-entry{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:10px 16px;border-radius:14px;color:#fff;box-shadow:0 4px 16px #00000038;font-weight:800}.leaderboard-entry.is-first{padding:14px 18px;font-size:1.15em;box-shadow:0 6px 22px #0000004d}.leaderboard-entry.is-empty{opacity:.5}.leaderboard-entry.is-empty .leaderboard-name{opacity:.4;font-style:italic}.leaderboard-entry.is-current-player{outline:2px solid rgba(255,255,255,.8);outline-offset:2px;animation:leaderboard-current-player-glow 1.5s ease-in-out infinite}@keyframes leaderboard-current-player-glow{0%,to{outline-color:#fffc}50%{outline-color:#ffffff4d}}.leaderboard-rank{font-size:22px;font-weight:950;min-width:36px;text-align:center}.leaderboard-name{font-size:15px;font-weight:700;opacity:.92;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-score{font-size:20px;font-weight:950;text-align:right}.leaderboard-actions{display:grid;justify-items:center;padding-top:2px}.leaderboard-start-action{min-height:44px;min-width:132px;padding:0 24px;color:#ffffffdb;background:#0000003d;border-color:#ffffff47;box-shadow:none}.recording-section{display:grid;justify-items:center;gap:12px;padding:16px 0}.recording-section[hidden]{display:none}.recording-qr,.recording-error{display:grid;justify-items:center;gap:12px;width:100%}.recording-qr[hidden],.recording-error[hidden],.recording-download-local[hidden]{display:none}.loading-status{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;color:#ffffffc7;font-size:14px;font-weight:700}.loading-status[hidden]{display:none}.loading-status-text{margin:0}.loading-spinner{width:22px;height:22px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:loading-spin .8s linear infinite}@keyframes loading-spin{to{transform:rotate(360deg)}}.recording-qr-label{margin:0;color:#ffffffd1;font-size:14px;font-weight:800;text-align:center}.recording-qr-img{width:200px;height:200px;border-radius:14px;background:#fff;padding:8px;box-shadow:0 8px 24px #0000004d}.recording-download,.recording-download-local{min-height:40px;font-size:14px}.recording-error-text{margin:0;color:#ff9b93;font-size:13px;font-weight:700;text-align:center}.game-countdown{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#00000047;font-size:clamp(80px,22vw,180px);font-weight:900;color:#fff;text-shadow:0 0 36px rgba(255,100,200,.7),0 4px 18px rgba(0,0,0,.85);font-family:inherit;pointer-events:auto}.game-countdown.pop{animation:countdown-pop .8s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes countdown-pop{0%{transform:scale(2.5);opacity:0}30%{transform:scale(.9);opacity:1}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.qr-recall-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9997;display:flex;align-items:center;justify-content:center;background:#000000e0}.qr-recall-card{display:flex;flex-direction:column;align-items:center;gap:16px;padding:28px;background:#fff;border-radius:22px;box-shadow:0 24px 60px #00000080}.qr-recall-name{margin:0;font-size:26px;font-weight:900;color:#111}.qr-recall-img{width:min(60vw,360px);height:min(60vw,360px)}.qr-recall-hint{margin:0;font-size:15px;font-weight:600;color:#555}.qr-recall-close{margin-top:4px;padding:12px 28px;font-size:16px;font-weight:800;border-radius:12px;background:#111;color:#fff;cursor:pointer}.privacy-page{max-width:640px;margin:0 auto;padding:32px 24px;color:#f2f2f2;line-height:1.55}.privacy-page h1{font-size:26px;font-weight:800}.privacy-page ul{padding-left:20px}.privacy-page a.privacy-back{color:#ff6ec7;text-decoration:underline}.controller-body{margin:0;padding:0;background:#111;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100dvh;overflow-x:hidden}.controller-root{max-width:600px;margin:0 auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}.ctrl-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.ctrl-header h1{font-size:20px;font-weight:800;margin:0}.ctrl-status{display:flex;align-items:center;gap:8px;font-size:13px;color:#ffffffb3}.ctrl-status-dot{width:10px;height:10px;border-radius:50%;background:#888;flex-shrink:0}.ctrl-panel{background:#ffffff0d;border-radius:16px;padding:20px}.ctrl-panel.hidden{display:none}.ctrl-label{display:block;font-size:14px;font-weight:600;color:#fff9;margin-bottom:8px}.ctrl-input{width:100%;padding:14px 16px;font-size:18px;font-weight:600;border:2px solid rgba(255,255,255,.15);border-radius:12px;background:#ffffff14;color:#fff;outline:none;transition:border-color .2s;box-sizing:border-box;-webkit-appearance:none}.ctrl-input:focus{border-color:#ff64c899}.ctrl-input-small{padding:10px 14px;font-size:15px}.ctrl-gdpr{margin-top:12px;margin-bottom:4px}.ctrl-gdpr-label{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#ffffffb3;cursor:pointer}.ctrl-gdpr-label input[type=checkbox]{width:22px;height:22px;margin-top:1px;flex-shrink:0;accent-color:#ff6ec7}.ctrl-gdpr-link{color:#ff6ec7;text-decoration:underline;text-underline-offset:2px}.ctrl-hint{margin:12px 0 0;font-size:13px;font-weight:600;color:#ffcf6e}.ctrl-btn{display:block;width:100%;padding:16px;font-size:18px;font-weight:800;border:none;border-radius:12px;cursor:pointer;transition:opacity .2s,transform .1s;-webkit-tap-highlight-color:transparent;margin-top:12px;min-height:44px}.ctrl-btn:active{transform:scale(.97)}.ctrl-btn:disabled{opacity:.35;cursor:not-allowed}.ctrl-btn-primary{background:linear-gradient(135deg,#ff6ec7,#ff3d8b);color:#fff}.ctrl-btn-warning{background:#ff9800;color:#000}.ctrl-btn-danger{background:#dc2828d9;color:#fff}.ctrl-btn-small{width:auto;padding:10px 16px;font-size:14px;margin-top:0;min-height:44px}.ctrl-actions{display:flex;gap:12px;margin-top:16px}.ctrl-actions .ctrl-btn{flex:1;margin-top:0}.ctrl-live-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ctrl-stat{display:flex;flex-direction:column;gap:2px}.ctrl-stat-label{font-size:11px;font-weight:600;color:#ffffff73;text-transform:uppercase;letter-spacing:.05em}.ctrl-stat-value{font-size:22px;font-weight:800;color:#fff}.ctrl-stat-value.ctrl-lyric{font-size:14px;font-weight:600;color:#ffffffb3;grid-column:1 / -1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ctrl-paused-text{font-size:24px;font-weight:800;text-align:center;color:#ff9800;margin:0 0 8px}.ctrl-result-info{text-align:center;margin-bottom:12px}.ctrl-result-player{display:block;font-size:24px;font-weight:800}.ctrl-result-score{display:block;font-size:16px;color:#fff9;margin-top:4px}.ctrl-result-status{text-align:center;font-size:14px;color:#ffffff80}.ctrl-qr-panel{border-top:1px solid rgba(255,255,255,.08)}.ctrl-qr-panel h3{font-size:15px;font-weight:700;margin:0 0 12px}.ctrl-qr-results{display:flex;flex-direction:column;gap:8px;max-height:40vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.ctrl-qr-entry{display:flex;align-items:center;justify-content:space-between;background:#ffffff0f;border-radius:10px;padding:10px 14px;gap:10px}.ctrl-qr-info{display:flex;flex-direction:column;gap:2px;min-width:0}.ctrl-qr-info strong{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ctrl-qr-info span{font-size:12px;color:#ffffff73}.ctrl-qr-empty{font-size:13px;color:#fff6;text-align:center;padding:12px 0}.ctrl-countdown-text{font-size:20px;font-weight:700;text-align:center;color:#f0c040;animation:ctrl-pulse 1s ease-in-out infinite}@keyframes ctrl-pulse{0%,to{opacity:1}50%{opacity:.5}}.ctrl-admin-panel{border-top:1px solid rgba(255,255,255,.08);background:#ffffff08}.ctrl-admin-toggle{display:block;width:100%;background:none;border:none;color:#ffffff80;font-size:14px;font-weight:600;cursor:pointer;padding:0;text-align:left;min-height:44px}.ctrl-admin-content{margin-top:16px;display:flex;flex-direction:column;gap:16px}.ctrl-admin-content.hidden{display:none}.ctrl-setting{display:flex;flex-direction:column;gap:8px}.ctrl-setting-label{font-size:13px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.04em}.ctrl-setting-options{display:flex;gap:8px}.ctrl-setting-btn{flex:1;padding:12px 16px;font-size:15px;font-weight:700;border:2px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff0d;color:#fff9;cursor:pointer;transition:all .2s;min-height:44px}.ctrl-setting-btn.active{border-color:#ff6ec7;background:#ff6ec726;color:#fff}.ctrl-speed-control{display:flex;align-items:center;gap:12px}.ctrl-speed-value{font-size:24px;font-weight:800;color:#fff;min-width:60px;text-align:center}.ctrl-speed-control .ctrl-btn{width:48px;height:48px;padding:0;font-size:24px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0;background:#ffffff1a;color:#fff}.ctrl-setting-hint{font-size:12px;color:#ffffff59}
