@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-grotesk-vietnamese-400-normal-B7xT_GF5.woff2) format("woff2"),url(/assets/space-grotesk-vietnamese-400-normal-BIWiOVfw.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-grotesk-latin-ext-400-normal-CfP_5XZW.woff2) format("woff2"),url(/assets/space-grotesk-latin-ext-400-normal-DRPE3kg4.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-grotesk-latin-400-normal-CJ-V5oYT.woff2) format("woff2"),url(/assets/space-grotesk-latin-400-normal-BnQMeOim.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-vietnamese-600-normal-DUi7WF5p.woff2) format("woff2"),url(/assets/space-grotesk-vietnamese-600-normal-D6zpsUhD.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-latin-ext-600-normal-DxxdqCpr.woff2) format("woff2"),url(/assets/space-grotesk-latin-ext-600-normal-VcznFIpX.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-latin-600-normal-DjKNqYRj.woff2) format("woff2"),url(/assets/space-grotesk-latin-600-normal-BflQw4A9.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-vietnamese-700-normal-DMty7AZE.woff2) format("woff2"),url(/assets/space-grotesk-vietnamese-700-normal-Duxec5Rn.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-latin-ext-700-normal-BQnZhY3m.woff2) format("woff2"),url(/assets/space-grotesk-latin-ext-700-normal-HVCqSBdx.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-latin-700-normal-RjhwGPKo.woff2) format("woff2"),url(/assets/space-grotesk-latin-700-normal-CwsQ-cCU.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: #0a0a0f;--bg-rgb: 10 10 15;--surface-on: 255 255 255;--surface: rgb(var(--surface-on) / .04);--surface-2: rgb(var(--surface-on) / .07);--surface-line: rgb(var(--surface-on) / .06);--border: rgb(var(--surface-on) / .09);--text: #e9e9f2;--text-rgb: 233 233 242;--dim: rgb(var(--text-rgb) / .45);--text-soft: rgb(var(--text-rgb) / .78);--accent: #22d3ee;--accent-rgb: 34 211 238;--accent-2: #e879f9;--accent-2-rgb: 232 121 249;--accent-soft: rgb(var(--accent-rgb) / .14);--accent-2-soft: rgb(var(--accent-2-rgb) / .13);--glow: rgb(var(--accent-rgb) / .16);--gold: #fbbf24;--gold-rgb: 251 191 36;--gold-soft: rgb(var(--gold-rgb) / .18);--gold-glow: rgb(var(--gold-rgb) / .18);--good: #34d399;--bad: #f87171;--bad-rgb: 248 113 113;--bad-soft: rgb(var(--bad-rgb) / .12);--bad-glow: rgb(var(--bad-rgb) / .55);--hand-l: #9bd6e8;--hand-l-rgb: 155 214 232;--hand-r: #dfb8ea;--hand-r-rgb: 223 184 234;--overlay-bg: rgb(var(--bg-rgb) / .82);--panel-bg: rgb(var(--bg-rgb) / .9);--detail-bg: rgb(0 0 0 / .18);--selection: rgb(var(--accent-rgb) / .3);--on-bright: #0a0a0f;--font-display: "Space Grotesk", system-ui, sans-serif;--font-mono: ui-monospace, "SF Mono", "Cascadia Mono", Menlo, monospace}:root[data-theme=sunset]{--bg: #180e1d;--bg-rgb: 24 14 29;--surface-on: 255 240 230;--text: #fce7e0;--text-rgb: 252 231 224;--accent: #fb7185;--accent-rgb: 251 113 133;--accent-2: #f59e0b;--accent-2-rgb: 245 158 11;--glow: rgb(var(--accent-rgb) / .2);--gold: #fbbf24;--gold-rgb: 251 191 36;--good: #6ee7b7;--bad: #ef4444;--bad-rgb: 239 68 68;--hand-l: #fda4af;--hand-l-rgb: 253 164 175;--hand-r: #fdba74;--hand-r-rgb: 253 186 116}:root[data-theme=moss]{--bg: #0f1714;--bg-rgb: 15 23 20;--surface-on: 220 250 220;--text: #e9f5e6;--text-rgb: 233 245 230;--accent: #a3e635;--accent-rgb: 163 230 53;--accent-2: #2dd4bf;--accent-2-rgb: 45 212 191;--glow: rgb(var(--accent-rgb) / .2);--gold: #facc15;--gold-rgb: 250 204 21;--good: #86efac;--bad: #fb7185;--bad-rgb: 251 113 133;--hand-l: #bef264;--hand-l-rgb: 190 242 100;--hand-r: #5eead4;--hand-r-rgb: 94 234 212}:root[data-theme=paper]{--bg: #e8dfd1;--bg-rgb: 232 223 209;--surface-on: 39 35 29;--surface: rgb(var(--surface-on) / .05);--surface-2: rgb(var(--surface-on) / .08);--border: rgb(var(--surface-on) / .13);--text: #27231d;--text-rgb: 39 35 29;--dim: rgb(var(--text-rgb) / .58);--accent: #476b64;--accent-rgb: 71 107 100;--accent-2: #7b5948;--accent-2-rgb: 123 89 72;--glow: rgb(var(--accent-rgb) / .13);--gold: #735a27;--gold-rgb: 115 90 39;--good: #58724f;--bad: #964a43;--bad-rgb: 150 74 67;--hand-l: #476b64;--hand-l-rgb: 71 107 100;--hand-r: #745b66;--hand-r-rgb: 116 91 102;--overlay-bg: rgb(232 223 209 / .88);--panel-bg: rgb(232 223 209 / .95);--detail-bg: rgb(var(--surface-on) / .05);--on-bright: #f5efe4}:root[data-theme=voltage]{--bg: #101012;--bg-rgb: 16 16 18;--surface-on: 245 245 240;--text: #f1f5f9;--text-rgb: 241 245 249;--accent: #38bdf8;--accent-rgb: 56 189 248;--accent-2: #f97316;--accent-2-rgb: 249 115 22;--glow: rgb(var(--accent-rgb) / .18);--gold: #facc15;--gold-rgb: 250 204 21;--good: #4ade80;--bad: #f43f5e;--bad-rgb: 244 63 94;--hand-l: #7dd3fc;--hand-l-rgb: 125 211 252;--hand-r: #fdba74;--hand-r-rgb: 253 186 116}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-display);-webkit-font-smoothing:antialiased}#root,.app{min-height:100vh;display:flex;flex-direction:column}button{font:inherit;color:inherit;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.6rem 1.4rem;cursor:pointer;transition:border-color .15s,background .15s}button:hover{border-color:var(--accent);background:var(--surface-2)}.cap{display:inline-flex;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);font-family:var(--font-mono);font-size:1.05rem;transition:background .08s,border-color .08s,color .08s}.home{position:relative;width:100%;height:100vh;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2.2rem 1.2rem 1.2rem;overflow:hidden;text-align:center}.logo{font-size:clamp(4rem,12vw,6.4rem);font-weight:700;letter-spacing:.35em;line-height:.9;margin:0 0 0 .35em;background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.brand{color:var(--dim);font-size:.72rem;letter-spacing:.22em;text-decoration:none}.brand:hover{color:var(--accent)}.tagline{color:var(--dim);font-size:.95rem;letter-spacing:.06em;margin:0}.settings-button{position:absolute;top:1.1rem;right:1.1rem;padding:.45rem .8rem;border-radius:8px;color:var(--dim)}.menu{width:min(100%,520px);display:grid;gap:.7rem;margin-top:.55rem}.menu-card{position:relative;min-height:72px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.9rem;padding:.85rem 1rem;overflow:hidden;text-align:left;border-radius:8px}.menu-card span,.menu-card em{position:relative;z-index:1}.menu-card b{display:block;font-size:1.08rem}.menu-card small{display:block;margin-top:.12rem;color:var(--dim);font-size:.78rem}.menu-card em{color:var(--accent);font-family:var(--font-mono);font-size:.86rem;font-style:normal;white-space:nowrap}.menu-card.quick{border-color:var(--gold);box-shadow:0 0 24px var(--gold-glow)}.menu-card.zen{border-color:var(--accent);box-shadow:0 0 24px var(--glow)}.menu-card.levels{border-color:var(--accent-2);box-shadow:0 0 24px var(--accent-2-soft)}.menu-card.levels em{color:var(--accent-2)}.zen-meter{position:absolute;inset:auto 0 0;height:3px;overflow:hidden;background:var(--surface-line)}.zen-meter span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform-origin:left;transition:transform .18s ease}.menu-row{display:flex;gap:.7rem}.menu-row button{flex:1;min-height:44px;border-radius:8px;color:var(--dim)}.theme-picker{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.45rem}.theme-picker.compact{grid-template-columns:repeat(auto-fit,minmax(84px,1fr))}.theme-choice{min-width:0;display:grid;justify-items:center;gap:.32rem;padding:.5rem .35rem;border-radius:8px;color:var(--dim);font-size:.68rem;line-height:1}.theme-choice[data-active]{color:var(--text);border-color:var(--accent);background:var(--surface-2);box-shadow:0 0 18px var(--glow)}.theme-swatches{display:grid;grid-template-columns:repeat(3,1fr);width:42px;height:14px;overflow:hidden;border:1px solid var(--border);border-radius:999px}.theme-swatches i{min-width:0}.level-select{width:100%;display:grid;gap:.45rem}.level-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:.4rem;min-height:var(--level-row-height)}.level-lb{display:inline-flex;align-items:center;justify-content:center;width:64px;padding:0;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;border-radius:8px;background:var(--surface);border:1px solid var(--border);color:var(--text);transition:border-color .15s,background .15s,transform .1s}.level-lb:hover{border-color:var(--accent-2);background:var(--surface-2);transform:scale(1.05)}.level-pager{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding-top:.6rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--dim)}.level-pager button{padding:.4rem .8rem;font-size:.82rem}.level-pager button:disabled{opacity:.35;cursor:default;border-color:var(--border);background:var(--surface)}.level-head{display:flex;align-items:baseline;justify-content:space-between;padding:0 .2rem;color:var(--dim);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}.level-head b{color:var(--accent);font-weight:600}.level-card{position:relative;width:100%;min-height:64px;display:grid;grid-template-columns:48px minmax(0,1fr) auto;grid-template-areas:"rank main stats";align-items:center;gap:.25rem .8rem;padding:.65rem .9rem .65rem .6rem;overflow:hidden;text-align:left;border-radius:8px;background:linear-gradient(90deg,var(--accent-soft),rgb(var(--accent-2-rgb) / .08) 54%,var(--surface)),var(--surface)}.level-card:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:linear-gradient(var(--accent),var(--accent-2))}.level-rank{grid-area:rank;display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgb(var(--gold-rgb) / .45);color:var(--gold);font-family:var(--font-mono);font-size:.82rem;font-weight:700;box-shadow:0 0 18px rgb(var(--gold-rgb) / .13)}.level-rank.grade-badge{width:38px;height:38px;padding:0;border-radius:50%;font-size:.78rem}.level-new{border-color:var(--border);color:var(--dim);box-shadow:none;background:var(--surface-2)}.level-main{grid-area:main;min-width:0}.level-main b{overflow:hidden;font-size:1.05rem;text-overflow:ellipsis;white-space:nowrap}.level-stats span{color:var(--dim);font-size:.78rem}.level-stats{grid-area:stats;display:grid;gap:.08rem;justify-items:end;font-family:var(--font-mono);line-height:1.15;white-space:nowrap}.level-stats b{color:var(--text);font-size:.9rem}.level-screen{--level-row-height: 74px;width:min(720px,100%);margin:auto;display:grid;gap:1rem;padding:2rem 1.4rem}.level-screen-head{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:1rem}.level-screen-head h2{margin:0;color:var(--text);font-size:clamp(1.8rem,5vw,2.6rem);line-height:1;text-align:right;text-transform:uppercase}.level-browser{display:grid;grid-template-rows:repeat(5,var(--level-row-height));gap:.55rem}.level-card.beatmap{min-height:0;height:100%}.info-screen{width:min(560px,100%);margin:auto;display:flex;flex-direction:column;gap:1.2rem;padding:2rem 1.4rem}.info-screen header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem}.info-screen h2{margin:0;text-align:center;font-size:1.6rem;letter-spacing:.08em}.back{padding:.45rem .8rem;border-radius:8px;color:var(--dim)}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin:0}.stats-grid div,.info-list p{border:1px solid var(--border);border-radius:8px;background:var(--surface);padding:.85rem}.stats-grid dt{color:var(--dim);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}.stats-grid dd{margin:.25rem 0 0;font-family:var(--font-mono)}.info-list{display:grid;gap:.5rem}.info-list h3{margin:0;color:var(--dim);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}.info-list p{display:flex;justify-content:space-between;gap:1rem;margin:0}.quick-rules{display:grid;gap:.7rem;margin:0;padding-left:1.1rem;color:var(--dim)}.quick-rules li::marker{color:var(--accent)}.custom-map-panel{display:grid;gap:.7rem}.custom-map-panel label{color:var(--dim);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}.custom-map-panel textarea{min-height:150px;resize:vertical;padding:.85rem;border:1px solid var(--border);border-radius:8px;outline:none;background:var(--surface);color:var(--text);font-family:var(--font-mono);font-size:.95rem;line-height:1.45}.custom-map-panel textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--glow)}.custom-map-panel textarea[aria-invalid=true]{border-color:rgb(var(--bad-rgb) / .65)}.custom-map-meta{display:flex;min-height:1.1rem;align-items:center;justify-content:space-between;gap:.8rem;color:var(--dim);font-size:.76rem}.custom-map-meta b{color:var(--bad);font-weight:600;text-align:right}.custom-map-panel button{min-height:46px}.settings-list{display:grid;gap:.7rem}.setting-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(140px,220px);align-items:center;gap:1rem;padding:.85rem;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.setting-row b,.setting-row small{display:block}.setting-row small{margin-top:.12rem;color:var(--dim);font-family:var(--font-mono);font-size:.78rem}.setting-row input[type=range]{width:100%;accent-color:var(--accent)}.setting-row input[type=checkbox]{justify-self:end;width:1.2rem;height:1.2rem;accent-color:var(--accent)}.setting-row-wide{grid-template-columns:1fr;align-items:start}.keybind-editor{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.5rem}.keybind-editor input{width:100%;padding:.65rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font:600 1rem var(--font-mono);letter-spacing:.08em;outline:none}.keybind-editor input:focus{border-color:var(--accent);background:var(--surface-2)}.keybind-editor input[aria-invalid=true]{border-color:var(--bad)}.keybind-editor button,.keybind-presets button{padding:.45rem .65rem;border-radius:8px;font-size:.78rem}.keybind-presets{display:flex;flex-wrap:wrap;gap:.4rem}.setting-error{color:var(--bad)!important}.song-maps{margin-top:1.6rem}.song-maps h3{display:flex;align-items:center;gap:.5rem;margin:0 0 .3rem;font-size:1rem}.exp-tag{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bg);background:var(--accent);border-radius:5px;padding:.12rem .4rem}.song-blurb{color:var(--dim);font-size:.85rem;margin:0 0 .7rem}.song-list{display:flex;flex-wrap:wrap;gap:.6rem}.song-card{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.7rem 1rem;text-align:left}.song-card small{color:var(--dim);font-size:.75rem}.soundfont-picker{display:flex;flex-wrap:wrap;gap:.4rem}.soundfont-choice{padding:.45rem .8rem;border-radius:8px;font-size:.82rem}.soundfont-choice[data-active]{border-color:var(--accent);color:var(--accent);box-shadow:0 0 14px var(--glow)}@media(max-height:640px){.home{gap:.45rem;padding-block:1.2rem .8rem}.logo{font-size:clamp(3.2rem,10vw,4.8rem)}.menu{gap:.45rem;margin-top:.25rem}.menu-card{min-height:58px;padding-block:.62rem}.level-card{min-height:54px;padding-block:.48rem}.level-screen{--level-row-height: 68px;padding-block:1.2rem .8rem}}@media(max-width:520px){.setting-row{grid-template-columns:1fr}.setting-row input[type=checkbox]{justify-self:start}.level-row{grid-template-columns:minmax(0,1fr) 56px}.level-lb{width:56px;font-size:.66rem}.level-stats span{font-size:.7rem}}.site-footer{display:flex;align-items:center;gap:.45rem;color:var(--dim);font-size:.78rem}.site-footer .flink{padding:0;color:inherit;border:0;background:none;text-decoration:none}.site-footer .flink:hover{color:var(--accent)}.play{position:relative;flex:1;display:flex;flex-direction:column;padding:1.5rem clamp(1rem,4vw,3rem);gap:1.5rem;overflow:hidden;background:radial-gradient(ellipse 50% 22% at 50% 0%,var(--glow),transparent 70%)}.ghost-clock{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;display:grid;place-items:center;color:rgb(var(--text-rgb) / .055);font-family:var(--font-mono);font-size:clamp(11rem,38vw,25rem);font-weight:700;font-variant-numeric:tabular-nums;line-height:.8;pointer-events:none;-webkit-user-select:none;user-select:none}.hud{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;min-height:4.1rem}.score-block{text-align:center}.score{font-family:var(--font-mono);font-size:2.8rem;font-weight:700;font-variant-numeric:tabular-nums;text-shadow:0 0 30px var(--glow)}.score.pop{animation:score-pop .18s ease-out}@keyframes score-pop{35%{transform:scale(1.06)}}.zen-hud{width:min(260px,44vw);display:grid;gap:.22rem;margin:.4rem auto 0}.zen-hud span,.zen-hud small{color:var(--dim);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase}.zen-hud span{color:var(--accent)}.zen-hud i{height:7px;overflow:hidden;border:1px solid var(--border);border-radius:999px;background:var(--surface-2)}.zen-hud b{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--gold));transform-origin:left;transition:transform .12s ease-out}.nerd-stats{position:absolute;top:1.1rem;right:clamp(1rem,4vw,3rem);z-index:3;display:grid;width:10.4rem;padding:.45rem .55rem;border:1px solid rgb(var(--surface-on) / .055);border-radius:8px;background:rgb(var(--bg-rgb) / .34);color:rgb(var(--text-rgb) / .36);font-family:var(--font-mono);font-size:.62rem;font-variant-numeric:tabular-nums;line-height:1.22;pointer-events:none}.nerd-stats span{display:flex;justify-content:space-between;gap:.55rem}.nerd-stats b{color:inherit;font-weight:500;letter-spacing:.06em;text-transform:uppercase}.nerd-stats i{color:rgb(var(--text-rgb) / .5);font-style:normal}.nerd-stats .warn b,.nerd-stats .warn i{color:rgb(var(--bad-rgb) / .72)}.board-zone{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:10px;padding-bottom:.6rem;min-height:0}.board{position:relative;overflow:hidden;border-bottom:2px solid var(--accent);background:repeating-linear-gradient(to right,transparent 0,transparent 57px,var(--surface) 57px,var(--surface) 58px);mask-image:linear-gradient(to bottom,transparent 0,#000 10%);-webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 10%)}.board[data-shaken]{animation:shake .25s}.note{position:absolute;bottom:0;display:flex;align-items:flex-end;justify-content:center;padding-bottom:.4rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);transition:transform .12s ease,height .12s ease;will-change:transform}.note-label{font-family:var(--font-mono);font-size:1.05rem;color:rgb(var(--text-rgb) / .55)}.note.hand-l{background:rgb(var(--hand-l-rgb) / .1);border-color:rgb(var(--hand-l-rgb) / .28)}.note.hand-r{background:rgb(var(--hand-r-rgb) / .1);border-color:rgb(var(--hand-r-rgb) / .28)}.note.hand-l .note-label{color:var(--hand-l)}.note.hand-r .note-label{color:var(--hand-r)}.note.expected{border-color:var(--accent);box-shadow:0 0 22px var(--glow);background:var(--surface-2)}.note.expected .note-label{color:var(--text)}.note.holdnote{background:repeating-linear-gradient(-45deg,var(--surface-line) 0,var(--surface-line) 6px,transparent 6px,transparent 12px),rgb(var(--gold-rgb) / .08);border-color:rgb(var(--gold-rgb) / .4)}.note.holdnote .note-label{color:var(--gold)}.note.held{background:rgb(var(--gold-rgb) / .18);border-color:var(--gold);box-shadow:0 0 18px rgb(var(--gold-rgb) / .25)}.note.held .note-label{color:var(--gold)}.float{position:absolute;bottom:3rem;transform:translate(-50%);font-family:var(--font-mono);font-weight:700;font-size:1.2rem;color:var(--gold);pointer-events:none;animation:float-up .7s ease-out forwards}@keyframes float-up{0%{opacity:1;translate:0 0}to{opacity:0;translate:0 -46px}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(5px)}75%{transform:translate(-3px)}}.hitrow{display:flex;justify-content:space-between}.hitrow .cap{font-size:1.2rem;border-radius:10px;transition:background .06s,border-color .06s,color .06s,box-shadow .06s}.hitrow .cap.hand-l{color:var(--hand-l)}.hitrow .cap.hand-r{color:var(--hand-r)}.hitrow .cap.pressed{background:var(--accent);border-color:var(--accent);color:var(--on-bright);box-shadow:0 0 18px var(--glow)}.hitrow .cap.holding{background:rgb(var(--gold-rgb) / .25);border-color:var(--gold);color:var(--gold);box-shadow:0 0 18px rgb(var(--gold-rgb) / .3)}.hitrow .cap.glow-hint{border-color:var(--accent);color:var(--accent);animation:pulse 1.2s infinite}.play-footer{min-height:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.45rem}.shortcut-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:.45rem .8rem;color:var(--dim);font-size:.72rem}.shortcut-legend span{white-space:nowrap}.shortcut-legend kbd{min-width:1.6rem;display:inline-grid;place-items:center;margin-right:.22rem;padding:.12rem .32rem;border:1px solid var(--border);border-radius:5px;background:var(--surface);color:var(--text);font-family:var(--font-mono);font-size:.68rem;font-weight:700;box-shadow:inset 0 -1px #ffffff14}.screen-warning{position:fixed;left:50%;bottom:.8rem;z-index:45;transform:translate(-50%);width:min(92vw,360px);padding:.55rem .8rem;border:1px solid rgb(var(--gold-rgb) / .55);border-radius:8px;background:var(--panel-bg);color:var(--gold);box-shadow:0 0 22px var(--gold-glow);font-size:.78rem;letter-spacing:.08em;text-align:center;text-transform:lowercase;pointer-events:none}.hint{color:var(--dim);font-size:.85rem;letter-spacing:.05em;margin:0}.pace{font-family:var(--font-mono);font-size:.95rem;font-variant-numeric:tabular-nums}.pace.ahead{color:var(--good)}.pace.behind{color:var(--bad)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:var(--overlay-bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto}.pause-menu{position:relative;z-index:1;width:min(320px,calc(100vw - 2rem));display:grid;gap:.85rem;padding:1.2rem;border:1px solid rgb(var(--accent-rgb) / .24);border-radius:8px;background:linear-gradient(135deg,rgb(var(--accent-rgb) / .12),rgb(var(--accent-2-rgb) / .08)),var(--panel-bg);box-shadow:0 0 36px var(--glow);text-align:center}.pause-menu.resuming{width:auto;min-width:180px;animation:resume-pop .35s ease both}.overlay h2{font-size:2rem;margin:0}.overlay p{color:var(--dim);margin:0}.pause-actions{display:grid;gap:.55rem}.pause-actions button{width:100%;min-height:44px;border-radius:8px;text-transform:lowercase}.countdown{font-family:var(--font-mono);font-size:3.4rem;margin:0}@keyframes resume-pop{0%{opacity:0;transform:scale(.92)}55%{opacity:1;transform:scale(1.03)}to{opacity:0;transform:scale(1)}}.results{margin:auto;display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1.5rem;text-align:center;max-width:580px}.newpb{color:var(--gold);letter-spacing:.3em;font-size:.8rem;animation:pulse 1.2s infinite}@keyframes pulse{50%{opacity:.5}}.grade{font-size:4.5rem;line-height:1}.grade-badge{--grade-bg: linear-gradient(145deg, rgb(80 84 96 / .2), rgb(37 40 49 / .74));--grade-border: rgb(178 185 200 / .34);--grade-ring: rgb(178 185 200 / .16);--grade-text: var(--text-soft);--grade-glow: rgb(178 185 200 / .16);position:relative;isolation:isolate;display:inline-grid;min-width:2.2em;min-height:2.2em;place-items:center;padding:.25em .52em;overflow:hidden;border:1px solid var(--grade-border);border-radius:.52em;background:var(--grade-bg);box-shadow:inset 0 1px #ffffff1f,0 0 0 1px var(--grade-ring),0 0 18px var(--grade-glow);color:var(--grade-text);font-family:var(--font-mono);font-weight:800;letter-spacing:.02em;text-shadow:0 1px 10px var(--grade-glow)}.grade-badge:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background:linear-gradient(120deg,transparent 18%,rgb(255 255 255 / .22) 45%,transparent 72%);opacity:0;transform:translate(-140%)}.grade-badge.hero{min-width:1.8em;min-height:1.45em;padding:.08em .28em .12em;border-width:2px;border-radius:.26em;font-size:clamp(4.2rem,16vw,6.4rem);line-height:.95;box-shadow:inset 0 1px #fff3,0 0 0 2px var(--grade-ring),0 0 42px var(--grade-glow)}.grade-badge.inline{min-width:2.65em;min-height:1.75em;padding:.12em .42em;border-radius:.45em;font-size:.86rem}.grade-badge.level{min-width:0;min-height:0;padding:0;border-radius:50%;font-size:.78rem}.grade-badge[data-grade=D]{--grade-bg: linear-gradient(145deg, rgb(76 78 88 / .2), rgb(32 34 42 / .86));--grade-border: rgb(150 154 168 / .28);--grade-ring: rgb(150 154 168 / .1);--grade-text: rgb(184 188 200);--grade-glow: rgb(150 154 168 / .09)}.grade-badge[data-grade=C],.grade-badge[data-grade="C+"],.grade-badge[data-grade=C-]{--grade-bg: linear-gradient(145deg, rgb(31 124 115 / .2), rgb(27 53 59 / .88));--grade-border: rgb(74 203 188 / .36);--grade-ring: rgb(74 203 188 / .13);--grade-text: rgb(159 235 224);--grade-glow: rgb(74 203 188 / .13)}.grade-badge[data-grade=B],.grade-badge[data-grade="B+"],.grade-badge[data-grade=B-]{--grade-bg: linear-gradient(145deg, rgb(60 113 205 / .25), rgb(30 42 78 / .88));--grade-border: rgb(121 176 255 / .42);--grade-ring: rgb(121 176 255 / .16);--grade-text: rgb(184 213 255);--grade-glow: rgb(92 147 255 / .18)}.grade-badge[data-grade=A],.grade-badge[data-grade="A+"],.grade-badge[data-grade=A-]{--grade-bg: linear-gradient(145deg, rgb(var(--accent-rgb) / .3), rgb(44 34 87 / .9));--grade-border: rgb(var(--accent-rgb) / .56);--grade-ring: rgb(var(--accent-2-rgb) / .18);--grade-text: rgb(216 244 255);--grade-glow: rgb(var(--accent-rgb) / .26)}.grade-badge[data-grade=S],.grade-badge[data-grade="S+"],.grade-badge[data-grade=S-]{--grade-bg: radial-gradient(circle at 28% 16%, rgb(255 255 255 / .24), transparent 24%), linear-gradient(145deg, rgb(var(--gold-rgb) / .34), rgb(106 58 21 / .9) 46%, rgb(72 38 90 / .88));--grade-border: rgb(var(--gold-rgb) / .72);--grade-ring: rgb(var(--gold-rgb) / .24);--grade-text: rgb(255 238 174);--grade-glow: rgb(var(--gold-rgb) / .36)}.grade-badge[data-grade=S]:after,.grade-badge[data-grade="S+"]:after,.grade-badge[data-grade=S-]:after{animation:grade-sheen 3.8s ease-in-out infinite;opacity:.8}.grade-badge[data-grade=SS]{--grade-bg: radial-gradient(circle at 30% 18%, rgb(255 255 255 / .36), transparent 21%), conic-gradient(from 210deg, #22d3ee, #f472b6, #facc15, #67e8f9, #22d3ee);--grade-border: rgb(255 255 255 / .86);--grade-ring: rgb(255 255 255 / .3);--grade-text: #ffffff;--grade-glow: rgb(244 114 182 / .42);border-width:2px;text-shadow:0 1px 8px rgb(0 0 0 / .42),0 0 18px rgb(255 255 255 / .38);animation:grade-ss-pulse 2.4s ease-in-out infinite}.grade-badge[data-grade=SS]:before{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;z-index:-1;border:1px solid rgb(255 255 255 / .72);border-radius:inherit;box-shadow:inset 0 0 18px #ffffff38}.grade-badge[data-grade=SS]:after{animation:grade-sheen 2.2s ease-in-out infinite;opacity:.95}.clear-badge{font-weight:800;font-family:var(--font-mono);color:var(--accent);text-shadow:0 0 40px var(--glow)}@keyframes grade-sheen{0%,18%{transform:translate(-140%)}52%,to{transform:translate(140%)}}@keyframes grade-ss-pulse{50%{filter:saturate(1.18) brightness(1.08);box-shadow:inset 0 1px #ffffff47,0 0 0 2px #ffffff57,0 0 56px #f472b680}}@media(prefers-reduced-motion:reduce){.grade-badge,.grade-badge:after{animation:none!important}}.final-score{font-family:var(--font-mono);font-size:3rem;font-variant-numeric:tabular-nums}.pb-delta{color:var(--dim);margin:0}.stats{display:flex;gap:1.6rem;flex-wrap:wrap;justify-content:center;margin:0}.stats div{display:flex;flex-direction:column;gap:.2rem}.stats dt{color:var(--dim);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase}.stats dd{margin:0;font-family:var(--font-mono);font-size:1.3rem}.actions{display:flex;gap:.8rem}@media(prefers-reduced-motion:reduce){.active-slot[data-shaken],.newpb,.score.pop,.card{animation:none}.card{transition:none}.burst,.float{animation:none;opacity:0}}.lockflash{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,var(--bad-soft),rgb(var(--bad-rgb) / .05));animation:lock-fade 1s ease-out forwards}.lockflash span{font-family:var(--font-mono);font-weight:700;font-size:2rem;letter-spacing:.4em;color:var(--bad);text-shadow:0 0 30px rgb(var(--bad-rgb) / .5);animation:lock-stamp 1s ease-out forwards}@keyframes lock-fade{0%,75%{opacity:1}to{opacity:0}}@keyframes lock-stamp{0%{transform:scale(1.4);opacity:0}12%{transform:scale(1);opacity:1}75%{opacity:1}to{opacity:0}}.errorflash{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;box-shadow:inset 0 0 90px 8px rgb(var(--bad-rgb) / .16);animation:error-pulse .32s ease-out forwards}@keyframes error-pulse{0%{opacity:.85}to{opacity:0}}.board.sparkle:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 60% 30% at 50% 100%,var(--glow),transparent 70%);animation:sparkle-flash .5s ease-out}@keyframes sparkle-flash{0%{opacity:.9}to{opacity:0}}.modes{display:flex;gap:.8rem}.start.quick{border-color:var(--gold);box-shadow:0 0 24px var(--gold-glow)}.start .best{color:var(--dim);font-weight:400;font-size:.85em}.modehint{color:var(--dim);font-size:.78rem;margin:0;letter-spacing:.04em}.totals{display:flex;gap:1.4rem;flex-wrap:wrap;justify-content:center;color:var(--dim);font-size:.85rem}.totals b{color:var(--text);font-family:var(--font-mono)}.result-tag{color:var(--gold);letter-spacing:.3em;font-size:.8rem}.gestures{width:min(420px,84vw);display:flex;flex-direction:column;gap:.35rem}.gestures h3{margin:0 0 .2rem;color:var(--dim);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;text-align:center}.grow{position:relative;display:grid;grid-template-columns:5.5rem 1fr 6rem;align-items:center;gap:.5rem;font-size:.82rem;border-radius:6px}.grow .gname{display:inline-flex;align-items:center;justify-content:flex-end;gap:.25rem;color:var(--dim);text-align:right}.ginfo{display:inline-grid;width:1rem;height:1rem;place-items:center;border:1px solid rgb(var(--accent-rgb) / .25);border-radius:999px;color:var(--dim);font-size:.68rem;line-height:1}.grow .gbar{height:6px;border-radius:3px;background:var(--surface-2);overflow:hidden}.grow .gbar i{display:block;height:100%;background:var(--accent);transform-origin:left}.grow .gval{font-family:var(--font-mono);color:var(--dim);font-size:.75rem}.grow.best .gname,.grow.best .gval{color:var(--good)}.grow.best .gbar i{background:var(--good)}.grow.worst .gname,.grow.worst .gval{color:var(--bad)}.gesture-pop{position:absolute;z-index:10;right:5.7rem;bottom:calc(100% + .5rem);width:min(260px,72vw);display:grid;gap:.28rem;padding:.65rem .75rem;border:1px solid rgb(var(--accent-rgb) / .28);border-radius:8px;background:linear-gradient(135deg,rgb(var(--accent-rgb) / .12),rgb(var(--accent-2-rgb) / .08)),var(--panel-bg);box-shadow:0 14px 36px #00000052,0 0 24px var(--glow);color:var(--text-soft);text-align:left;opacity:0;pointer-events:none;transform:translateY(4px) scale(.98);transition:opacity .14s ease,transform .14s ease;visibility:hidden}.gesture-pop:after{content:"";position:absolute;right:1.5rem;bottom:-6px;width:10px;height:10px;border-right:1px solid rgb(var(--accent-rgb) / .28);border-bottom:1px solid rgb(var(--accent-rgb) / .28);background:var(--panel-bg);transform:rotate(45deg)}.gesture-pop b{color:var(--text);font-size:.78rem}.gesture-pop span{color:var(--dim);font-size:.75rem;line-height:1.25}.gesture-pop code{justify-self:start;padding:.16rem .38rem;border-radius:5px;background:rgb(var(--accent-rgb) / .1);color:var(--accent);font-family:var(--font-mono);font-size:.8rem}.grow:hover .gesture-pop,.grow:focus-visible .gesture-pop,.grow:focus-within .gesture-pop{opacity:1;transform:translateY(0) scale(1);visibility:visible}.site-footer{display:flex;align-items:center;gap:.6rem;color:var(--dim);font-size:.78rem}.flink{background:none;border:none;padding:0;color:var(--dim);font-size:.78rem;text-decoration:none;cursor:pointer;transition:color .15s}.flink:hover{color:var(--text);background:none;border:none}.legal{margin:0 auto;max-width:620px;padding:3.5rem 1.5rem 4rem;line-height:1.65}.legal h1{font-size:1.9rem;margin:0 0 .2rem}.legal .updated{color:var(--dim);font-size:.85rem;margin:0 0 1.6rem}.legal h2{font-size:1.05rem;margin:1.6rem 0 .4rem;color:var(--accent)}.legal p,.legal li{color:var(--text-soft);font-size:.95rem;margin:.4rem 0}.legal ul{padding-left:1.2rem;margin:.4rem 0}.legal a{color:var(--accent);text-decoration:none}.legal a:hover{text-decoration:underline}.legal button{margin-top:2rem}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}::selection{background:var(--selection)}.start{letter-spacing:.08em;font-weight:600;padding:.7rem 1.6rem}.home{gap:1.4rem}@media(prefers-reduced-motion:reduce){.lockflash,.lockflash span,.errorflash{animation:none}.lockflash,.errorflash{opacity:0}}.play[data-mashlock] .hitrow .cap,.play[data-mashlock] .note-cell{filter:grayscale(.85) brightness(.55);transition:filter .12s ease}.play[data-mashlock] .board-zone{filter:saturate(.4)}.mashflash{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;background:radial-gradient(ellipse at center,rgb(var(--bad-rgb) / .22),rgb(var(--bad-rgb) / .06) 60%,transparent);animation:mash-fade .5s ease-out forwards}.mashflash span{font-family:var(--font-mono);font-weight:700;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:.32em;color:var(--bad);text-shadow:0 0 30px rgb(var(--bad-rgb) / .7);animation:mash-stamp .5s ease-out forwards}.mashflash small{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:rgb(var(--bad-rgb) / .85)}.zen-celebration{position:fixed;top:0;right:0;bottom:0;left:0;z-index:42;display:grid;place-items:center;pointer-events:none;background:radial-gradient(ellipse at center,rgb(var(--accent-rgb) / .18),transparent 62%);animation:zen-celebration-fade 1.7s ease-out forwards}.zen-celebration.five{animation-duration:2.2s;background:radial-gradient(ellipse at center,rgb(var(--accent-2-rgb) / .22),rgb(var(--accent-rgb) / .08) 58%,transparent)}.zen-celebration.ten{animation-duration:2.6s;background:radial-gradient(ellipse at center,rgb(var(--gold-rgb) / .24),rgb(var(--accent-2-rgb) / .12) 56%,transparent)}.zen-celebration.fifty,.zen-celebration.hundred{animation-duration:3.2s;background:radial-gradient(ellipse at center,rgb(var(--gold-rgb) / .28),rgb(var(--accent-2-rgb) / .14) 48%,transparent 70%),radial-gradient(circle at 50% 50%,rgb(var(--accent-rgb) / .18),transparent 42%)}.zen-celebration.hundred{animation-duration:3.6s}.zen-celebration-card{position:relative;z-index:1;display:grid;justify-items:center;gap:.28rem;padding:1rem 1.3rem;border:1px solid rgb(var(--gold-rgb) / .5);border-radius:8px;background:linear-gradient(135deg,rgb(var(--accent-rgb) / .18),rgb(var(--accent-2-rgb) / .16)),var(--panel-bg);box-shadow:0 0 46px var(--glow),0 0 26px var(--gold-glow);animation:zen-card-pop .42s cubic-bezier(.2,1.4,.25,1) both}.zen-celebration-card small{color:var(--gold);font-size:.75rem;letter-spacing:.34em;text-transform:uppercase}.zen-celebration-card b{color:var(--text);font-family:var(--font-mono);font-size:clamp(2.4rem,8vw,4.8rem);line-height:.95;text-shadow:0 0 34px var(--glow);text-transform:uppercase}.zen-celebration-card span{color:var(--dim);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase}.zen-burst{position:absolute;width:min(76vmin,560px);aspect-ratio:1;animation:zen-burst-spin 1.5s ease-out forwards}.zen-burst i{position:absolute;left:50%;top:50%;width:4px;height:46%;transform-origin:50% 0}.zen-burst i:before{content:"";display:block;width:100%;height:38%;border-radius:999px;background:linear-gradient(to bottom,var(--gold),transparent)}@keyframes zen-celebration-fade{0%{opacity:0}12%,78%{opacity:1}to{opacity:0}}@keyframes zen-card-pop{0%{opacity:0;transform:scale(.7) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes zen-burst-spin{0%{opacity:0;transform:scale(.45) rotate(-18deg)}18%{opacity:1}to{opacity:0;transform:scale(1.18) rotate(18deg)}}@keyframes mash-fade{0%,85%{opacity:1}to{opacity:0}}@keyframes mash-stamp{0%{transform:scale(1.4);opacity:0}20%{transform:scale(1);opacity:1}to{transform:scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){.mashflash,.mashflash span,.zen-celebration,.zen-celebration-card,.zen-burst{animation:none}.play[data-mashlock] .hitrow .cap,.play[data-mashlock] .note-cell,.play[data-mashlock] .board-zone{transition:none}}.name-gate{width:min(100%,460px);margin:auto;padding:2.4rem 1.2rem;display:grid;gap:1.4rem;text-align:center}.gate-score{display:grid;justify-items:center;gap:.25rem}.gate-score-value{font-family:var(--font-mono);font-size:clamp(3.4rem,9vw,4.8rem);font-weight:700;color:var(--accent);letter-spacing:.02em;line-height:1}.gate-score-label{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--dim)}.gate-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;padding:.85rem .6rem;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.gate-mini span{display:grid;gap:.15rem}.gate-mini b{font-size:1.15rem;color:var(--text)}.gate-mini small{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim)}.gate-msg h2{margin:0 0 .4rem;font-size:1.05rem;letter-spacing:.04em}.gate-msg p{margin:0;font-size:.78rem;color:var(--dim)}.gate-input input{width:100%;padding:.8rem 1rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;font-size:1rem;text-align:center;outline:none;transition:border-color .15s,background .15s}.gate-input input:focus{border-color:var(--accent);background:var(--surface-2)}.gate-input input[aria-invalid=true]{border-color:var(--bad)}.gate-input input:disabled{opacity:.6}.gate-error{margin-top:.4rem;font-size:.72rem;color:var(--bad)}.gate-actions{display:flex;gap:.6rem;justify-content:center}.gate-submit{flex:1;padding:.7rem 1rem;border-radius:10px;border:1px solid var(--accent);background:linear-gradient(90deg,rgb(var(--accent-rgb) / .18),rgb(var(--accent-2-rgb) / .18));color:var(--text);font-weight:600;letter-spacing:.04em}.gate-submit:disabled{opacity:.45;cursor:not-allowed;border-color:var(--border);background:var(--surface)}.gate-skip{padding:.7rem 1rem;color:var(--dim)}.leaderboard .lb-sub{margin:0 0 1rem;color:var(--dim);font-size:.82rem}.lb-rows{list-style:none;display:grid;gap:.4rem;padding:0;margin:0}.lb-row{border:1px solid var(--border);border-radius:10px;background:var(--surface);overflow:hidden;transition:border-color .12s}.lb-row.me{border-color:var(--accent);box-shadow:0 0 18px var(--glow)}.lb-row.expanded{border-color:var(--accent)}.lb-row-head{width:100%;display:grid;grid-template-columns:44px 1fr auto auto;align-items:center;gap:.8rem;padding:.65rem .9rem;border:none;border-radius:0;background:transparent;text-align:left}.lb-row-head:hover{background:var(--surface-2);border-color:transparent}.lb-rank{font-family:var(--font-mono);color:var(--dim);font-size:.9rem;text-align:center}.lb-name{font-size:1rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-grade{display:flex;justify-content:flex-end;min-width:3.3rem}.lb-grade .grade-badge{min-width:2.75em;min-height:1.7em;padding:.1em .34em;font-size:.78rem}.lb-score{display:grid;justify-items:end;min-width:6.5rem;font-family:var(--font-mono);font-variant-numeric:tabular-nums;line-height:1.15;color:var(--accent);white-space:nowrap}.lb-score b{font-size:1.05rem}.lb-score span{display:inline-block;width:8ch;text-align:right;color:var(--dim);font-size:.72rem}.lb-detail{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.6rem 1rem;padding:.55rem .9rem .85rem 3rem;margin:0;border-top:1px dashed var(--border);background:var(--detail-bg)}.lb-detail dt{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}.lb-detail dd{margin:0;font-family:var(--font-mono);font-size:.92rem;color:var(--text)}.lb-skel{height:44px;background:linear-gradient(90deg,var(--surface),var(--surface-2),var(--surface));background-size:200% 100%;animation:lbShimmer 1.6s linear infinite}@keyframes lbShimmer{to{background-position:-200% 0}}.lb-empty{padding:2.4rem 0;text-align:center;color:var(--dim)}.lb-pager{display:flex;align-items:center;justify-content:space-between;margin-top:.8rem;padding-top:.6rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--dim)}.lb-pager button{padding:.35rem .7rem;font-size:.78rem}.lb-pager button:disabled{opacity:.35;cursor:default;border-color:var(--border);background:var(--surface)}.volume-overlay{position:fixed;top:50%;right:1.4rem;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;pointer-events:none;z-index:50;animation:volume-pop 1.2s ease-out forwards}.volume-overlay-track{width:8px;height:180px;border-radius:6px;background:var(--surface-2);overflow:hidden;position:relative;border:1px solid var(--border)}.volume-overlay-track i{display:block;position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,var(--accent),var(--accent-2));transform-origin:bottom;transition:transform .08s ease-out}.volume-overlay-label{display:grid;justify-items:center;gap:.15rem;padding:.4rem .6rem;border-radius:8px;background:var(--panel-bg);border:1px solid var(--border);font-family:var(--font-mono)}.volume-overlay-label b{font-size:.95rem;color:var(--text)}.volume-overlay-label small{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dim)}@keyframes volume-pop{0%{opacity:0;transform:translateY(-50%) translate(10px)}10%,80%{opacity:1;transform:translateY(-50%) translate(0)}to{opacity:0;transform:translateY(-50%) translate(10px)}}@media(prefers-reduced-motion:reduce){.volume-overlay{animation:none}}
