.trademark-disclaimer{max-width:60rem;margin:2.5rem auto 0;padding-top:1rem;border-top:1px solid var(--line-soft);color:var(--text-faint);font-family:var(--font-body);font-size:.8rem;line-height:1.5;text-align:center}.mode-seo{display:flex;flex-direction:column;gap:1rem;max-width:54rem;margin:0 auto;padding:1.75rem;background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg)}.mode-seo-heading{font-size:1.5rem;letter-spacing:.02em;margin:0}.mode-seo-text{color:var(--text-muted);font-size:1rem;line-height:1.6;margin:0;max-width:46rem}.mode-seo-features{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(15rem,1fr));gap:.5rem 1.5rem}.mode-seo-features li{position:relative;padding-left:1.25rem;color:var(--text-muted);line-height:1.5}.mode-seo-features li:before{content:"▸";position:absolute;left:0;color:var(--accent-cyan)}.mode-seo-features strong{color:var(--text);font-weight:600}.mode-seo-how{display:flex;flex-direction:column;gap:.4rem}.mode-seo-subhead{font-size:1.1rem;letter-spacing:.03em;margin:0;color:var(--text)}.mode-seo-keys{display:inline-flex;gap:.3rem;margin-right:.15rem}.mode-seo-cta{justify-content:flex-start;margin-top:.25rem}.trophy-strip{--trophy-star-color: #ffd84d;--trophy-cup-color: #ffb13b;--trophy-crown-color: #ffcf33;--trophy-empty-color: var(--text-faint);display:flex;flex-direction:column;gap:.25rem;align-items:flex-end}.trophy-row{display:flex;gap:.2rem;line-height:1;align-items:center}.trophy-icon{display:inline-flex;align-items:center;justify-content:center;width:1em;color:var(--trophy-empty-color);filter:none;transition:filter .15s ease}.trophy-row-stars .trophy-icon-on{color:var(--trophy-star-color);text-shadow:0 0 .4rem rgba(255,216,77,.65)}.trophy-row-cups .trophy-icon-on{color:var(--trophy-cup-color);text-shadow:0 0 .45rem rgba(255,177,59,.7)}.trophy-row-cups .trophy-icon:not(.trophy-icon-on){opacity:.65}.trophy-row-crowns .trophy-icon-on{color:var(--trophy-crown-color);text-shadow:0 0 .45rem rgba(255,207,51,.7)}.trophy-row-max .trophy-icon-on{animation:trophy-row-max-pulse 2.4s ease-in-out infinite}@keyframes trophy-row-max-pulse{0%,to{filter:drop-shadow(0 0 .4rem currentColor)}50%{filter:drop-shadow(0 0 .85rem currentColor)}}.trophy-strip-sm{gap:.15rem}.trophy-strip-sm .trophy-icon{font-size:.95rem}.trophy-strip-md .trophy-icon{font-size:1.15rem}@media(prefers-reduced-motion:reduce){.trophy-row-max .trophy-icon-on{animation:none}}.home{display:flex;flex-direction:column;gap:2rem}.home-hero{text-align:center;padding:1.5rem 0 .5rem}.home-hero-kicker{font-family:var(--font-display);font-size:clamp(1.9rem,5vw,3rem);font-weight:800;letter-spacing:.06em;line-height:1;margin:0 0 1.5rem;text-shadow:0 0 1.4rem color-mix(in srgb,var(--accent-cyan) 30%,transparent)}.home-cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.home-maps-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.home-maps-header h2{font-size:1.2rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin:0}.variant-selector{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin:0 0 1rem;padding:.5rem .75rem;background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg)}.variant-tab{flex:0 0 auto;font-family:var(--font-display);font-size:.95rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.55rem 1.2rem;border-radius:var(--radius-md);border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease,transform .1s ease}.variant-tab:hover{color:var(--text);border-color:var(--line);transform:translateY(-1px)}.variant-tab-normal.is-active{color:var(--bg-elev);background:var(--variant-normal);border-color:var(--variant-normal);box-shadow:0 0 .75rem #16e0ff73}.variant-tab-hard.is-active{color:var(--bg-elev);background:var(--variant-hard);border-color:var(--variant-hard);box-shadow:0 0 .75rem #ff2bd673}.variant-tab-extreme.is-active{color:#fff;background:var(--variant-extreme);border-color:var(--variant-extreme);box-shadow:0 0 .85rem #ff3b3b8c}.variant-tab-insane.is-active{color:#fff;background:var(--variant-insane);border-color:var(--variant-insane);box-shadow:0 0 .9rem #8a3bff99}.variant-hint{flex:1 1 16rem;margin:0;font-size:.85rem;line-height:1.4;color:var(--text-muted)}.map-row-pad-count{font-size:.8rem;font-weight:500;color:var(--text-muted);letter-spacing:.04em}.map-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}.map-row{display:grid;grid-template-columns:4rem minmax(11rem,18rem) minmax(0,1fr) auto;align-items:stretch;gap:1rem;background:var(--bg-elev);border:1px solid var(--line-soft);border-left:4px solid var(--map-pad, var(--accent-cyan));border-radius:var(--radius-lg);padding:1rem 1.25rem;text-decoration:none;color:inherit;transition:transform .15s ease,border-color .15s,box-shadow .15s;min-height:7rem}.map-row:hover{transform:translate(.25rem);border-color:var(--map-pad, var(--accent-cyan));box-shadow:0 0 1.5rem #16e0ff2e}.map-row-index{display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:2.2rem;letter-spacing:.05em;color:var(--map-pad, var(--accent-cyan));text-shadow:0 0 .75rem var(--map-pad, var(--accent-cyan));min-width:3rem}.map-row-preview{position:relative;border-radius:var(--radius-md);background:linear-gradient(180deg,var(--map-bg, #0a0e27),var(--map-bg-accent, #1a1f4d));overflow:hidden;min-height:5rem}.map-row-preview:after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,transparent 0 1.875rem,rgba(255,255,255,.04) 1.875rem 1.9375rem);background-size:1.875rem 100%}.map-row-rail{position:absolute;left:0;right:0;height:.125rem;background:var(--map-pad, #16e0ff);box-shadow:0 0 .5rem var(--map-pad, #16e0ff)}.map-row-rail-top{top:25%}.map-row-rail-bottom{bottom:25%}.map-row-player{position:absolute;width:1rem;height:1rem;background:var(--map-player, #ff2bd6);bottom:calc(25% + .125rem);left:1rem;box-shadow:0 0 .75rem var(--map-player, #ff2bd6)}.map-row-body{display:flex;flex-direction:column;justify-content:center;gap:.25rem;min-width:0}.map-row-title{font-family:var(--font-display);font-size:1.4rem;font-weight:700;letter-spacing:.04em}.map-row-desc{color:var(--text-muted);font-size:.9rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.map-row-mapper{margin-top:4px;font-size:.78rem;letter-spacing:.02em}.map-row-meta{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:.25rem;font-family:var(--font-mono);font-size:.85rem;color:var(--text-muted);white-space:nowrap}.map-row-bpm{font-weight:600;color:var(--text)}.map-row-difficulty{display:flex;gap:.1875rem}@media(max-width:640px){.map-row{grid-template-columns:3rem 1fr;grid-template-rows:auto auto auto;grid-template-areas:"index body" "preview preview" "meta meta";min-height:auto}.map-row-index{grid-area:index;font-size:1.6rem;min-width:auto}.map-row-body{grid-area:body}.map-row-preview{grid-area:preview;min-height:3.5rem}.map-row-meta{grid-area:meta;flex-direction:row;justify-content:flex-start;gap:.75rem;align-items:center}}.pip{display:inline-block;width:.375rem;height:.375rem;border-radius:50%;background:var(--line)}.pip-on{background:var(--accent-magenta);box-shadow:0 0 .25rem var(--accent-magenta)}.play-page{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:100vw;flex:1;min-height:0;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.play-page .play-overlay,.play-page .pause-card,.play-page .loop-finale-card,.play-page .play-overlay-card{user-select:text;-webkit-user-select:text;-webkit-touch-callout:default}.play-title{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.6rem;margin:0 0 .25rem}.play-title-text{font:inherit;letter-spacing:inherit}.variant-badge{display:inline-flex;align-items:center;font-family:var(--font-display);font-weight:700;font-size:.7rem;letter-spacing:.18em;padding:.2rem .55rem;border-radius:999px;border:1px solid currentColor;position:relative;top:-.05rem}.variant-badge-normal{color:var(--accent-cyan);background:#16e0ff14;box-shadow:0 0 .3rem #16e0ff33}.variant-badge-hard{color:var(--variant-hard);background:#ff2bd61a;box-shadow:0 0 .4rem #ff2bd659}.variant-badge-extreme{color:var(--variant-extreme);background:#ff3b3b1f;box-shadow:0 0 .5rem #ff3b3b73}.variant-badge-insane{color:var(--variant-insane);background:#8a3bff24;box-shadow:0 0 .55rem #8a3bff80}.variant-badge-sm{font-size:.6rem;padding:.12rem .45rem;letter-spacing:.16em;top:0}.play-attribution{font-size:.78rem;margin-top:.1rem;margin-bottom:0}.play-attribution-overlay{font-size:.78rem;margin-top:-.5rem;margin-bottom:.75rem}.app-main:has(.play-page){max-width:none;padding-left:clamp(.5rem,1.5vw,1.25rem);padding-right:clamp(.5rem,1.5vw,1.25rem);padding-top:.5rem;padding-bottom:.5rem;display:flex;flex-direction:column;min-height:0}.app-shell:has(.play-page){height:100dvh;overflow:hidden}.play-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:.15rem}.play-header h2{margin:0;font-size:1.4rem}@media(max-width:720px),(orientation:landscape)and (max-height:500px){.app-shell:has(.play-page:not(.tutorial-page))>.top-nav{display:none}.app-main:has(.play-page:not(.tutorial-page)){padding-top:.25rem;padding-bottom:.25rem}.play-page:not(.tutorial-page){position:relative}.play-page:not(.tutorial-page)>.play-header{position:absolute;top:.4rem;right:.4rem;z-index:20;margin:0;gap:.35rem;padding:0;pointer-events:none;flex-wrap:nowrap}.play-page:not(.tutorial-page)>.play-header>div:first-child{display:none}.play-page:not(.tutorial-page)>.play-header .play-header-actions{pointer-events:auto;gap:.25rem}.play-page:not(.tutorial-page)>.play-header .play-header-actions .btn{padding:.4rem .6rem;font-size:.75rem;min-height:2.75rem;background:#0a0e27bf;backdrop-filter:blur(.375rem);-webkit-backdrop-filter:blur(.375rem)}.play-page:not(.tutorial-page)>.play-header .play-header-actions .kbd-hint{display:none}.play-page:not(.tutorial-page):has(.play-overlay)>.play-header{display:none}.play-page:not(.tutorial-page)>.play-layout{margin-top:0}.play-page:not(.tutorial-page)>.play-layout>.play-canvas-wrap{min-height:0}}.play-header-actions{display:flex;gap:.5rem}.play-layout{position:relative;width:100%;flex:1;min-height:0;display:flex;flex-direction:column}.play-canvas-wrap{position:relative;width:100%;flex:1;min-height:22rem;background:#000;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:0 0 3.75rem #ff2bd626}.play-leaderboard{position:absolute;top:.75rem;right:.75rem;width:16rem;max-height:calc(100% - 1.5rem);background:#0a0e27c7;border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:.75rem .875rem;backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem);overflow:hidden;display:flex;flex-direction:column;z-index:5;transition:transform .25s ease}.play-leaderboard.collapsed{transform:translate(calc(100% - 2rem))}.play-leaderboard-toggle{position:absolute;top:.5rem;left:-2.25rem;width:2.25rem;height:2.25rem;border-radius:var(--radius-sm) 0 0 var(--radius-sm);border:1px solid var(--line-soft);border-right:none;background:#0a0e27c7;color:var(--text-muted);cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem)}.play-leaderboard-toggle:hover{color:var(--accent-cyan);border-color:var(--accent-cyan)}.play-leaderboard-list{overflow-y:auto;flex:1}@media(max-width:720px),(orientation:landscape)and (max-height:500px){.play-leaderboard{display:none}}.play-leaderboard h3{margin:0 0 .75rem;font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.play-leaderboard ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.play-leaderboard li{display:grid;grid-template-columns:1.75rem 1fr auto auto auto;gap:.625rem;align-items:center;padding:.5rem .625rem;background:var(--bg);border-radius:var(--radius-sm);font-size:.85rem}.play-leaderboard li.lb-self{background:var(--bg-elev-2);border:1px solid var(--accent-magenta)}.lb-rank{font-family:var(--font-mono);font-weight:700;color:var(--text-muted);font-size:.75rem}.lb-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lb-crown{font-family:var(--font-mono);font-weight:700;font-size:.75rem;color:#c79bff;white-space:nowrap}.lb-score{font-family:var(--font-mono);color:var(--accent-cyan);font-weight:700}.lb-acc{font-family:var(--font-mono);color:var(--text-muted);font-size:.75rem}.play-canvas{width:100%;height:100%;display:block;cursor:crosshair;touch-action:none}.play-overlay{position:absolute;inset:0;background:#060819c7;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(.375rem);-webkit-backdrop-filter:blur(.375rem);z-index:10}.play-overlay-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2rem clamp(1.25rem,4vw,3rem);max-width:min(32.5rem,95vw);max-height:100%;overflow-y:auto;text-align:center;display:flex;flex-direction:column;gap:.875rem;box-shadow:var(--shadow-glow-magenta)}.play-overlay-card h3{margin:0;font-size:2rem;background:linear-gradient(90deg,var(--accent-magenta),var(--accent-cyan));-webkit-background-clip:text;background-clip:text;color:transparent}.play-overlay-card kbd{background:var(--bg-elev-2);border:1px solid var(--line);border-bottom-width:.1875rem;padding:.125rem .5rem;border-radius:.25rem;font-family:var(--font-mono);font-size:.85em}.btn-large{padding:.875rem 1.75rem;font-size:1.05rem;min-height:3.25rem}.result-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(6.5rem,100%),1fr));gap:.5rem;margin:.25rem 0}.result-stats>div{display:flex;flex-direction:column;gap:.2rem;padding:.4rem .5rem;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--line-soft);min-width:0}.result-stats strong{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700}.result-stats span{font-family:var(--font-mono);font-size:1.05rem;color:var(--text);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-actions{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.play-error{text-align:center;padding:5rem 1.25rem;display:flex;flex-direction:column;gap:1rem;align-items:center}.pause-card{display:flex;flex-direction:column;gap:1rem;align-items:center;padding:1.5rem 2rem;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-glow-cyan);text-align:center}.pause-card h3{margin:0;font-size:1.6rem;letter-spacing:.1em;text-transform:uppercase}.hotkey-list{margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--line-soft);width:100%;text-align:left;color:var(--text-muted);font-size:.85rem}.hotkey-list strong{display:block;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.4rem}.hotkey-list ul{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.25rem .75rem}.hotkey-list kbd{display:inline-block;min-width:1.25rem;text-align:center}.results-card{animation:results-pop .45s cubic-bezier(.16,1,.3,1)}.play-overlay-card.results-card{padding:1.25rem clamp(1rem,3vw,2rem);gap:.5rem}.play-overlay-card.results-card h3{font-size:1.5rem}.results-context{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.4rem .6rem}.results-context-title{font-family:var(--font-display);font-weight:600;font-size:1rem;letter-spacing:.03em;color:var(--text)}.results-context .variant-badge{top:0}.results-context-mode{font-family:var(--font-display);font-weight:700;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;padding:.22rem .6rem;border-radius:var(--radius-sm);color:var(--bg-deep);border:1px solid transparent}.results-context-mode-pulse{background:var(--accent-cyan);box-shadow:0 0 .5rem color-mix(in srgb,var(--accent-cyan) 50%,transparent)}.results-context-mode-circles{background:var(--accent-magenta);box-shadow:0 0 .5rem color-mix(in srgb,var(--accent-magenta) 50%,transparent)}.results-context-mode-piano{background:var(--accent-lime);box-shadow:0 0 .5rem color-mix(in srgb,var(--accent-lime) 50%,transparent)}.results-context-mode-guitar{background:var(--accent-amber);box-shadow:0 0 .5rem color-mix(in srgb,var(--accent-amber) 50%,transparent)}.results-context-mode-waves{background:var(--accent-violet);box-shadow:0 0 .5rem color-mix(in srgb,var(--accent-violet) 50%,transparent)}.results-context-mode-jump{background:var(--accent-green);box-shadow:0 0 .5rem color-mix(in srgb,var(--accent-green) 50%,transparent)}.results-title-cleared{animation:results-glow-cleared 1.2s ease-out}.results-title-failed{background:linear-gradient(90deg,var(--danger),var(--accent-amber))!important;-webkit-background-clip:text!important;background-clip:text!important;color:transparent!important}.results-title-survived{background:linear-gradient(90deg,var(--accent-amber),var(--accent-magenta))!important;-webkit-background-clip:text!important;background-clip:text!important;color:transparent!important;animation:results-glow-cleared 1.2s ease-out}.results-loops-cleared{margin:0;text-align:center;font-size:.9rem;color:var(--text)}.results-loops-cleared strong{color:var(--accent-amber);font-size:1.15em}@keyframes results-pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}@keyframes results-glow-cleared{0%{text-shadow:0 0 0 transparent}40%{text-shadow:0 0 2.5rem var(--accent-magenta),0 0 1.5rem var(--accent-cyan)}to{text-shadow:0 0 .5rem var(--accent-magenta)}}.pb-badge{align-self:center;padding:.35rem .75rem;border-radius:999px;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-magenta));color:var(--bg);font-weight:600;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase;animation:pb-badge-pop .6s cubic-bezier(.16,1,.3,1);box-shadow:0 0 1.25rem #00f0ff99}@keyframes pb-badge-pop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08);opacity:1}to{transform:scale(1)}}.kbd-hint{opacity:.65;font-size:.8em;margin-left:.25rem}.loop-finale-overlay{background:radial-gradient(circle at center,#140624d9,#02000ef2);backdrop-filter:blur(6px)}.loop-finale-card{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem 3rem;text-align:center;animation:loop-finale-pop .45s cubic-bezier(.16,1,.3,1)}.loop-finale-splash{border-radius:1.25rem;background:linear-gradient(180deg,#ffd84d14,#0000)}.loop-finale-stars{display:flex;gap:1.25rem;font-size:5.5rem;line-height:1;color:#ffd84d;text-shadow:0 0 1.5rem rgba(255,216,77,.7)}.loop-finale-stars span{display:inline-block;animation:loop-finale-star-pop .7s cubic-bezier(.16,1,.3,1) backwards}.loop-finale-stars span:nth-child(1){animation-delay:.05s}.loop-finale-stars span:nth-child(2){animation-delay:.25s}.loop-finale-stars span:nth-child(3){animation-delay:.45s}.loop-finale-title{margin:0;font-size:2.5rem;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-magenta));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.02em}.loop-finale-sub{margin:0;color:var(--text-muted);font-size:1.05rem}.loop-finale-mode{border-radius:1.25rem;background:linear-gradient(180deg,#ff3b5c1f,#ff2bd60d);border:1px solid rgba(255,59,92,.35);box-shadow:0 0 3rem #ff3b5c40}.loop-finale-eyebrow{margin:0;text-transform:uppercase;letter-spacing:.35em;font-size:.85rem;color:var(--text-muted)}.loop-finale-mode-title{margin:0;font-size:3rem;letter-spacing:.08em;background:linear-gradient(90deg,var(--accent-magenta),var(--accent-cyan));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 2rem rgba(255,43,214,.4)}.loop-finale-warning{margin:.25rem 0 0;font-size:1.4rem;font-weight:700;letter-spacing:.18em}.loop-finale-warning-pulse{display:inline-block;padding:.25rem .85rem;border-radius:.5rem;background:var(--danger);color:#fff;animation:loop-finale-warning-pulse .9s ease-in-out infinite}.loop-finale-hint{margin:.75rem 0 0;color:var(--text-muted);font-size:.95rem;max-width:32ch}@keyframes loop-finale-pop{0%{transform:scale(.85) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}@keyframes loop-finale-star-pop{0%{transform:scale(.3) rotate(-12deg);opacity:0}60%{transform:scale(1.25) rotate(4deg);opacity:1}to{transform:scale(1) rotate(0)}}@keyframes loop-finale-warning-pulse{0%,to{box-shadow:0 0 #ff3b5cb3}50%{box-shadow:0 0 0 .75rem #ff3b5c00}}@media(prefers-reduced-motion:reduce){.loop-finale-card,.loop-finale-stars span,.loop-finale-warning-pulse{animation:none}}.loop-speedup-banner{position:absolute;top:0;left:0;right:0;display:flex;justify-content:center;padding-top:clamp(.75rem,6%,2.5rem);pointer-events:none;z-index:11;animation:loop-speedup-in .4s cubic-bezier(.16,1,.3,1)}.loop-speedup-card{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.6rem 1.5rem;border-radius:.9rem;text-align:center;background:linear-gradient(180deg,#ff3b5c2e,#ff2bd60f);border:1px solid rgba(255,59,92,.4);box-shadow:0 0 2rem #ff3b5c4d}.loop-speedup-eyebrow{margin:0;text-transform:uppercase;letter-spacing:.35em;font-size:.7rem;color:var(--text-muted)}.loop-speedup-multiplier{margin:0;font-size:2.4rem;font-weight:800;line-height:1.05;letter-spacing:.02em;background:linear-gradient(90deg,var(--accent-magenta),var(--accent-cyan));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 1.5rem rgba(255,43,214,.35)}.loop-speedup-message{margin:0;font-size:.95rem;color:var(--text-muted)}@keyframes loop-speedup-in{0%{transform:translateY(-.75rem);opacity:0}to{transform:translateY(0);opacity:1}}@media(prefers-reduced-motion:reduce){.loop-speedup-banner{animation:none}}.play-loading-overlay{flex-direction:column;animation:play-loading-fade-in .25s ease .18s both}.play-loading-inner{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:min(20rem,72vw)}.play-loading-text{margin:0;color:var(--text-muted);font-size:1rem;letter-spacing:.04em}.play-loading-progress{position:relative;width:100%;height:.5rem;border-radius:999px;background:#ffffff1f;overflow:hidden}.play-loading-progress-fill{width:0;height:100%;border-radius:inherit;background:var(--accent-cyan);transition:width .15s ease-out}.play-loading-progress.is-indeterminate .play-loading-progress-fill{width:40%;animation:play-loading-indeterminate 1.1s ease-in-out infinite}.play-loading-bytes{margin:0;color:var(--text-muted);font-size:.85rem;font-variant-numeric:tabular-nums;letter-spacing:.03em}@keyframes play-loading-fade-in{0%{opacity:0}to{opacity:1}}@keyframes play-loading-indeterminate{0%{transform:translate(-100%)}to{transform:translate(250%)}}@media(prefers-reduced-motion:reduce){.play-loading-progress-fill{transition:none}.play-loading-progress.is-indeterminate .play-loading-progress-fill{animation:none;width:100%;background:#ffffff40}}.results-trophies{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.15rem 0}.results-trophies-caption{color:var(--text-muted);font-size:.8rem;letter-spacing:.04em}.tutorial-page{position:relative}.tutorial-overlay{display:flex;justify-content:center;width:100%}.tutorial-page .play-canvas-wrap{min-height:0}.tutorial-overlay-card{background:#060819d9;backdrop-filter:blur(.375rem);-webkit-backdrop-filter:blur(.375rem);border:1px solid var(--line);border-radius:var(--radius-md);padding:.75rem 1.25rem;text-align:center;display:flex;flex-direction:column;gap:.25rem;box-shadow:var(--shadow-glow-cyan);width:min(28rem,92vw)}.tutorial-overlay-card h3{margin:0;font-size:1.1rem;color:var(--accent-cyan)}.tutorial-overlay-card p{margin:0;font-size:.92rem;color:var(--text-muted)}@media(min-width:720px)and (min-height:600px){.tutorial-overlay{position:absolute;left:50%;bottom:1.5rem;transform:translate(-50%);z-index:8;width:auto;pointer-events:none}}.play-overlay-actions{display:flex;flex-direction:column;gap:.5rem;align-items:stretch}.play-pb-line{margin:.25rem 0 0;font-size:.85rem}.tutorial-demo{display:block;width:100%;max-width:22rem;height:auto;margin:.75rem auto;border-radius:8px;border:1px solid var(--line);background:#0a0e25}.tutorial-demo-stars circle{fill:#fff;opacity:.55}.tutorial-demo-rail{fill:var(--accent-magenta, #ff2bd6);filter:drop-shadow(0 0 4px rgba(255,43,214,.5))}.tutorial-demo-receptor{stroke:var(--accent-magenta, #ff2bd6);stroke-width:.8;stroke-opacity:.4;stroke-dasharray:2 3;animation:tutorial-demo-receptor-pulse 1.5s ease-in-out infinite}.tutorial-demo-receptor-label{fill:var(--accent-magenta, #ff2bd6);font:700 7px Rajdhani,Orbitron,system-ui,sans-serif;letter-spacing:.08em;opacity:.7;animation:tutorial-demo-receptor-pulse 1.5s ease-in-out infinite}.tutorial-demo-pad-scroll{animation:tutorial-demo-pad-scroll 3s linear infinite}.tutorial-demo-pad{fill:var(--accent-magenta, #ff2bd6);filter:drop-shadow(0 0 6px rgba(255,43,214,.7))}.tutorial-demo-ring{fill:none;stroke:var(--accent-magenta, #ff2bd6);stroke-width:1.5;animation:tutorial-demo-ring 3s linear infinite}.tutorial-demo-cube-y{animation:tutorial-demo-cube-flip 3s linear infinite}.tutorial-demo-cube{fill:var(--accent-magenta, #ff2bd6);stroke:#fff;stroke-width:1.5;filter:drop-shadow(0 0 4px rgba(255,43,214,.65))}.tutorial-demo-cube-arrow{fill:#fff;opacity:.85}.tutorial-demo-hit{fill:#3bff9d;font:700 13px Rajdhani,Orbitron,system-ui,sans-serif;letter-spacing:.05em;opacity:0;animation:tutorial-demo-hit-flash 3s linear infinite}.tutorial-demo-tap-callout{animation:tutorial-demo-tap-callout 3s linear infinite;transform-origin:141px 54px}.tutorial-demo-tap-callout rect{fill:var(--accent-magenta, #ff2bd6);filter:drop-shadow(0 0 6px rgba(255,43,214,.8))}.tutorial-demo-tap-callout text{fill:#fff;font:700 11px Rajdhani,Orbitron,system-ui,sans-serif;letter-spacing:.08em}@keyframes tutorial-demo-pad-scroll{0%{transform:translate(360px);opacity:0}8%{opacity:1}50%{transform:translate(100px);opacity:1}53%{transform:translate(100px);opacity:.4}56%{transform:translate(80px);opacity:0}to{transform:translate(80px);opacity:0}}@keyframes tutorial-demo-ring{0%{r:22;opacity:0}20%{r:20;opacity:.4}48%{r:9;opacity:1}53%{r:28;opacity:0}to{r:22;opacity:0}}@keyframes tutorial-demo-cube-flip{0%,50%{transform:translateY(80px)}53%{transform:translateY(30px)}88%{transform:translateY(30px)}92%{transform:translateY(80px)}to{transform:translateY(80px)}}@keyframes tutorial-demo-hit-flash{0%,50%{opacity:0;transform:translateY(0)}53%{opacity:1;transform:translateY(-6px)}68%{opacity:0;transform:translateY(-14px)}to{opacity:0;transform:translateY(0)}}@keyframes tutorial-demo-tap-callout{0%,38%{opacity:0;transform:scale(.85)}44%{opacity:1;transform:scale(1.08)}50%{opacity:1;transform:scale(1)}55%{opacity:0;transform:scale(.95)}to{opacity:0;transform:scale(.85)}}@keyframes tutorial-demo-receptor-pulse{0%,to{stroke-opacity:.3;opacity:.55}50%{stroke-opacity:.55;opacity:.85}}@media(prefers-reduced-motion:reduce){.tutorial-demo-pad-scroll,.tutorial-demo-cube-y,.tutorial-demo-ring,.tutorial-demo-receptor,.tutorial-demo-receptor-label,.tutorial-demo-hit,.tutorial-demo-tap-callout{animation:none}.tutorial-demo-pad-scroll{transform:translate(230px)}.tutorial-demo-cube-y{transform:translateY(80px)}.tutorial-demo-hit,.tutorial-demo-tap-callout{display:none}}.my-maps{display:flex;flex-direction:column;gap:.875rem}.my-maps-builder{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:1rem 1.25rem}.my-maps-header{display:flex;justify-content:space-between;align-items:flex-end;gap:.75rem;flex-wrap:wrap}.my-maps-header h3{margin:0}.my-maps-count{margin:.15rem 0 0;font-size:.8rem}.my-maps-create{display:flex;gap:.5rem;flex-wrap:wrap}.my-maps-empty{margin:0;line-height:1.5;max-width:40rem}.my-maps-error{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.my-maps-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.625rem}.my-map-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding:.75rem .875rem .75rem 1rem;background:var(--bg);border:1px solid var(--line-soft);border-left:.25rem solid var(--map-pad, var(--accent-cyan));border-radius:var(--radius-md)}.my-map-row:hover{border-color:var(--line);border-left-color:var(--map-pad, var(--accent-cyan))}.my-map-main{display:flex;flex-direction:column;gap:.35rem;min-width:0;flex:1 1 16rem}.my-map-titleline{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.my-map-title{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.02em;color:var(--text)}.my-map-title:hover{color:var(--accent-magenta)}.my-map-mode{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--accent-cyan);border:1px solid var(--line);border-radius:999px;padding:.1rem .5rem}.my-map-status{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;border-radius:999px;padding:.1rem .5rem}.my-map-status.is-public{color:var(--success);border:1px solid rgba(59,255,157,.4);background:#3bff9d14}.my-map-status.is-private{color:var(--text-faint);border:1px solid var(--line)}.my-map-meta{display:flex;gap:.75rem;align-items:center;font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono);flex-wrap:wrap}.my-map-meta .diff-pips{display:inline-flex;gap:.1875rem}.my-map-meta .pip{display:inline-block;width:.375rem;height:.375rem;border-radius:50%;background:var(--line)}.my-map-meta .pip-on{background:var(--accent-magenta);box-shadow:0 0 .25rem var(--accent-magenta)}.my-map-actions{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}.my-map-actions .btn{min-height:2.4rem;padding:.4rem .8rem;font-size:.82rem}.my-map-delete{color:var(--text-faint)}.my-map-delete:hover{color:var(--danger);border-color:var(--danger)}@media(max-width:560px){.my-map-actions{width:100%}.my-map-actions .btn{flex:1 1 auto}}.builder-page{display:flex;flex-direction:column;gap:1rem}.link-button{background:none;border:none;color:var(--accent-cyan);font-size:inherit;font-family:inherit;cursor:pointer;padding:0 0 0 .5rem;margin:0;text-decoration:underline;text-underline-offset:.1875rem}.link-button:hover{color:var(--accent-magenta)}.bpm-row{display:flex;gap:.5rem;align-items:stretch}.bpm-row input[type=number]{flex:1}.tap-btn{white-space:nowrap}.tap-btn.active{border-color:var(--accent-magenta);color:var(--accent-magenta)}.checkbox-label{flex-direction:row!important;align-items:center!important;gap:.5rem!important}.builder-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.builder-header h2{margin:0}.dirty-dot{color:var(--accent-magenta);font-size:1.5em;margin-left:.25rem;animation:dirty-pulse 1.4s ease-in-out infinite}@keyframes dirty-pulse{0%,to{opacity:.6}50%{opacity:1}}.builder-header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.builder-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(17.5rem,1fr));gap:1rem}.builder-grid label{display:flex;flex-direction:column;gap:.375rem;margin-bottom:.75rem;font-size:.85rem;color:var(--text-muted)}.builder-grid input[type=text],.builder-grid input[type=number],.builder-grid textarea,.builder-grid select{background:var(--bg);border:1px solid var(--line);color:var(--text);padding:.5rem .625rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;min-height:2.5rem;width:100%;min-width:0}.builder-grid label.checkbox{flex-direction:row;align-items:center}.palette-picker{display:flex;gap:.375rem;flex-wrap:wrap;margin-top:.25rem}.palette-swatch{width:2.75rem;height:2.75rem;border-radius:var(--radius-sm);border:.125rem solid var(--line);cursor:pointer;padding:0;background:var(--bg-elev-2);transition:transform .1s}.palette-swatch:hover{transform:scale(1.1)}.palette-swatch.active{border-width:.1875rem;box-shadow:var(--shadow-glow-magenta)}.builder-track-card{padding:1rem}.builder-track-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.builder-track-header h3{margin:0}.builder-track-controls{display:flex;gap:.375rem;align-items:center;flex-wrap:wrap}.builder-track-controls .btn.active{border-color:var(--accent-magenta);color:var(--accent-magenta)}.builder-control-separator{width:1px;height:1.5rem;background:var(--line);margin:0 .25rem}.builder-track-scroll{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--line);overscroll-behavior-x:contain}.builder-track{position:relative;height:13.75rem;cursor:crosshair;user-select:none;touch-action:none}.builder-loop-ruler{position:relative;height:1.5rem;background:#ffffff0a;border-bottom:1px solid var(--line);cursor:ew-resize;user-select:none;touch-action:none}.builder-loop-ruler-label{position:absolute;left:.375rem;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:.625rem;letter-spacing:.05em;text-transform:uppercase;color:var(--text-faint);pointer-events:none}.builder-loop-ruler-region{position:absolute;top:0;bottom:0;background:#3bff9d59;border-left:2px solid var(--success);border-right:2px solid var(--success);pointer-events:none}.builder-loop-band{position:absolute;top:0;bottom:0;background:#3bff9d14;border-left:1px solid rgba(59,255,157,.45);border-right:1px solid rgba(59,255,157,.45);pointer-events:none}.builder-playhead{position:absolute;top:0;bottom:0;width:2px;margin-left:-1px;background:var(--success);box-shadow:0 0 .5rem var(--success);pointer-events:none;z-index:5}.hover-cursor{position:absolute;top:0;bottom:0;width:1px;opacity:.55;pointer-events:none;box-shadow:0 0 .375rem currentColor}.hover-readout{position:absolute;top:.25rem;left:.25rem;white-space:nowrap;font-family:var(--font-mono);font-size:.625rem;font-weight:700;text-shadow:0 0 .375rem currentColor}.hover-marker{position:absolute;width:.875rem;height:.875rem;left:-.4375rem;border-radius:.1875rem;opacity:.5;box-shadow:0 0 .5rem currentColor}.hover-marker.floor{bottom:28%;margin-bottom:.25rem}.hover-marker.ceiling{top:28%;margin-top:.25rem}.rail{position:absolute;left:0;right:0;height:.1875rem;box-shadow:0 0 .5rem currentColor}.rail-top{top:30%}.rail-bottom{bottom:30%}.beat-line{position:absolute;top:0;bottom:0;width:1px;background:#ffffff12;pointer-events:none}.beat-line.bar-line{background:#fff3}.onset-tick{position:absolute;bottom:0;width:2px;height:.625rem;pointer-events:none;transform:translate(-1px);border-radius:1px}.onset-tick.onset-kick{background:#ff6b9d;box-shadow:0 0 .25rem #ff6b9d;height:.875rem}.onset-tick.onset-snare{background:#16e0ff;box-shadow:0 0 .25rem #16e0ff}.onset-tick.onset-lead{background:#b6ff3b;box-shadow:0 0 .25rem #b6ff3b;height:.5rem}.beat-label{position:absolute;top:.25rem;left:.25rem;font-family:var(--font-mono);font-size:.625rem;color:var(--text-faint)}.pad{position:absolute;width:1.5rem;height:1.125rem;border-radius:.1875rem;cursor:pointer;box-shadow:0 0 .75rem currentColor}.pad.floor{bottom:30%;margin-bottom:.1875rem}.pad.ceiling{top:30%;margin-top:.1875rem}.pad-optional{opacity:.7;outline:.125rem dashed currentColor}.pad-error{outline:.1875rem solid #ff3b5c;box-shadow:0 0 .5rem #ff3b5c,0 0 .75rem currentColor}.goal{position:absolute;top:25%;bottom:25%;width:.25rem;box-shadow:0 0 .75rem currentColor}.builder-saved{background:#3bff9d1a;border:1px solid var(--success);color:var(--text)}.builder-saved code{background:var(--bg);padding:.125rem .375rem;border-radius:.25rem;font-size:.85em}.validation-list{margin:0;padding-left:1.25rem;color:var(--text-muted);font-size:.85rem}.hidden{display:none}.builder-instructions{margin:.375rem 0 0}.shortcut-overlay{position:fixed;inset:0;background:#060819b3;backdrop-filter:blur(.375rem);-webkit-backdrop-filter:blur(.375rem);display:flex;align-items:center;justify-content:center;z-index:200}.shortcut-card{width:min(27.5rem,92vw);display:flex;flex-direction:column;gap:.75rem}.shortcut-card h3{margin:0}.shortcut-card ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem;font-size:.92rem}.shortcut-card li{display:flex;align-items:center;gap:.75rem;border-bottom:1px solid var(--line-soft);padding-bottom:.375rem}.shortcut-card li:last-child{border-bottom:none}.shortcut-card .btn{align-self:flex-end}.browse-page{display:flex;flex-direction:column;gap:1rem}.browse-header{display:flex;justify-content:space-between;align-items:flex-end;gap:.75rem;flex-wrap:wrap}.browse-header h2{margin:0}.browse-intro{margin:0;max-width:52rem;line-height:1.5;font-size:.92rem}.browse-controls{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);gap:.75rem;align-items:center}@media(max-width:700px){.browse-controls{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}.browse-search{background:var(--bg);border:1px solid var(--line);color:var(--text);padding:.625rem .75rem;border-radius:var(--radius-sm);font-size:.95rem;min-height:2.5rem;width:100%;min-width:0}.browse-filter-group{display:flex;flex-direction:column;gap:.25rem}.browse-filter-group label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em}.browse-filter-group select{background:var(--bg);border:1px solid var(--line);color:var(--text);padding:.5rem .625rem;border-radius:var(--radius-sm);min-height:2.5rem;width:100%;min-width:0}.checkbox-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.browse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(17.5rem,1fr));gap:1rem}.browse-card{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.browse-card:hover{border-color:var(--map-pad, var(--accent-cyan))}.browse-card-thumb{position:relative;display:block;height:7.5rem;background:linear-gradient(180deg,var(--map-bg, #0a0e27),var(--map-bg-accent, #1a1f4d));overflow:hidden;text-decoration:none}.thumb-bg{position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,transparent 0 1.875rem,rgba(255,255,255,.04) 1.875rem 1.9375rem)}.thumb-rail{position:absolute;left:0;right:0;height:.125rem;background:var(--map-pad, #16e0ff);box-shadow:0 0 .375rem var(--map-pad, #16e0ff)}.thumb-rail-top{top:30%}.thumb-rail-bottom{bottom:30%}.thumb-player{position:absolute;width:1.125rem;height:1.125rem;background:var(--map-player, #ff2bd6);bottom:calc(30% + .125rem);left:25%;box-shadow:0 0 .875rem var(--map-player, #ff2bd6)}.thumb-badge{position:absolute;top:.5rem;right:.5rem;background:#00000080;color:var(--accent-cyan);font-size:.65rem;padding:.125rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.1em;font-weight:700}.browse-card-body{padding:.875rem 1rem 1rem;display:flex;flex-direction:column;gap:.375rem}.browse-card-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.browse-card-title{font-family:var(--font-display);font-weight:700;font-size:1.15rem;letter-spacing:.02em;color:var(--text)}.browse-card-title:hover{color:var(--accent-magenta)}.like-btn{display:flex;gap:.375rem;align-items:center;justify-content:center;background:transparent;border:1px solid var(--line);color:var(--text-muted);padding:.5rem .875rem;border-radius:999px;font-family:var(--font-mono);font-size:.85rem;min-height:2.75rem;min-width:2.75rem}.like-btn:hover{color:var(--accent-magenta);border-color:var(--accent-magenta)}.like-btn.liked{color:var(--accent-magenta);border-color:var(--accent-magenta);background:#ff2bd61a}.heart{font-size:1rem;line-height:1}.browse-card-meta{display:flex;gap:.75rem;align-items:center;font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono);flex-wrap:wrap}.diff-pips{display:inline-flex;gap:.1875rem}.browse-card-desc{margin:.25rem 0 0;font-size:.85rem;color:var(--text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.browse-edit-link{margin-top:.25rem;font-size:.8rem}.empty-state{text-align:center;padding:3.75rem 1.25rem;display:flex;flex-direction:column;gap:1rem;align-items:center}.browse-card-skeleton{pointer-events:none}.browse-card-skeleton .browse-card-thumb{background:var(--bg)}.skeleton-line{background:linear-gradient(90deg,var(--bg) 0%,var(--bg-elev-2) 50%,var(--bg) 100%);background-size:200% 100%;border-radius:.25rem;animation:skeleton-shimmer 1.4s ease-in-out infinite}.skeleton-title{height:1.4rem;width:70%;margin-bottom:.4rem}.skeleton-meta{height:.85rem;width:50%;margin-bottom:.4rem}.skeleton-desc{height:.75rem;width:95%}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.calibration-page{display:flex;flex-direction:column;gap:1.5rem;max-width:62.5rem;margin:0 auto}.calibration-page header{text-align:center}.calibration-page header h2{margin:0 0 .4em}.calibration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(22.5rem,1fr));gap:1rem}.calibration-tap{text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center}.calibration-tap h3{margin:0;text-align:center}.tap-zone{width:100%;height:11.25rem;background:var(--bg);border:.125rem dashed var(--accent-cyan);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;user-select:none;outline:none;transition:all .1s}.tap-zone:hover,.tap-zone:focus{background:var(--bg-elev-2);box-shadow:var(--shadow-glow-cyan)}.tap-zone:active{transform:scale(.98);box-shadow:var(--shadow-glow-magenta)}.tap-progress{font-family:var(--font-display);font-size:2.5rem;font-weight:800;color:var(--accent-cyan)}.calibration-result{display:flex;flex-direction:column;align-items:center;gap:.75rem}.big-number{font-family:var(--font-mono);font-size:3rem;font-weight:700;color:var(--accent-magenta);text-shadow:0 0 1rem var(--accent-magenta)}.manual-offset{display:flex;flex-direction:column;gap:.75rem;margin:.75rem 0}.manual-offset input[type=range]{width:100%;accent-color:var(--accent-magenta)}.manual-offset-readout{display:flex;align-items:center;gap:.5rem}.manual-offset-readout input[type=number]{width:6.25rem;padding:.5rem .625rem;background:var(--bg);border:1px solid var(--line);color:var(--text);border-radius:var(--radius-sm);font-family:var(--font-mono);min-height:2.5rem}.ok-pill{color:var(--success);font-weight:700}.err-pill{color:var(--danger);font-weight:700}.profile-page{max-width:45rem;margin:0 auto;display:flex;flex-direction:column;gap:1rem}.profile-card{display:flex;flex-direction:column}.profile-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 0;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}.profile-row:last-child{border-bottom:none}.profile-row strong{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.edit-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.edit-row input[type=text]{padding:.5rem .625rem;background:var(--bg);border:1px solid var(--line);color:var(--text);border-radius:var(--radius-sm);font-size:.95rem;min-height:2.5rem;min-width:12.5rem}.profile-uid{font-family:var(--font-mono);font-size:.8rem;color:var(--text-faint);background:var(--bg);padding:.125rem .375rem;border-radius:.25rem;word-break:break-all}.keybind-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.keybind-header h3{margin:0}.keybind-section{margin-top:.75rem;display:flex;flex-direction:column;gap:.5rem}.keybind-section h4{margin:0;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.keybind-section p{margin:0}.keybind-grid{display:grid;gap:.5rem}.keybind-grid-circles{grid-template-columns:repeat(2,minmax(8rem,1fr))}.keybind-grid-piano{grid-template-columns:1fr}.keybind-lane{display:grid;grid-template-columns:minmax(5rem,7rem) 1fr;align-items:center;gap:.75rem;background:var(--bg);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.5rem .75rem}.keybind-lane-label{font-family:var(--font-display, inherit);font-weight:700;font-size:.85rem;letter-spacing:.05em;color:var(--text-muted)}.keybind-lane-slots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.keybind-slot{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-elev-2);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;text-align:left;color:var(--text);font:inherit;transition:border-color .15s ease,box-shadow .15s ease;min-height:2.5rem}.keybind-slot:hover{border-color:var(--accent-cyan)}.keybind-slot:focus-visible{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 1px var(--accent-cyan)}.keybind-slot.is-custom{border-color:var(--accent-magenta)}.keybind-slot.is-capturing{border-color:var(--accent-cyan);box-shadow:0 0 0 1px var(--accent-cyan),0 0 1rem #16e0ff59;animation:keybind-pulse 1s ease-in-out infinite}.keybind-slot-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.keybind-slot-key{font-family:var(--font-mono);font-size:.95rem;font-weight:700;color:var(--accent-cyan);padding:.15rem .55rem;border:1px solid var(--line-soft);border-radius:var(--radius-sm);background:var(--bg);min-width:3rem;text-align:center}.keybind-slot.is-custom .keybind-slot-key{color:var(--accent-magenta)}.keybind-error{margin-top:.5rem;padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--danger, #ff4d4d);color:var(--danger, #ff4d4d);background:#ff3b3b14;font-size:.85rem}@keyframes keybind-pulse{0%,to{box-shadow:0 0 0 1px var(--accent-cyan),0 0 .5rem #16e0ff40}50%{box-shadow:0 0 0 1px var(--accent-cyan),0 0 1.25rem #16e0ff8c}}@media(max-width:540px){.keybind-grid-circles{grid-template-columns:1fr}.keybind-lane{grid-template-columns:1fr;gap:.4rem}}.app-main:has(.mode-picker){padding-block:0 clamp(2.5rem,6dvh,4rem);padding-inline:clamp(.5rem,3vw,2rem)}.mode-picker{display:flex;flex-direction:column;gap:clamp(2rem,6dvh,3.5rem)}.mode-picker-stage{display:flex;flex-direction:column;justify-content:center;gap:clamp(.5rem,1.8dvh,1rem);min-height:min(82dvh,50rem);padding-block:clamp(.75rem,2.5dvh,1.5rem)}.mode-picker-hero{flex-shrink:0;text-align:center}.mode-picker-wordmark-sub{display:block;font-family:var(--font-body);font-weight:600;font-size:clamp(.8rem,2.2vw,1.05rem);letter-spacing:.02em;text-transform:none;color:var(--text-muted);margin-top:.35rem;text-shadow:none}.mode-picker-hero h1{font-size:clamp(1.4rem,min(5.5vw,5dvh),3rem);letter-spacing:.05em;margin:0 0 .15em;line-height:1.05}.mode-picker-hero .faint{margin:.15rem 0 0;font-size:clamp(.72rem,1.6dvh,.8rem)}.mode-picker-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:minmax(0,1fr);gap:clamp(.35rem,min(1.2vw,1.5dvh),1rem);width:100%;max-width:min(96rem,100%);margin:0 auto;flex:1 1 auto;align-content:stretch;align-items:stretch;min-height:clamp(5rem,28dvh,14rem)}@media(min-width:540px)and (max-width:899px){.mode-picker-grid{grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr));min-height:clamp(8rem,42dvh,20rem)}.mode-card:nth-child(1){grid-column:1 / 3}.mode-card:nth-child(2){grid-column:3 / 5}.mode-card:nth-child(3){grid-column:5 / 7}.mode-card:nth-child(4){grid-column:1 / 3}.mode-card:nth-child(5){grid-column:3 / 5}.mode-card:nth-child(6){grid-column:5 / 7}}.mode-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(.2rem,1.2dvh,.65rem);min-height:0;height:100%;background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:clamp(.45rem,2dvh,1.25rem) clamp(.35rem,1.2vw,1rem);text-decoration:none;color:inherit;overflow:hidden;text-align:center;transition:transform .18s ease,border-color .18s ease,box-shadow .22s ease}.mode-card:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top right,color-mix(in srgb,var(--mode-accent) 18%,transparent) 0%,transparent 55%);opacity:.55;pointer-events:none;transition:opacity .22s ease}.mode-card:hover,.mode-card:focus-visible{transform:translateY(-3px);border-color:var(--mode-accent);box-shadow:0 1.4rem 2rem -1rem color-mix(in srgb,var(--mode-accent) 50%,transparent);color:inherit}.mode-card:hover:before,.mode-card:focus-visible:before{opacity:.95}.mode-card-badge{position:absolute;top:.35rem;right:.35rem;background:var(--mode-accent);color:var(--bg-deep);font-family:var(--font-display);font-weight:700;font-size:clamp(.5rem,1.6vw,.65rem);letter-spacing:.12em;padding:.1rem .35rem;border-radius:var(--radius-sm);z-index:1}.mode-card-art{position:relative;z-index:1;flex:1 1 auto;display:flex;align-items:center;justify-content:center;width:100%;min-height:clamp(2rem,12dvh,6.5rem);color:var(--mode-accent)}.mode-art-svg{width:100%;max-width:min(12rem,90%);height:100%}.mode-card-body{position:relative;z-index:1;flex:0 1 auto;min-width:0;display:flex;flex-direction:column;align-items:center;gap:.15rem}.mode-card-title{font-size:clamp(.68rem,min(2.8vw,3.2dvh),1.65rem);margin:0;line-height:1.15;color:var(--mode-accent)}.mode-card-tagline{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;font-size:clamp(.48rem,min(1.6vw,1.8dvh),.82rem);color:var(--text-muted);margin:0;line-height:1.2}.mode-card-description,.mode-card-controls,.mode-card-cta{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.mode-card-controls strong{color:var(--text)}.mode-picker-footer{flex-shrink:0;text-align:center;font-size:clamp(.75rem,2vw,.9rem);padding:0}.mode-picker-footer a{color:var(--text-muted);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:.2em}.mode-picker-footer a:hover{color:var(--accent-cyan)}@media(max-height:780px){.mode-picker-stage{gap:.35rem;min-height:88dvh}.mode-picker-grid{min-height:clamp(4rem,22dvh,7rem)}.mode-picker-hero h1{font-size:clamp(1.25rem,5vw,2rem)}.mode-picker-hero .faint{display:none}.mode-card-tagline{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.mode-card-art{flex:0 0 auto;min-height:clamp(1.5rem,8dvh,2.75rem)}.mode-card-title{font-size:clamp(.62rem,2.4vw,.95rem)}}@media(max-height:780px)and (min-width:540px)and (max-width:899px){.mode-picker-grid{min-height:clamp(5.5rem,30dvh,8.5rem)}}@media(max-width:539px){.mode-card-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}}@media(min-width:900px)and (min-height:760px){.mode-picker-grid{min-height:clamp(7rem,32dvh,16rem)}.mode-card-art{max-height:62%}.mode-card-title{text-shadow:0 0 1.2rem color-mix(in srgb,var(--mode-accent) 35%,transparent)}}.mode-picker-content{width:100%;max-width:54rem;margin:0 auto;display:flex;flex-direction:column;gap:clamp(1.5rem,4dvh,2.5rem)}.mode-picker-intro h2,.mode-picker-faq h2{font-size:clamp(1.3rem,3.5vw,1.8rem);margin:0 0 .85rem;text-align:center}.mode-picker-intro p{color:var(--text-muted);line-height:1.6;margin:0 auto 1rem;max-width:46rem;text-align:center}.mode-picker-intro p:last-child{margin-bottom:0}.mode-picker-faq-list{display:grid;gap:.75rem}.mode-picker-faq-item{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:1rem 1.25rem}.mode-picker-faq-item h3{font-size:1.05rem;margin:0 0 .4rem;color:var(--text)}.mode-picker-faq-item p{color:var(--text-muted);line-height:1.55;margin:0;font-size:.92rem}.songs-hub{max-width:56rem;margin:0 auto;display:flex;flex-direction:column;gap:clamp(2rem,5dvh,3rem)}.songs-hub-header{text-align:center}.songs-hub-eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;color:var(--text-muted);margin:0 0 .5rem}.songs-hub-eyebrow a{color:var(--text-muted)}.songs-hub-eyebrow a:hover{color:var(--accent-cyan)}.songs-hub-header h1{font-size:clamp(2rem,6vw,3.25rem);margin:0 0 .5rem}.songs-hub-lede{color:var(--text-muted);font-size:clamp(.95rem,2.2vw,1.1rem);line-height:1.55;max-width:44rem;margin:0 auto}.songs-hub-lede abbr{text-decoration-color:var(--line)}.songs-hub-modes{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1.25rem}.songs-hub-mode-chip{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;font-weight:700;color:var(--text-muted);background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:.45rem .9rem;min-height:2.75rem;display:inline-flex;align-items:center;transition:color .15s,border-color .15s,transform .1s}.songs-hub-mode-chip:hover{color:var(--text);border-color:var(--accent-cyan);transform:translateY(-1px)}.songs-hub-section h2{font-size:clamp(1.25rem,3vw,1.7rem);margin:0 0 1rem}.songs-hub-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.song-card{display:grid;grid-template-columns:3rem minmax(0,1fr);gap:1rem;align-items:center;background:var(--bg-elev);border:1px solid var(--line-soft);border-left:4px solid var(--accent-cyan);border-radius:var(--radius-lg);padding:1rem 1.25rem;text-decoration:none;color:inherit;transition:transform .15s ease,border-color .15s,box-shadow .15s}.song-card:hover{transform:translate(.25rem);border-color:var(--accent-cyan);box-shadow:0 0 1.5rem #16e0ff2e;color:inherit}.song-card-rank{font-family:var(--font-display);font-weight:800;font-size:1.6rem;color:var(--accent-cyan);text-shadow:0 0 .6rem rgba(22,224,255,.5);text-align:center}.song-card-body{min-width:0}.song-card-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0 0 .25rem}.song-card-artist{color:var(--text-muted);font-weight:500;font-size:.95rem}.song-card-desc{color:var(--text-muted);font-size:.9rem;line-height:1.45;margin:0 0 .6rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.song-card-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem 1rem;font-family:var(--font-mono);font-size:.82rem;color:var(--text-muted)}.song-card-bpm{color:var(--text);font-weight:600}.song-card-cta{margin-left:auto;color:var(--accent-cyan);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem}.song-pips{display:inline-flex;gap:.2rem}.song-pip{width:.4rem;height:.4rem;border-radius:50%;background:var(--line)}.song-pip-on{background:var(--accent-magenta);box-shadow:0 0 .25rem var(--accent-magenta)}.songs-hub-about p{color:var(--text-muted);line-height:1.6;max-width:44rem;margin:0 0 1rem}.songs-hub-about h2:not(:first-child){margin-top:1.5rem}.song-detail-crumbs{font-size:.85rem}.song-detail-crumbs a{color:var(--text-muted)}.song-detail-crumbs a:hover{color:var(--accent-cyan)}.song-detail-header h1{font-size:clamp(1.9rem,5vw,3rem);margin:0 0 .5rem}.song-detail-artist{color:var(--text-muted);font-weight:500;font-size:.55em;display:inline-block}.song-detail-lede{color:var(--text-muted);font-size:clamp(.95rem,2.2vw,1.1rem);line-height:1.55;max-width:44rem;margin:0 0 1.25rem}.song-detail-facts{display:flex;flex-wrap:wrap;gap:.6rem}.song-detail-fact{font-family:var(--font-mono);font-size:.85rem;color:var(--text);background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:.4rem .8rem}.song-detail-ncs{color:var(--accent-cyan)}.song-detail-ncs:hover{border-color:var(--accent-cyan)}.song-mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(11rem,1fr));gap:.75rem}.song-mode-card{display:flex;flex-direction:column;gap:.25rem;background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:1rem 1.1rem;text-decoration:none;color:inherit;transition:transform .15s ease,border-color .15s,box-shadow .15s}.song-mode-card:hover{transform:translateY(-2px);border-color:var(--accent-magenta);box-shadow:0 0 1.4rem #ff2bd62e;color:inherit}.song-mode-name{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--accent-magenta)}.song-mode-pitch{color:var(--text-muted);font-size:.85rem}.song-related-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(13rem,1fr));gap:.75rem}.song-related-card{display:flex;flex-direction:column;gap:.2rem;background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:.9rem 1rem;text-decoration:none;color:inherit;transition:transform .15s ease,border-color .15s}.song-related-card:hover{transform:translateY(-2px);border-color:var(--accent-cyan);color:inherit}.song-related-title{font-family:var(--font-display);font-weight:700;font-size:1rem}.song-related-artist{color:var(--text-muted);font-size:.85rem}.song-related-meta{font-family:var(--font-mono);font-size:.78rem;color:var(--text-faint);margin-top:.15rem}.seasons-page{--season-star: #ffd84d;--season-cup: #ffb13b;--season-crown: #c79bff;max-width:60rem;margin:0 auto;padding:1.5rem 1.25rem 4rem}.seasons-header{margin-bottom:1.5rem}.seasons-eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--accent-cyan);margin:0 0 .35rem}.seasons-header h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);line-height:1.05;margin:0 0 .6rem;background:linear-gradient(100deg,var(--text),var(--accent-cyan));-webkit-background-clip:text;background-clip:text;color:transparent}.seasons-lede{color:var(--text-muted);max-width:46rem;line-height:1.6;margin:0}.seasons-legend-item{white-space:nowrap;color:var(--text)}.seasons-legend-glyph{font-weight:700}.seasons-legend-star{color:var(--season-star)}.seasons-legend-cup{color:var(--season-cup)}.seasons-legend-crown{color:var(--season-crown)}.seasons-scope-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem}.seasons-scope-tab{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:600;padding:.5rem .95rem;min-height:2.5rem;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--bg-elev);color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.seasons-scope-tab:hover{color:var(--text);border-color:color-mix(in srgb,var(--accent-cyan) 45%,var(--line))}.seasons-scope-tab.is-active{color:var(--bg-deep);background:var(--accent-cyan);border-color:var(--accent-cyan);box-shadow:var(--shadow-glow-cyan)}.seasons-status-msg{color:var(--text-muted);padding:2rem 0}.seasons-error{color:var(--accent-crimson)}.seasons-body{display:flex;flex-direction:column;gap:1.5rem}.season-section-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;font-size:.95rem;color:var(--text);margin:0 0 .9rem}.season-status{padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--line);background:linear-gradient(180deg,var(--bg-elev),color-mix(in srgb,var(--bg-elev) 60%,var(--bg)))}.season-status-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:.5rem}.season-status-head .season-section-title{margin-bottom:0}.season-status-position{margin:0;font-size:1.05rem;color:var(--text-muted)}.season-status-position strong{font-family:var(--font-mono);font-size:1.4rem;color:var(--accent-cyan)}.season-status-unranked{font-size:.9rem}.season-score{display:flex;flex-direction:column;gap:.85rem;margin:1.1rem 0}.season-currency-row{display:flex;flex-wrap:wrap;gap:.5rem}.season-currency-stat{display:inline-flex;align-items:center;gap:.45rem;padding:.4rem .75rem;border-radius:999px;background:var(--bg);border:1px solid var(--line-soft)}.season-currency-stat-glyph{font-size:1.05rem;line-height:1}.season-currency-stat-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:1.05rem;font-weight:700;color:var(--text)}.season-currency-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}.season-currency-stat-star .season-currency-stat-glyph{color:var(--season-star)}.season-currency-stat-cup .season-currency-stat-glyph{color:var(--season-cup)}.season-currency-stat-crown .season-currency-stat-glyph{color:var(--season-crown)}.season-score-total{display:flex;align-items:baseline;gap:.7rem;padding:.9rem 1.15rem;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--accent-cyan) 40%,var(--line));background:color-mix(in srgb,var(--accent-cyan) 8%,var(--bg))}.season-score-total-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:2.6rem;font-weight:700;line-height:1;color:var(--accent-cyan)}.season-score-total-label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;color:var(--text-muted)}.season-status-awards{display:flex;flex-wrap:wrap;gap:1.5rem}.season-status-award{display:flex;flex-direction:column;gap:.4rem}.season-status-award-caption{display:inline-flex;align-items:center;gap:.3rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-faint)}.season-hint{position:relative;display:inline-flex}.season-hint-trigger{display:inline-flex;align-items:center;justify-content:center;width:1rem;height:1rem;padding:0;border-radius:999px;border:1px solid var(--line);background:var(--bg);color:var(--text-muted);font-family:var(--font-display);font-size:.62rem;font-style:italic;font-weight:700;text-transform:none;line-height:1;transition:color .15s,border-color .15s}.season-hint-trigger:hover,.season-hint-trigger:focus-visible{color:var(--text);border-color:var(--accent-cyan)}.season-hint-bubble{position:absolute;bottom:calc(100% + .45rem);left:50%;transform:translate(-50%);z-index:5;width:max-content;max-width:14rem;padding:.5rem .65rem;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--bg-deep);color:var(--text);font-family:var(--font-body);font-size:.72rem;font-weight:400;letter-spacing:normal;text-transform:none;line-height:1.4;box-shadow:0 .5rem 1.5rem #00000080;pointer-events:none}.season-status-award-empty{color:var(--text-muted);font-size:.85rem}.season-status-next{display:flex;align-items:center;gap:.6rem}.season-status-next-hint{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.season-awards{margin-bottom:1.5rem}.season-awards-empty{margin:0;color:var(--text-muted);font-size:.9rem}.season-awards-rail{display:flex;gap:.6rem;overflow-x:auto;margin:0;padding:.25rem .1rem .75rem;list-style:none;scrollbar-width:thin}.season-award{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:.4rem;min-width:4.5rem;padding:.7rem .6rem;border-radius:var(--radius-md);border:1px solid var(--line);background:var(--bg-elev);--award-colour: var(--text-muted)}.season-award-medallion{display:inline-flex;align-items:center;justify-content:center;min-width:2.2rem;height:2.2rem;padding:0 .5rem;border-radius:999px;font-family:var(--font-mono);font-weight:700;font-size:.85rem;color:var(--bg-deep);background:var(--award-colour)}.season-award-label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem;color:var(--text-muted);white-space:nowrap}.season-award-season{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;font-size:.58rem;font-weight:700;color:var(--award-colour);padding:.05rem .4rem;border:1px solid color-mix(in srgb,var(--award-colour) 40%,var(--line));border-radius:999px}.season-award-scope{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:.6rem;color:var(--text-faint);white-space:nowrap}.season-award-champion{--award-colour: var(--season-star)}.season-award-podium{--award-colour: var(--accent-cyan)}.season-award-elite{--award-colour: var(--accent-violet)}.season-award-gold{--award-colour: var(--accent-amber)}.season-award-silver{--award-colour: #c8d2ff}.season-award-bronze{--award-colour: #cd8a5a}.season-award.is-won{border-color:color-mix(in srgb,var(--award-colour) 50%,var(--line));background:color-mix(in srgb,var(--award-colour) 10%,var(--bg-elev))}.season-award.is-won .season-award-label{color:var(--text)}.season-award.is-current{border-color:var(--award-colour);box-shadow:0 0 .9rem color-mix(in srgb,var(--award-colour) 45%,transparent);background:color-mix(in srgb,var(--award-colour) 12%,var(--bg-elev))}.season-award.is-current .season-award-label{color:var(--text)}.season-award.is-next{border-style:dashed;border-color:color-mix(in srgb,var(--award-colour) 65%,var(--line));animation:season-award-pulse 1.8s ease-in-out infinite}@keyframes season-award-pulse{0%,to{box-shadow:0 0 0 transparent}50%{box-shadow:0 0 .8rem color-mix(in srgb,var(--award-colour) 40%,transparent)}}.season-award-sm{min-width:0;flex-direction:row;padding:.4rem .6rem}.season-award-sm .season-award-medallion{min-width:1.8rem;height:1.8rem;font-size:.75rem}.season-board-empty{color:var(--text-muted)}.season-board-table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}.season-board-table th{text-align:right;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;color:var(--text-faint);padding:.5rem .6rem;border-bottom:1px solid var(--line)}.season-board-table td{padding:.55rem .6rem;border-bottom:1px solid var(--line-soft);color:var(--text)}.season-col-rank{text-align:right;width:3.5rem;font-family:var(--font-mono);color:var(--text-muted)}.season-col-name,.season-board-table th.season-col-name{text-align:left}.season-col-num{text-align:right;font-family:var(--font-mono);width:4rem}.season-col-total{color:var(--accent-cyan);font-weight:700}.season-board-row.is-self{background:color-mix(in srgb,var(--accent-cyan) 12%,transparent)}.season-board-row.is-self td{border-color:color-mix(in srgb,var(--accent-cyan) 35%,var(--line))}.season-you-tag{margin-left:.5rem;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;font-size:.6rem;padding:.1rem .4rem;border-radius:var(--radius-sm);background:var(--accent-cyan);color:var(--bg-deep)}.season-board-gap td{text-align:center;color:var(--text-faint);letter-spacing:.3em}@media(max-width:540px){.season-score-total-value{font-size:2.1rem}}.circles-home .home-hero-kicker{text-shadow:0 0 1.4rem color-mix(in srgb,var(--accent-magenta) 30%,transparent)}.circles-map-row-preview{position:relative;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 50%,color-mix(in srgb,var(--map-pad) 24%,transparent) 0%,transparent 60%),var(--map-bg, #0a0e25)}.circles-preview-ring{position:absolute;border-radius:50%;border:2px solid var(--map-pad, #ff2bd6);box-shadow:0 0 12px color-mix(in srgb,var(--map-pad) 40%,transparent);opacity:.85}.circles-preview-ring-a{width:22px;height:22px;left:18%}.circles-preview-ring-b{width:16px;height:16px;left:46%;opacity:.65}.circles-preview-ring-c{width:12px;height:12px;left:70%;opacity:.45}.circles-tutorial-rules{list-style:none;padding:0;margin:1rem 0;text-align:left;display:grid;gap:.4rem}.circles-tutorial-rules li{font-size:.95rem;color:var(--text-muted);line-height:1.5}.circles-tutorial-rules li strong{color:var(--text-primary);font-weight:600}.piano-home .home-hero-kicker{text-shadow:0 0 1.4rem color-mix(in srgb,var(--accent-lime, #b6ff3b) 30%,transparent)}.piano-map-row-preview{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:2px;align-items:stretch;justify-content:stretch;padding:4px;background:linear-gradient(180deg,color-mix(in srgb,var(--map-bg-accent, #0a0e25) 90%,transparent),color-mix(in srgb,var(--map-bg, #050817) 95%,transparent))}.piano-preview-lane{position:relative;background:color-mix(in srgb,var(--map-pad, #b6ff3b) calc(18% + var(--lane-index, 0) * 4%),transparent);border-radius:2px;overflow:hidden}.piano-preview-lane:after{content:"";position:absolute;left:12%;right:12%;height:18%;top:calc(20% + var(--lane-index, 0) * 16%);border-radius:2px;background:var(--map-pad, #b6ff3b);box-shadow:0 0 6px color-mix(in srgb,var(--map-pad, #b6ff3b) 50%,transparent);opacity:.85}.piano-tutorial-demo{display:block;width:100%;max-width:22rem;height:auto;margin:.75rem auto;border-radius:8px;border:1px solid var(--line);background:#0a0e25}.piano-tutorial-demo-lane{fill:#14193a8c;stroke:#ffffff14;stroke-width:1}.piano-tutorial-demo-hitline{stroke:var(--accent-magenta, #ff2bd6);stroke-width:1.6;stroke-opacity:.55;animation:piano-tutorial-demo-hitline-pulse 1.5s ease-in-out infinite}.piano-tutorial-demo-tap{animation:piano-tutorial-demo-tap-fall 3s ease-in infinite;filter:drop-shadow(0 0 4px rgba(22,224,255,.55))}.piano-tutorial-demo-hold{animation:piano-tutorial-demo-hold-fall 3s linear infinite;filter:drop-shadow(0 0 4px rgba(59,255,157,.55))}.piano-tutorial-demo-key{fill:#ffffffb3;font:bold 11px var(--font-display, "Rajdhani"),system-ui,sans-serif;letter-spacing:.12em}.piano-tutorial-demo-hit{fill:#3bff9d;font:bold 14px var(--font-display, "Rajdhani"),system-ui,sans-serif;letter-spacing:.05em;opacity:0;animation:piano-tutorial-demo-hit-flash 3s linear infinite}@keyframes piano-tutorial-demo-tap-fall{0%{transform:translateY(-22px);opacity:0}10%{opacity:1}50%{transform:translateY(86px);opacity:1}55%{transform:translateY(90px);opacity:0}to{transform:translateY(90px);opacity:0}}@keyframes piano-tutorial-demo-hold-fall{0%{transform:translateY(-52px);opacity:0}10%{opacity:1}85%{transform:translateY(58px);opacity:1}92%{transform:translateY(64px);opacity:.3}to{transform:translateY(64px);opacity:0}}@keyframes piano-tutorial-demo-hit-flash{0%,46%{opacity:0;transform:translateY(0)}50%{opacity:1;transform:translateY(-6px)}62%{opacity:0;transform:translateY(-12px)}to{opacity:0;transform:translateY(0)}}@keyframes piano-tutorial-demo-hitline-pulse{0%,to{stroke-opacity:.35}50%{stroke-opacity:.7}}@media(prefers-reduced-motion:reduce){.piano-tutorial-demo-tap,.piano-tutorial-demo-hold,.piano-tutorial-demo-hit,.piano-tutorial-demo-hitline{animation:none}.piano-tutorial-demo-tap{transform:translateY(50px)}.piano-tutorial-demo-hold{transform:translateY(20px)}.piano-tutorial-demo-hit{display:none}}.guitar-home .home-hero-kicker{text-shadow:0 0 1.4rem color-mix(in srgb,var(--accent-amber, #ffae3b) 30%,transparent)}.guitar-map-row-preview{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:2px;align-items:stretch;justify-content:stretch;padding:4px;background:linear-gradient(180deg,color-mix(in srgb,var(--map-bg-accent, #1a0e05) 90%,transparent),color-mix(in srgb,var(--map-bg, #0c0703) 95%,transparent))}.guitar-preview-lane{position:relative;border-radius:2px;overflow:hidden;background:color-mix(in srgb,var(--map-pad, #ffae3b) 18%,transparent)}.guitar-map-row-preview>.guitar-preview-lane:nth-child(1){background:color-mix(in srgb,#3bff9d 22%,transparent)}.guitar-map-row-preview>.guitar-preview-lane:nth-child(2){background:color-mix(in srgb,#ff5577 22%,transparent)}.guitar-map-row-preview>.guitar-preview-lane:nth-child(3){background:color-mix(in srgb,#ffd84d 22%,transparent)}.guitar-map-row-preview>.guitar-preview-lane:nth-child(4){background:color-mix(in srgb,#4dc8ff 22%,transparent)}.guitar-preview-lane:after{content:"";position:absolute;inset:0;background:linear-gradient(-25deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);background-size:100% 220%;background-position-y:calc(0% + var(--lane-index, 0) * 12%);pointer-events:none}.guitar-builder-page{position:relative}.guitar-editor-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#040612b3;backdrop-filter:blur(.25rem);-webkit-backdrop-filter:blur(.25rem);border-radius:var(--radius-md);z-index:50}.guitar-editor-wrap{display:flex;flex-direction:column;gap:.5rem}.guitar-editor-canvas{width:100%;height:30rem;display:block;border-radius:var(--radius-md);border:1px solid var(--line);background:var(--bg);cursor:crosshair;user-select:none;touch-action:none}.guitar-editor-scrollbar{width:100%}.guitar-playtest-overlay{position:fixed;inset:0;background:#040612eb;backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem);display:flex;align-items:center;justify-content:center;z-index:300;padding:1rem}.guitar-playtest-inner{display:flex;flex-direction:column;gap:.75rem;width:min(60rem,96vw)}.guitar-playtest-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.guitar-playtest-header h3{margin:0}.guitar-playtest-stage{position:relative}.guitar-playtest-canvas{width:100%;aspect-ratio:16 / 9;height:auto;display:block;border-radius:var(--radius-md);border:1px solid var(--line);background:#000}.guitar-playtest-results{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;text-align:center;background:#060819d1;backdrop-filter:blur(.4rem);-webkit-backdrop-filter:blur(.4rem);border-radius:var(--radius-md)}.guitar-playtest-results h4{margin:0;font-size:1.5rem;color:var(--accent-cyan)}.guitar-playtest-stats{display:grid;grid-template-columns:repeat(3,minmax(5rem,1fr));gap:.75rem 1.5rem;margin:0}.guitar-playtest-stats div{display:flex;flex-direction:column;gap:.15rem}.guitar-playtest-stats dt{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.guitar-playtest-stats dd{margin:0;font-size:1.1rem;font-variant-numeric:tabular-nums;color:var(--text)}.guitar-playtest-actions{display:flex;gap:.75rem}.guitar-tutorial-demo{display:block;width:100%;max-width:22rem;height:auto;margin:.75rem auto;border-radius:8px;border:1px solid var(--line);background:#1a0410}.guitar-tutorial-demo-highway{fill:#3a0a2599;stroke:#ffffff1a;stroke-width:1}.guitar-tutorial-demo-lane{fill:#ffffff0a;stroke:#ffffff14;stroke-width:1}.guitar-tutorial-demo-lane-0{fill:#3bff7a0f}.guitar-tutorial-demo-lane-1{fill:#ff3b5c0f}.guitar-tutorial-demo-lane-2{fill:#ffd84d14}.guitar-tutorial-demo-lane-3{fill:#3b9dff0f}.guitar-tutorial-demo-strumbar{stroke:var(--accent-magenta, #ff2bd6);stroke-width:2;stroke-opacity:.55;animation:guitar-tutorial-demo-strumbar-pulse 1.5s ease-in-out infinite}.guitar-tutorial-demo-gem{animation:guitar-tutorial-demo-gem-fall 3s ease-in infinite;filter:drop-shadow(0 0 4px rgba(255,59,92,.55))}.guitar-tutorial-demo-key{fill:#ffffffd9;font:bold 11px var(--font-display, "Rajdhani"),system-ui,sans-serif;letter-spacing:.12em}.guitar-tutorial-demo-hit{fill:#ffd84d;font:bold 14px var(--font-display, "Rajdhani"),system-ui,sans-serif;letter-spacing:.08em;opacity:0;animation:guitar-tutorial-demo-hit-flash 3s linear infinite}@keyframes guitar-tutorial-demo-gem-fall{0%{transform:translateY(-22px) scale(.45);opacity:0}8%{opacity:1}50%{transform:translate(18px,92px) scale(1);opacity:1}55%{transform:translate(20px,100px) scale(1.05);opacity:0}to{transform:translate(20px,100px) scale(1.05);opacity:0}}@keyframes guitar-tutorial-demo-hit-flash{0%,47%{opacity:0;transform:translateY(0)}52%{opacity:1;transform:translateY(-6px)}64%{opacity:0;transform:translateY(-12px)}to{opacity:0;transform:translateY(0)}}@keyframes guitar-tutorial-demo-strumbar-pulse{0%,to{stroke-opacity:.4;stroke-width:1.6}50%{stroke-opacity:.85;stroke-width:2.4}}@media(prefers-reduced-motion:reduce){.guitar-tutorial-demo-gem,.guitar-tutorial-demo-hit,.guitar-tutorial-demo-strumbar{animation:none}.guitar-tutorial-demo-gem{transform:translate(15px,60px) scale(.9)}.guitar-tutorial-demo-hit{display:none}}.waves-home .home-hero-kicker{text-shadow:0 0 1.4rem color-mix(in srgb,var(--accent-cyan, #3bd8ff) 30%,transparent)}.waves-map-row-preview{position:relative;display:block;padding:0;overflow:hidden;background:linear-gradient(180deg,color-mix(in srgb,var(--map-bg-accent, #0c1f3d) 90%,transparent),color-mix(in srgb,var(--map-bg, #06122a) 95%,transparent))}.waves-preview-corridor-top,.waves-preview-corridor-bottom{position:absolute;left:0;right:0;height:2px;background:color-mix(in srgb,var(--map-hazard, #ff5577) 70%,transparent);opacity:.75}.waves-preview-corridor-top{top:6px}.waves-preview-corridor-bottom{bottom:6px}.waves-preview-trajectory{position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(-30deg,transparent 0,transparent 6px,color-mix(in srgb,var(--map-player, #3bd8ff) 30%,transparent) 6px,color-mix(in srgb,var(--map-player, #3bd8ff) 30%,transparent) 8px);opacity:.6}.waves-tutorial-demo{display:block;width:100%;max-width:22rem;height:auto;margin:.75rem auto;border-radius:8px;border:1px solid var(--line);background:#061229}.waves-tutorial-demo-ceiling,.waves-tutorial-demo-floor{stroke:#ffffff40;stroke-width:2;fill:none}.waves-tutorial-demo-spike{fill:#ff6482d9;stroke:#ffffff80;stroke-width:1}.waves-tutorial-demo-trail{stroke:#a6f1ff73;stroke-width:2;stroke-linecap:round;fill:none;stroke-dasharray:4 5;animation:waves-tutorial-demo-trail-shift 4s linear infinite}.waves-tutorial-demo-player{animation:waves-tutorial-demo-player-path 4s linear infinite;filter:drop-shadow(0 0 4px rgba(59,216,255,.7))}.waves-tutorial-demo-key{fill:#ffffffb3;font:bold 11px var(--font-display, "Rajdhani"),system-ui,sans-serif;letter-spacing:.12em}.waves-tutorial-demo-hit{fill:#3bd8ff;font:bold 13px var(--font-display, "Rajdhani"),system-ui,sans-serif;letter-spacing:.08em;opacity:0;animation:waves-tutorial-demo-hit-flash 4s linear infinite}@keyframes waves-tutorial-demo-trail-shift{0%{stroke-dashoffset:0}to{stroke-dashoffset:-90}}@keyframes waves-tutorial-demo-player-path{0%{transform:translate(16px,80px);opacity:0}6%{opacity:1}25%{transform:translate(72px,38px)}50%{transform:translate(152px,98px)}75%{transform:translate(224px,42px)}95%{transform:translate(304px,82px);opacity:1}to{transform:translate(304px,82px);opacity:0}}@keyframes waves-tutorial-demo-hit-flash{0%,20%{opacity:0}28%{opacity:1;transform:translateY(-6px)}40%{opacity:0;transform:translateY(-10px)}to{opacity:0;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.waves-tutorial-demo-player,.waves-tutorial-demo-hit,.waves-tutorial-demo-trail{animation:none}.waves-tutorial-demo-player{transform:translate(160px,70px)}.waves-tutorial-demo-hit{display:none}}.jump-home .home-hero-kicker{text-shadow:0 0 1.4rem color-mix(in srgb,var(--accent-green, #3bff9d) 30%,transparent)}.jump-map-row-preview{position:relative;display:block;padding:0;overflow:hidden;background:linear-gradient(180deg,color-mix(in srgb,var(--map-bg-accent, #10243a) 90%,transparent),color-mix(in srgb,var(--map-bg, #0a1424) 95%,transparent))}.jump-preview-ground{position:absolute;left:0;right:0;bottom:10px;height:2px;background:color-mix(in srgb,var(--map-player, #3bff9d) 65%,transparent);opacity:.8}.jump-preview-block{position:absolute;right:14px;bottom:12px;width:22px;height:16px;border-radius:2px;background:color-mix(in srgb,var(--map-pad, #1c3a5c) 85%,transparent);border:1px solid color-mix(in srgb,var(--map-player, #3bff9d) 40%,transparent)}.jump-preview-spike{position:absolute;left:50%;bottom:12px;width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:16px solid color-mix(in srgb,var(--map-hazard, #ff5577) 80%,transparent)}.jump-preview-cube{position:absolute;left:16px;bottom:22px;width:12px;height:12px;border-radius:2px;background:var(--map-player, #3bff9d);box-shadow:0 0 6px color-mix(in srgb,var(--map-player, #3bff9d) 60%,transparent);transform:rotate(-18deg)}.jump-tutorial-demo{display:block;width:100%;max-width:22rem;height:auto;margin:.75rem auto;border-radius:8px;border:1px solid var(--line);background:#0a1424}.jump-tutorial-demo-ground{stroke:#ffffff40;stroke-width:2;fill:none}.jump-tutorial-demo-spike{fill:#ff6482d9;stroke:#ffffff80;stroke-width:1}.jump-tutorial-demo-trail{stroke:#78ffb473;stroke-width:2;stroke-linecap:round;fill:none;stroke-dasharray:4 5;animation:jump-tutorial-demo-trail-shift 4s linear infinite}.jump-tutorial-demo-player{animation:jump-tutorial-demo-player-path 4s linear infinite;filter:drop-shadow(0 0 4px rgba(59,255,157,.7))}.jump-tutorial-demo-key{fill:#ffffffb3;font:bold 11px var(--font-display, "Rajdhani"),system-ui,sans-serif;letter-spacing:.12em}.jump-tutorial-demo-hit{fill:#3bff9d;font:bold 13px var(--font-display, "Rajdhani"),system-ui,sans-serif;letter-spacing:.08em;opacity:0}.jump-tutorial-demo-hit-tap{animation:jump-tutorial-demo-hit-tap 4s linear infinite}.jump-tutorial-demo-hit-hold{animation:jump-tutorial-demo-hit-hold 4s linear infinite}@keyframes jump-tutorial-demo-trail-shift{0%{stroke-dashoffset:0}to{stroke-dashoffset:-120}}@keyframes jump-tutorial-demo-player-path{0%{transform:translate(16px,96px);opacity:0}5%{opacity:1}21%{transform:translate(86px,96px)}29%{transform:translate(110px,71px)}37%{transform:translate(134px,96px)}52%{transform:translate(186px,96px)}61%{transform:translate(210px,33px)}71%{transform:translate(236px,96px)}88%{transform:translate(304px,96px)}95%{transform:translate(304px,96px);opacity:1}to{transform:translate(304px,96px);opacity:0}}@keyframes jump-tutorial-demo-hit-tap{0%,24%{opacity:0}29%{opacity:1;transform:translateY(-3px)}40%{opacity:0;transform:translateY(-9px)}to{opacity:0;transform:translateY(0)}}@keyframes jump-tutorial-demo-hit-hold{0%,56%{opacity:0}61%{opacity:1;transform:translateY(-3px)}72%{opacity:0;transform:translateY(-9px)}to{opacity:0;transform:translateY(0)}}.jump-tutorial-retry-overlay{background:#080e1a8c}.jump-tutorial-retry-card{animation:jump-tutorial-retry-pulse .95s ease-out forwards}@keyframes jump-tutorial-retry-pulse{0%{opacity:0;transform:scale(.94)}18%{opacity:1;transform:scale(1)}78%{opacity:1;transform:scale(1)}to{opacity:.35;transform:scale(.98)}}@media(prefers-reduced-motion:reduce){.jump-tutorial-demo-player,.jump-tutorial-demo-hit,.jump-tutorial-demo-trail{animation:none}.jump-tutorial-demo-player{transform:translate(86px,96px)}.jump-tutorial-demo-hit{display:none}.jump-tutorial-retry-card{animation:none}}.analytics-page{display:flex;flex-direction:column;gap:2rem;max-width:78rem;margin:0 auto;padding:1.5rem 1rem 4rem}.analytics-header{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap}.analytics-header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.analytics-refresh-btn{font-size:.85rem;padding:.4rem .9rem}.analytics-refresh-btn:disabled{opacity:.55;cursor:progress}.analytics-loaded-at{margin-left:.5rem;font-size:.75rem;white-space:nowrap}.analytics-header h1{font-size:clamp(1.6rem,4vw,2.4rem);margin:0 0 .25rem;letter-spacing:.04em}.analytics-header code{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.1em .35em;font-family:var(--font-mono);font-size:.85em}.analytics-range-tabs{display:flex;gap:.5rem;flex-wrap:wrap}.analytics-range-tabs button{background:var(--bg-elev);color:var(--text-muted);border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:.4rem .9rem;font-family:var(--font-body);font-size:.85rem;cursor:pointer;transition:all .15s ease}.analytics-range-tabs button:hover{border-color:var(--accent-cyan);color:var(--text)}.analytics-range-tabs button.active{background:var(--accent-cyan);color:var(--bg-deep);border-color:var(--accent-cyan)}.analytics-error{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.analytics-whoami{display:flex;align-items:center;gap:.5rem;font-size:.8rem;align-self:flex-start}.analytics-whoami code{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.15em .4em;font-family:var(--font-mono);font-size:.85em;color:var(--text-faint)}.analytics-forbidden{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:1.5rem 1.75rem 1.75rem;display:flex;flex-direction:column;gap:.85rem;max-width:52rem}.analytics-forbidden h2{margin:0;font-size:1.1rem;letter-spacing:.06em}.analytics-forbidden p{margin:0}.analytics-forbidden-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.analytics-forbidden-row code,.analytics-forbidden-cmd{background:var(--bg-elev-2);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.4rem .65rem;font-family:var(--font-mono);font-size:.85rem;color:var(--text);word-break:break-all;flex:1;min-width:0}.btn-small{padding:.3rem .7rem;font-size:.75rem}.analytics-section{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:1.25rem 1.5rem 1.5rem}.analytics-section h2{font-size:1rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin:0 0 .75rem}.analytics-section>p.muted{margin:0 0 1rem;font-size:.9rem;line-height:1.5}.analytics-section>p.muted code{background:var(--bg-elev-2);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.05em .3em;font-family:var(--font-mono);font-size:.85em}.analytics-explainer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.analytics-explainer-list li{display:grid;grid-template-columns:6rem 1fr;gap:.85rem;align-items:baseline;font-size:.9rem;line-height:1.5}.analytics-explainer-list strong{color:var(--text);font-weight:600}.analytics-explainer-foot{margin:1rem 0 0;font-size:.8rem}.analytics-explainer-foot code{background:var(--bg-elev-2);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.05em .3em;font-family:var(--font-mono);font-size:.85em}.analytics-event-badge{display:inline-block;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;padding:.18em .55em;border-radius:var(--radius-sm);border:1px solid var(--line-soft);text-transform:lowercase;white-space:nowrap;background:var(--bg-elev-2);color:var(--text-muted);text-align:center;min-width:4.5rem}.analytics-event-start{border-color:#16e0ff66;color:var(--accent-cyan);background:#16e0ff14}.analytics-event-end{border-color:#b6ff3b66;color:var(--accent-lime);background:#b6ff3b14}.analytics-event-abandon{border-color:#ff3b3b66;color:var(--accent-crimson);background:#ff3b3b14}.analytics-event-view{border-color:#8a3bff66;color:var(--accent-violet);background:#8a3bff14}.analytics-event-session{border-color:#ffae3b66;color:var(--accent-amber);background:#ffae3b14}.analytics-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));gap:1rem}.analytics-kpi{background:var(--bg-elev-2);border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:.9rem 1rem;display:flex;flex-direction:column;gap:.2rem}.analytics-kpi-value{font-family:var(--font-display);font-size:1.75rem;letter-spacing:.04em;color:var(--text)}.analytics-kpi-label{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.analytics-kpi-sub{font-size:.8rem;color:var(--text-faint)}.analytics-table-wrap{overflow-x:auto}.analytics-table{width:100%;border-collapse:collapse;font-size:.9rem}.analytics-table-compact{font-size:.8rem}.analytics-table th,.analytics-table td{text-align:left;padding:.5rem .75rem;border-bottom:1px solid var(--line-soft);vertical-align:middle}.analytics-table th{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.analytics-table tr:last-child td{border-bottom:none}.analytics-table .mono{font-family:var(--font-mono);color:var(--text-faint)}.analytics-context-cell{max-width:22rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-when-cell{font-family:var(--font-mono);font-size:.78rem;white-space:nowrap;color:var(--text)}.analytics-player-cell{max-width:14rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-recent-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin:0 0 .85rem}.analytics-recent-controls>p.muted{margin:0;flex:1;min-width:16rem}.analytics-toggle{display:inline-flex;align-items:center;gap:.45rem;font-size:.85rem;color:var(--text-muted);cursor:pointer;user-select:none}.analytics-toggle input[type=checkbox]{width:.95rem;height:.95rem;accent-color:var(--accent-cyan);cursor:pointer}.analytics-drilldown-controls{display:flex;align-items:flex-start;gap:1.5rem;flex-wrap:wrap;margin:0 0 1rem;padding:.85rem 1rem;background:var(--bg-elev-2);border:1px solid var(--line-soft);border-radius:var(--radius-md)}.analytics-drilldown-label{display:flex;flex-direction:column;gap:.3rem;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;flex:1;min-width:18rem}.analytics-drilldown-select{background:var(--bg-elev);color:var(--text);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.5rem .75rem;font-family:var(--font-body);font-size:.85rem;cursor:pointer;text-transform:none;letter-spacing:normal}.analytics-drilldown-select:hover{border-color:var(--accent-cyan)}.analytics-drilldown-select:focus{outline:2px solid var(--accent-cyan);outline-offset:1px}.analytics-drilldown-summary{display:flex;flex-direction:column;gap:.3rem;flex:1;min-width:18rem;font-size:.8rem}.analytics-drilldown-summary-row{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.analytics-drilldown-summary-row>.muted{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;min-width:4.5rem}.analytics-drilldown-summary-row code{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.15em .4em;font-family:var(--font-mono);font-size:.78rem;color:var(--text);word-break:break-all;max-width:100%}.error-text{color:var(--accent-crimson);font-size:.85rem;margin:0 0 .75rem}.analytics-histogram{display:flex;flex-direction:column;gap:.5rem}.analytics-histogram-row{display:grid;grid-template-columns:12rem 1fr 7rem;gap:.75rem;align-items:center}.analytics-histogram-label{font-size:.85rem;color:var(--text-muted)}.analytics-histogram-bar{background:var(--bg-elev-2);border-radius:var(--radius-sm);height:.9rem;overflow:hidden}.analytics-histogram-fill{height:100%;background:linear-gradient(90deg,var(--accent-violet),var(--accent-cyan));transition:width .2s ease}.analytics-histogram-count{font-family:var(--font-mono);font-size:.8rem;text-align:right;color:var(--text)}.analytics-histogram-pct{color:var(--text-faint)}.analytics-histogram-compact .analytics-histogram-row{grid-template-columns:9rem 1fr 5rem;gap:.5rem}.analytics-histogram-compact .analytics-histogram-label{font-size:.75rem}.analytics-histogram-compact .analytics-histogram-bar{height:.65rem}.analytics-histogram-compact .analytics-histogram-count{font-size:.72rem}.analytics-map-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(28rem,1fr));gap:1rem}.analytics-map-card{background:var(--bg-elev-2);border:1px solid var(--line-soft);border-radius:var(--radius-md);padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.85rem}.analytics-map-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;flex-wrap:wrap}.analytics-map-card-title{display:flex;flex-direction:column;gap:.15rem;min-width:0}.analytics-map-card-mode{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-cyan)}.analytics-map-card-song{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.02em;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-map-card-tags{display:flex;gap:.35rem;flex-wrap:wrap}.analytics-map-card-tag{font-size:.7rem;letter-spacing:.06em;color:var(--text-faint);background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.15em .5em;white-space:nowrap}.analytics-map-card-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.5rem;padding:.6rem 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}.analytics-map-stat{display:flex;flex-direction:column;gap:.1rem;min-width:0}.analytics-map-stat-value{font-family:var(--font-display);font-size:1.1rem;color:var(--text);letter-spacing:.02em}.analytics-map-stat-label{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.analytics-map-stat-hint{font-size:.7rem;color:var(--text-faint)}.analytics-map-card-empty{margin:0;font-size:.8rem;font-style:italic}.analytics-dau-summary{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--line-soft)}.analytics-dau-summary-item{display:flex;flex-direction:column;gap:.1rem}.analytics-dau-summary-value{font-family:var(--font-display);font-size:1.5rem;color:var(--text);letter-spacing:.02em}.analytics-dau-summary-label{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.analytics-dau-legend{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-muted);margin-left:auto}.analytics-dau-legend>.analytics-dau-swatch+span+.analytics-dau-swatch{margin-left:.6rem}.analytics-dau-swatch{display:inline-block;width:.8rem;height:.8rem;border-radius:2px}.analytics-dau-swatch-return{background:var(--accent-violet)}.analytics-dau-swatch-new{background:var(--accent-lime)}.analytics-bars{display:flex;align-items:stretch;gap:.4rem;border-top:1px solid var(--line-soft);padding-top:.75rem}.analytics-bar-col{flex:1;display:flex;flex-direction:column;align-items:stretch;min-width:2.5rem;gap:.3rem}.analytics-bar-value{font-family:var(--font-mono);font-size:.8rem;color:var(--text);text-align:center;height:1.1rem;font-weight:600}.analytics-bar-track{position:relative;height:11rem;background:var(--bg-elev-2);border-radius:var(--radius-sm);overflow:hidden;display:flex;align-items:flex-end}.analytics-bar-stack{width:100%;display:flex;flex-direction:column;min-height:2px}.analytics-bar-new{background:var(--accent-lime);min-height:2px}.analytics-bar-returning{background:var(--accent-violet);min-height:2px}.analytics-bar-date{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);text-align:center;white-space:nowrap}.analytics-bar-new-sub{font-family:var(--font-mono);font-size:.65rem;color:var(--accent-lime);text-align:center;white-space:nowrap;height:1rem}.analytics-chart-scroll{overflow-x:auto;padding-bottom:.25rem}.analytics-playtime-seg{min-height:2px}.analytics-playtime-seg:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.analytics-mode-legend{flex-wrap:wrap;gap:.75rem}.analytics-mode-legend-item{display:inline-flex;align-items:center;gap:.35rem}.analytics-mode-tabs{margin-bottom:1rem}@media(max-width:768px){.analytics-histogram-row{grid-template-columns:1fr;gap:.25rem}.analytics-histogram-count{text-align:left}.analytics-histogram-compact .analytics-histogram-row,.analytics-map-grid{grid-template-columns:1fr}.analytics-map-card-stats{grid-template-columns:repeat(2,1fr)}.analytics-explainer-list li{grid-template-columns:1fr;gap:.3rem}.analytics-dau-legend{margin-left:0}}.discord-invite{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-height:2.25rem;padding:0 .55rem;border-radius:var(--radius-sm);border:1px solid var(--line-soft);background:var(--bg-elev-2);color:var(--text-muted);font-weight:600;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:color .12s ease,border-color .12s ease,background .12s ease}.discord-invite:hover{color:var(--text);border-color:color-mix(in srgb,#5865f2 55%,var(--line));background:color-mix(in srgb,#5865f2 12%,var(--bg-elev-2))}.discord-invite:focus-visible{outline:none;border-color:#5865f2;box-shadow:0 0 0 1px #5865f2}.discord-invite-icon{display:block;flex-shrink:0}@media(max-width:720px){.discord-invite-label{display:none}.discord-invite{width:2.25rem;padding:0}}.top-nav-mode{display:inline-flex;align-items:center;gap:.5rem;margin-right:.5rem}.top-nav-mode-badge{font-family:var(--font-display);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.75rem;padding:.2rem .55rem;border-radius:var(--radius-sm);background:var(--bg-elev-2);border:1px solid var(--line)}.top-nav-mode-badge-pulse{color:var(--accent-cyan);border-color:color-mix(in srgb,var(--accent-cyan) 50%,var(--line));box-shadow:0 0 .6rem color-mix(in srgb,var(--accent-cyan) 30%,transparent)}.top-nav-mode-badge-circles{color:var(--accent-magenta);border-color:color-mix(in srgb,var(--accent-magenta) 50%,var(--line));box-shadow:0 0 .6rem color-mix(in srgb,var(--accent-magenta) 30%,transparent)}.top-nav-mode-badge-piano{color:var(--accent-lime, #b6ff3b);border-color:color-mix(in srgb,var(--accent-lime, #b6ff3b) 50%,var(--line));box-shadow:0 0 .6rem color-mix(in srgb,var(--accent-lime, #b6ff3b) 30%,transparent)}.top-nav-mode-badge-guitar{color:var(--accent-amber, #ffae3b);border-color:color-mix(in srgb,var(--accent-amber, #ffae3b) 50%,var(--line));box-shadow:0 0 .6rem color-mix(in srgb,var(--accent-amber, #ffae3b) 30%,transparent)}.top-nav-mode-badge-waves{color:var(--accent-cyan, #3bd8ff);border-color:color-mix(in srgb,var(--accent-cyan, #3bd8ff) 50%,var(--line));box-shadow:0 0 .6rem color-mix(in srgb,var(--accent-cyan, #3bd8ff) 30%,transparent)}.top-nav-mode-badge-jump{color:var(--accent-green, #3bff9d);border-color:color-mix(in srgb,var(--accent-green, #3bff9d) 50%,var(--line));box-shadow:0 0 .6rem color-mix(in srgb,var(--accent-green, #3bff9d) 30%,transparent)}.top-nav-trophies-row{display:inline-flex;align-items:center;gap:.25rem}.top-nav-trophies-overall{font-weight:600}.top-nav-trophies-mode{font-size:.7rem;color:var(--text-muted)}.top-nav-trophies-mode-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;font-size:.6rem;margin-right:.25rem;opacity:.85}.top-nav-trophies-mode-pulse .top-nav-trophies-mode-label{color:var(--accent-cyan)}.top-nav-trophies-mode-circles .top-nav-trophies-mode-label{color:var(--accent-magenta)}.top-nav-trophies-mode-piano .top-nav-trophies-mode-label{color:var(--accent-lime, #b6ff3b)}.top-nav-trophies-mode-guitar .top-nav-trophies-mode-label{color:var(--accent-amber, #ffae3b)}.top-nav-trophies-mode-waves .top-nav-trophies-mode-label{color:var(--accent-cyan, #3bd8ff)}.top-nav-trophies-mode-jump .top-nav-trophies-mode-label{color:var(--accent-green, #3bff9d)}@media(max-width:640px){.top-nav-trophies-mode{display:none}}.top-nav-volume{position:relative;display:inline-flex;align-items:center}.top-nav-volume-trigger{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;padding:0;background:var(--bg-elev-2);border:1px solid var(--line-soft);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:color .12s ease,border-color .12s ease}.top-nav-volume:hover .top-nav-volume-trigger,.top-nav-volume[data-open=true] .top-nav-volume-trigger{color:var(--text);border-color:color-mix(in srgb,var(--accent-cyan) 50%,var(--line))}.top-nav-volume-trigger:focus-visible{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 1px var(--accent-cyan)}.top-nav-volume-icon{display:block}.top-nav-volume-icon.is-silenced{color:var(--accent-magenta)}.top-nav-volume-panel{position:absolute;top:calc(100% + .5rem);right:0;min-width:16rem;padding:.75rem .875rem;display:flex;flex-direction:column;gap:.55rem;background:linear-gradient(180deg,#0a0e27fa,#0a0e27eb);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:0 .5rem 1.25rem #00000073;backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-.25rem);transition:opacity .12s ease,transform .12s ease,visibility 0s linear .12s;z-index:110}.top-nav-volume-panel:before{content:"";position:absolute;inset:-.5rem -1rem auto;height:.5rem}.top-nav-volume[data-open=true] .top-nav-volume-panel{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);transition:opacity .12s ease,transform .12s ease,visibility 0s linear 0s}.top-nav-volume-row{display:grid;grid-template-columns:3.5rem 1fr 2.5rem;align-items:center;gap:.625rem}.top-nav-volume-row label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.top-nav-volume-row input[type=range]{width:100%;margin:0;accent-color:var(--accent-cyan);min-width:0;cursor:pointer}.top-nav-volume-readout{font-family:var(--font-mono);font-size:.75rem;color:var(--accent-cyan);text-align:right}@media(max-width:480px){.top-nav-volume-panel{min-width:14rem;padding:.625rem .75rem}.top-nav-volume-row{grid-template-columns:3rem 1fr 2.25rem}}:root{--bg-deep: #060819;--bg: #0a0e27;--bg-elev: #131a3d;--bg-elev-2: #1a2350;--line: #2a3270;--line-soft: #1f2858;--text: #e8ecff;--text-muted: #8e96c7;--text-faint: #7a82b8;--accent-magenta: #ff2bd6;--accent-cyan: #16e0ff;--accent-violet: #8a3bff;--accent-lime: #b6ff3b;--accent-amber: #ffae3b;--accent-green: #3bff9d;--accent-crimson: #ff3b3b;--danger: #ff3b5c;--success: #3bff9d;--variant-normal: var(--accent-cyan);--variant-hard: var(--accent-magenta);--variant-extreme: var(--accent-crimson);--variant-insane: var(--accent-violet);--shadow-glow-magenta: 0 0 1.5rem rgba(255, 43, 214, .45);--shadow-glow-cyan: 0 0 1.5rem rgba(22, 224, 255, .45);--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: 1rem;--font-display: "Rajdhani", "Orbitron", "Inter", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace}html{font-size:12.5px;scrollbar-gutter:stable}@media(min-width:480px){html{font-size:13.5px}}@media(min-width:768px){html{font-size:15px}}@media(min-width:1280px){html{font-size:16px}}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg-deep);color:var(--text);font-family:var(--font-body);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{font-size:1rem;min-height:100dvh;background-image:radial-gradient(ellipse at 25% 15%,rgba(138,59,255,.18) 0%,transparent 60%),radial-gradient(ellipse at 75% 85%,rgba(22,224,255,.12) 0%,transparent 60%),radial-gradient(ellipse at 50% 50%,rgba(255,43,214,.06) 0%,transparent 70%)}#root{min-height:100dvh;display:flex;flex-direction:column}a{color:var(--accent-cyan);text-decoration:none}a:hover{color:var(--accent-magenta)}button{font-family:inherit;font-size:inherit;cursor:pointer}:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px;border-radius:var(--radius-sm)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}input:focus-visible,select:focus-visible,textarea:focus-visible{outline-color:var(--accent-magenta);box-shadow:0 0 0 3px #ff2bd640}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:.02em;margin:0 0 .5em}h1{font-size:2.5rem;text-shadow:0 0 1.5rem rgba(255,43,214,.4)}h2{font-size:1.6rem}code,pre{font-family:var(--font-mono)}kbd{background:var(--bg-elev-2);border:1px solid var(--line);border-bottom-width:.1875rem;padding:.0625rem .375rem;border-radius:.25rem;font-family:var(--font-mono);font-size:.85em}.app-shell{display:flex;flex-direction:column;min-height:100dvh}.app-main{flex:1;padding:1.5rem clamp(1rem,4vw,3rem) 4rem;max-width:80rem;width:100%;margin:0 auto}.top-nav{display:flex;align-items:center;gap:1.5rem;padding:.875rem clamp(1rem,4vw,3rem);border-bottom:1px solid var(--line-soft);background:linear-gradient(180deg,#0a0e27f2,#0a0e27b3);backdrop-filter:blur(.5rem);-webkit-backdrop-filter:blur(.5rem);position:sticky;top:0;z-index:100;flex-wrap:wrap;row-gap:.5rem}.top-nav-brand{font-family:var(--font-display);font-weight:800;font-size:1.4rem;letter-spacing:.1em;text-transform:uppercase;background:linear-gradient(90deg,var(--accent-magenta),var(--accent-cyan));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:none;text-decoration:none}.top-nav-links{display:flex;gap:.5rem;align-items:center;flex:1 1 auto;flex-wrap:wrap}.top-nav-links a{color:var(--text-muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.85rem;padding:.625rem .875rem;display:inline-flex;align-items:center;min-height:2.75rem;border-radius:var(--radius-sm);transition:color .15s,background .15s}.top-nav-links a:hover,.top-nav-links a.active{color:var(--text);background:var(--bg-elev)}.top-nav-user{display:flex;gap:.625rem;align-items:center;font-size:.85rem;color:var(--text-muted)}.top-nav-trophies{display:inline-flex;flex-direction:column;align-items:flex-end;gap:.15rem;padding:.3rem .7rem;border-radius:var(--radius-md);background:#0a0e2799;border:1px solid var(--line-soft);font-family:var(--font-mono);font-size:.85rem;color:var(--text);font-variant-numeric:tabular-nums;line-height:1.1;text-decoration:none;cursor:pointer;transition:border-color .15s,background .15s}.top-nav-trophies:hover{border-color:color-mix(in srgb,var(--accent-cyan) 50%,var(--line));background:#0a0e27cc}.top-nav-trophies:focus-visible{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 1px var(--accent-cyan)}.top-nav-trophy{font-size:1rem;line-height:1}.top-nav-trophy-star{color:#ffd84d;text-shadow:0 0 .4rem rgba(255,216,77,.65);margin-right:.05rem}.top-nav-trophy-cup{color:#ffb13b;margin-left:.4rem;margin-right:.05rem}.top-nav-trophy-crown{color:#c79bff;text-shadow:0 0 .4rem rgba(199,155,255,.6);margin-left:.4rem;margin-right:.05rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.125rem;border-radius:var(--radius-md);border:1px solid var(--line);background:var(--bg-elev);color:var(--text);font-weight:600;letter-spacing:.02em;transition:all .15s ease;font-size:.9rem;min-height:2.75rem}.btn:hover{border-color:var(--accent-cyan);background:var(--bg-elev-2);box-shadow:var(--shadow-glow-cyan)}.btn-primary{background:linear-gradient(135deg,var(--accent-magenta),var(--accent-violet));border-color:transparent;color:#fff}.btn-primary:hover{box-shadow:var(--shadow-glow-magenta);filter:brightness(1.1)}.btn-ghost{background:transparent;border-color:var(--line-soft)}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:#ff3b5c1a}.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}.card{background:var(--bg-elev);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:1.25rem}.card:hover{border-color:var(--line)}.glow-text{text-shadow:0 0 .75rem currentColor}.muted{color:var(--text-muted)}.faint{color:var(--text-faint)}.error-box{background:#ff3b5c1a;border:1px solid var(--danger);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--danger);font-size:.9rem}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:50dvh;flex-direction:column;gap:1rem;color:var(--text-muted)}
