@import"https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&family=Inter:wght@400;500;600;700&display=swap";.topbar{position:sticky;top:0;z-index:40;background:color-mix(in oklab,var(--bg) 82%,transparent);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--border)}.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:56px;gap:var(--s-3)}.brand{display:inline-flex;align-items:center;gap:var(--s-2);color:var(--text);text-decoration:none;font-weight:700;letter-spacing:.12em}.brand-mark{color:var(--accent);font-size:1.1rem}html[data-theme=hud] .brand-mark{text-shadow:0 0 12px var(--accent)}.brand-logo{width:26px;height:26px;object-fit:contain;display:block}html[data-theme=hud] .brand-logo{filter:drop-shadow(0 0 8px rgba(0,255,213,.35))}.brand-name{font-size:.9rem}.topbar-title{font-size:.9rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main{flex:1;padding:var(--s-5) 0 var(--s-8);min-height:0}.arcade-footer{border-top:1px solid var(--border);background:color-mix(in oklab,var(--bg) 80%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--s-4) 0 calc(var(--s-4) + env(safe-area-inset-bottom));font-size:.85rem;color:var(--text-dim);margin-top:var(--s-5);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);flex-wrap:wrap}.footer-left .heart{color:var(--accent-2)}.bb-link{color:var(--accent);font-weight:600;text-decoration:none;border-bottom:1px dashed color-mix(in oklab,var(--accent) 50%,transparent)}.bb-link:hover{border-bottom-style:solid}.footer-right{display:flex;gap:var(--s-4)}.footer-link{color:var(--text-dim);text-decoration:none}.footer-link:hover{color:var(--text)}@media (max-width: 480px){.footer-inner{justify-content:center;text-align:center;flex-direction:column;gap:var(--s-2)}}.token-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:color-mix(in oklab,var(--accent) 10%,transparent);color:var(--text);font-weight:700;font-size:.9rem;line-height:1;white-space:nowrap}.token-chip-icon{font-size:1rem}.token-chip-bal{font-variant-numeric:tabular-nums}.token-toast-stack{position:fixed;left:50%;bottom:24px;transform:translate(-50%);display:flex;flex-direction:column;gap:var(--s-2);z-index:80;pointer-events:none}.token-toast{pointer-events:auto;display:inline-flex;align-items:center;gap:var(--s-3);padding:12px 18px;border-radius:14px;border:1px solid var(--border);background:color-mix(in oklab,var(--bg) 90%,var(--accent) 10%);color:var(--text);box-shadow:0 10px 40px #00000059,0 0 24px color-mix(in oklab,var(--accent) 35%,transparent);cursor:pointer;animation:tokenToastIn .3s ease-out;font:inherit;text-align:left}.token-toast-icon{font-size:1.5rem}.token-toast-body{display:flex;flex-direction:column;gap:2px}.token-toast-title{font-weight:700}.token-toast-sub{font-size:.85rem;color:var(--text-dim)}@keyframes tokenToastIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.lb{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.lb-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.lb-row.is-self{border-color:var(--accent);background:var(--accent-soft)}.lb-rank{width:32px;color:var(--text-faint);font-size:.85rem;font-weight:600}.lb-row.is-self .lb-rank{color:var(--accent)}.lb-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-name-link{color:inherit;text-decoration:none;transition:color var(--dur-1) var(--ease)}.lb-name-link:hover{color:var(--accent);text-decoration:underline}.lb-score{font-weight:600;color:var(--text)}html[data-theme=hud] .lb-score{color:var(--accent)}.lb-compact .lb-row{padding:var(--s-2) var(--s-3)}.lb-empty{padding:var(--s-5);text-align:center}.sharecard{display:flex;flex-direction:column;gap:var(--s-3);align-items:center}.sharecard-preview{width:100%;max-width:240px;aspect-ratio:4 / 5;height:auto;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-1)}.sharecard-actions{display:flex;gap:var(--s-2);flex-wrap:wrap;justify-content:center}.ob-modal{max-width:560px;display:flex;flex-direction:column;gap:var(--s-4)}.ob-demo{position:relative;margin:calc(-1 * var(--s-4, 16px)) calc(-1 * var(--s-4, 16px)) 0;border-radius:var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0;overflow:hidden}.ob-demo .demo-scene{height:200px;border:none;border-radius:0}.ob-demo-loading{height:200px;background:var(--surface)}.ob-demo-label{position:absolute;top:8px;right:10px;font-size:.6rem;letter-spacing:.14em;color:var(--text-dim);opacity:.5;pointer-events:none}@media (max-width: 480px){.ob-demo .demo-scene{height:160px}}.ob-head{display:flex;align-items:center;gap:var(--s-3)}.ob-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0}.ob-head-text{display:flex;flex-direction:column;gap:2px;min-width:0}.ob-kicker{font-size:.7rem;letter-spacing:.12em;color:var(--accent)}.ob-title{font-size:1.4rem;margin:0}.ob-tagline{font-size:.9rem}.ob-goal{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem}.ob-goal-label{font-size:.7rem;letter-spacing:.12em;color:var(--accent);flex-shrink:0}.ob-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-2)}.ob-step{display:flex;align-items:flex-start;gap:var(--s-3);padding:var(--s-3);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.ob-step-num{font-size:.85rem;color:var(--accent);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 6px);padding:2px 8px;flex-shrink:0;line-height:1.4}.ob-step-text{font-size:.95rem;color:var(--text);line-height:1.45}.ob-tips{display:flex;flex-direction:column;gap:var(--s-2)}.ob-tip-list{margin:0;padding-left:var(--s-5);color:var(--text-dim);font-size:.9rem;display:flex;flex-direction:column;gap:4px}.ob-actions{display:flex;flex-direction:column;gap:var(--s-2);align-items:stretch}.ob-hint{font-size:.78rem;text-align:center}@media (max-width: 480px){.ob-title{font-size:1.2rem}.ob-icon{width:48px;height:48px;font-size:1.5rem}}.demo-scene{width:100%;height:180px;border-radius:var(--radius);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);position:relative}@media (max-width: 480px){.demo-scene{height:150px}}.demo-flip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;width:140px;perspective:400px}.demo-flip-tile{aspect-ratio:1;perspective:200px}.demo-flip-tile-inner{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .4s ease;border-radius:4px}.demo-flip-tile.flipped .demo-flip-tile-inner{transform:rotateY(180deg)}.demo-flip-tile-front{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;backface-visibility:hidden}.demo-flip-tile.pattern .demo-flip-tile-front{background:var(--accent);box-shadow:0 0 10px var(--accent)}.demo-flip-tile-back{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;backface-visibility:hidden;transform:rotateY(180deg)}.demo-flip-tile-back.hit{background:#34d399;box-shadow:0 0 8px #34d39966}.demo-flip-tile-back.miss{background:var(--surface-3)}.demo-stack-tower{display:flex;flex-direction:column-reverse;align-items:center;width:120px;height:160px;justify-content:flex-start}.demo-stack-block{height:16px;min-width:20px;background:linear-gradient(135deg,var(--accent),#0ea5e9);border-radius:2px;margin-top:1px;transition:width .3s ease}.demo-stack-block.sliding{animation:demo-stack-slide .6s ease-in-out infinite alternate}@keyframes demo-stack-slide{0%{transform:translate(-20px)}to{transform:translate(20px)}}.demo-odd-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;width:140px}.demo-odd-tile{aspect-ratio:1;border-radius:4px;transition:all .3s ease}.demo-odd-tile.found{transform:scale(1.2);box-shadow:0 0 14px #ffffff80;border:2px solid white}.demo-kick-field{position:relative;width:160px;height:160px}.demo-kick-post{position:absolute;bottom:10%;width:4px;height:55%;background:#e5e7eb;border-radius:2px}.demo-kick-post-l{left:25%}.demo-kick-post-r{right:25%}.demo-kick-bar{position:absolute;top:35%;left:25%;right:25%;height:4px;background:#e5e7eb;border-radius:2px}.demo-kick-ball{position:absolute;left:50%;width:14px;height:14px;margin-left:-7px;border-radius:50%;background:#fbbf24;transition:bottom .03s linear;box-shadow:0 0 8px #fbbf2480}.demo-kick-ball.good{box-shadow:0 0 18px #34d399b3;background:#34d399}.demo-kick-meter{position:absolute;bottom:6%;left:15%;right:15%;height:8px;background:var(--surface-3);border-radius:4px;overflow:hidden}.demo-kick-meter-fill{height:100%;border-radius:4px;animation:demo-kick-sweep .8s ease-in-out infinite alternate}.demo-kick-meter.power .demo-kick-meter-fill{background:#34d399}.demo-kick-meter.aim .demo-kick-meter-fill{background:#60a5fa;width:20%;animation:demo-kick-aim .7s ease-in-out infinite alternate}@keyframes demo-kick-sweep{0%{width:10%}to{width:90%}}@keyframes demo-kick-aim{0%{margin-left:0}to{margin-left:80%}}.demo-kick-label{position:absolute;top:18%;left:50%;transform:translate(-50%);font-weight:900;font-size:1.1rem;color:#34d399;text-shadow:0 0 12px #34d39966;animation:demo-kick-pop .4s ease}@keyframes demo-kick-pop{0%{transform:translate(-50%) scale(.5);opacity:0}to{transform:translate(-50%) scale(1);opacity:1}}.demo-react{flex-direction:column;gap:8px}.demo-react-combo{font-size:.72rem;letter-spacing:.12em;color:var(--accent)}.demo-react-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;width:130px}.demo-react-cell{aspect-ratio:1;border-radius:4px;background:var(--surface-2);border:1px solid var(--border);transition:all .15s ease}.demo-react-cell.target{background:#34d399;border-color:#34d399;box-shadow:0 0 10px #34d39966}.demo-react-cell.tapped{background:#34d399;transform:scale(.85);opacity:.5}.demo-snake-board{display:grid;grid-template-columns:repeat(var(--sw),1fr);grid-template-rows:repeat(var(--sh),1fr);width:170px;height:140px;gap:1px;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;position:relative}.demo-snake-seg{border-radius:2px;background:var(--accent);transition:all .15s ease}.demo-snake-seg.head{background:#fff;box-shadow:0 0 6px var(--accent)}.demo-snake-apple{border-radius:50%;background:#ef4444;box-shadow:0 0 8px #ef444466}.demo-rhythm-lanes{display:flex;width:130px;height:160px;gap:3px}.demo-rhythm-lane{flex:1;position:relative;background:var(--surface-2);border-radius:4px;overflow:hidden}.demo-rhythm-zone{position:absolute;bottom:0;left:0;right:0;height:18%;background:#ffffff0a;border-top:2px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.demo-rhythm-zone.hit{background:#34d39940;border-color:#34d399}.demo-rhythm-key{font-size:.6rem;letter-spacing:.1em;color:var(--text-dim);opacity:.6}.demo-rhythm-note{position:absolute;left:20%;right:20%;height:8px;border-radius:4px;background:var(--accent);box-shadow:0 0 6px var(--accent);transition:top .05s linear}.demo-lane-road{position:relative;width:120px;height:160px;background:#1a1a2e;border-radius:4px;overflow:hidden;display:flex}.demo-lane-col{flex:1;position:relative}.demo-lane-divider{position:absolute;right:0;top:0;bottom:0;width:1px;background:repeating-linear-gradient(to bottom,rgba(255,255,255,.15) 0px,rgba(255,255,255,.15) 10px,transparent 10px,transparent 20px);animation:demo-lane-scroll .6s linear infinite}@keyframes demo-lane-scroll{0%{transform:translateY(0)}to{transform:translateY(20px)}}.demo-lane-runner{position:absolute;bottom:12%;width:20px;height:26px;margin-left:-10px;background:var(--accent);border-radius:4px 4px 2px 2px;box-shadow:0 0 10px var(--accent);transition:left .25s ease;z-index:2}.demo-lane-obs{position:absolute;width:22px;height:22px;margin-left:-11px;background:#ef4444;border-radius:3px;box-shadow:0 0 6px #ef444466;z-index:1}.demo-lane-coin{position:absolute;width:12px;height:12px;margin-left:-6px;background:#fbbf24;border-radius:50%;box-shadow:0 0 6px #fbbf2466;z-index:1}.demo-hrd-field{position:relative;width:160px;height:160px}.demo-hrd-fence{position:absolute;top:30%;left:10%;right:10%;height:4px;background:#8b5e3c;border-radius:2px}.demo-hrd-mound{position:absolute;top:38%;left:50%;transform:translate(-50%);width:10px;height:6px;border-radius:50%;background:#c9a86c}.demo-hrd-batter{position:absolute;bottom:12%;left:56%;width:8px;height:22px;background:#444;border-radius:3px 3px 1px 1px}.demo-hrd-bat{position:absolute;top:4px;right:100%;width:22px;height:3px;background:linear-gradient(90deg,#b8860b,#daa520);border-radius:2px;transform-origin:right center;transform:rotate(-25deg);transition:transform .12s ease}.demo-hrd-batter.swung .demo-hrd-bat{transform:rotate(65deg)}.demo-hrd-ball{position:absolute;left:50%;width:10px;height:10px;margin-left:-5px;border-radius:50%;background:#fff;box-shadow:0 0 8px #fff9;transition:top .03s linear}.demo-hrd-ball.gone{opacity:0;transform:scale(.3);transition:all .3s ease}.demo-hrd-zone-hint{position:absolute;bottom:38%;left:50%;transform:translate(-50%);font-size:.6rem;letter-spacing:.12em;color:var(--text-dim);opacity:.6}.demo-hrd-label{position:absolute;top:18%;left:50%;transform:translate(-50%);font-weight:900;font-size:1.1rem;color:#34d399;text-shadow:0 0 12px #34d39966;animation:demo-kick-pop .4s ease}.demo-bt-court{position:relative;width:160px;height:160px;background:linear-gradient(180deg,#1a1225,#1a1225 50%,#8b6240 50%,#8b6240);border-radius:4px;overflow:hidden}.demo-bt-backboard{position:absolute;top:18%;right:12%;width:24px;height:18px;background:#ffffff1f;border:1.5px solid rgba(255,255,255,.25);border-radius:2px}.demo-bt-rim{position:absolute;top:36%;right:14%;width:18px;height:3px;background:#ea580c;border-radius:2px;box-shadow:0 0 6px #ea580c66}.demo-bt-shooter{position:absolute;bottom:12%;left:14%;width:10px;height:28px;background:#1d4ed8;border-radius:4px 4px 1px 1px}.demo-bt-shooter:before{content:"";position:absolute;top:-7px;left:50%;transform:translate(-50%);width:9px;height:9px;border-radius:50%;background:#c68642}.demo-bt-ball{position:absolute;width:12px;height:12px;margin-left:-6px;margin-top:-6px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#f59e0b,#ea580c);box-shadow:0 0 6px #f59e0b80;transition:left .04s linear,top .04s linear}.demo-bt-ball.good{box-shadow:0 0 14px #34d399b3;background:radial-gradient(circle at 35% 35%,#34d399,#059669)}.demo-bt-meter{position:absolute;bottom:5%;left:12%;right:12%;height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden}.demo-bt-meter-fill{height:100%;border-radius:3px}.demo-bt-meter.power .demo-bt-meter-fill{background:#34d399;animation:demo-kick-sweep .8s ease-in-out infinite alternate}.demo-bt-meter.aim .demo-bt-meter-fill{background:#60a5fa;width:20%;animation:demo-kick-aim .7s ease-in-out infinite alternate}.demo-bt-label{position:absolute;top:42%;left:50%;transform:translate(-50%);font-weight:900;font-size:1rem;color:#34d399;text-shadow:0 0 12px #34d39966;animation:demo-kick-pop .4s ease}.level-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--s-2)}.level-card{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:var(--s-3);align-items:baseline;padding:var(--s-3) var(--s-4);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);text-align:left;transition:border-color var(--dur-1) var(--ease),transform var(--dur-1) var(--ease);min-height:var(--tap)}.level-card:hover{border-color:var(--accent);transform:translateY(-1px)}.level-num{color:var(--accent);font-weight:700;grid-row:1 / span 2;align-self:center;font-size:.85rem}.level-name{font-weight:600}.level-meta{font-size:.72rem;letter-spacing:.08em}.hud{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-2);margin-bottom:var(--s-2)}.timer-bar{height:22px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);position:relative;overflow:hidden;margin-bottom:var(--s-3)}.timer-fill{position:absolute;top:0;bottom:0;left:0;width:100%;background:linear-gradient(90deg,var(--success),var(--accent));transition:width 1s linear;border-radius:var(--radius-pill)}.timer-mid .timer-fill{background:linear-gradient(90deg,var(--warning),var(--accent-2))}.timer-low .timer-fill{background:var(--danger);animation:pulse 1s infinite}.timer-txt{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:.78rem;font-weight:700;color:var(--text);letter-spacing:.1em;text-shadow:0 1px 2px rgba(0,0,0,.6);font-variant-numeric:tabular-nums}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.board-wrap{position:relative;display:flex;justify-content:center;align-items:center;margin:var(--s-7) 0 var(--s-3)}.phase-tag{position:absolute;top:calc(-1 * var(--s-6));left:50%;transform:translate(-50%);z-index:5;white-space:nowrap}.top-right-tags{position:absolute;top:calc(-1 * var(--s-6));right:var(--s-3);display:flex;gap:var(--s-2);z-index:5}.board-3d{width:min(96vw,560px);aspect-ratio:1 / 1;position:relative}.board-3d canvas{display:block;width:100%!important;height:100%!important;border-radius:var(--radius-lg)}.board-2d{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--s-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.row-2d{display:flex;gap:4px;justify-content:center}.powerup-rail{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(76px,1fr);gap:var(--s-2);padding:var(--s-2);background:color-mix(in oklab,var(--bg) 70%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius-lg);margin:var(--s-4) auto 0;max-width:100%;overflow-x:auto;scrollbar-width:none}.powerup-rail::-webkit-scrollbar{display:none}.pu-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--s-2) var(--s-2);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;transition:border-color var(--dur-1) var(--ease),transform var(--dur-1) var(--ease),background var(--dur-1) var(--ease);position:relative;min-height:64px;-webkit-tap-highlight-color:transparent}.pu-btn:hover:not(:disabled){border-color:var(--accent);background:var(--accent-soft)}.pu-btn:active:not(:disabled){transform:scale(.95)}.pu-btn:disabled{opacity:.35;cursor:not-allowed}.pu-ico{font-size:1.25rem;line-height:1}.pu-lbl{font-size:.68rem;letter-spacing:.04em;color:var(--text-dim);font-weight:600}.pu-btn:hover:not(:disabled) .pu-lbl{color:var(--text)}.pu-count{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 4px;display:grid;place-items:center;background:var(--accent);color:var(--btn-primary-text);font-size:.65rem;font-weight:800;border-radius:var(--radius-pill);font-family:var(--font-mono)}.pu-btn:disabled .pu-count{background:var(--surface-3);color:var(--text-faint)}.pu-pause{background:var(--surface-2)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-2)}html[data-theme=minimal] .tile{background:linear-gradient(135deg,var(--accent),var(--accent-2))}html[data-theme=minimal] .tile.flipped{background:linear-gradient(135deg,var(--success),#1b9e4b)}html[data-theme=minimal] .tile.wrong{background:linear-gradient(135deg,var(--danger),#c0392b)}@media (max-width: 480px){.hud{grid-template-columns:repeat(2,1fr)}}.cs-board{position:relative;min-height:560px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation}.cs-board .board-3d{min-height:560px;border-radius:var(--radius-lg);overflow:hidden}.cs-board .phase-tag{position:absolute;top:calc(-1 * var(--s-6));left:50%;transform:translate(-50%);z-index:2}.cs-board .top-right-tags{position:absolute;top:var(--s-3);right:var(--s-3);z-index:2;display:flex;gap:var(--s-2)}@media (max-width: 640px){.cs-board,.cs-board .board-3d{min-height:440px}}.ooo-board{position:relative;-webkit-user-select:none;user-select:none;touch-action:manipulation}.ooo-grid{display:grid;gap:var(--s-2);width:100%;max-width:520px;margin:0 auto;aspect-ratio:1 / 1}.ooo-tile{border:none;border-radius:var(--radius-md);cursor:pointer;padding:0;transition:transform .12s ease,box-shadow .12s ease;box-shadow:inset 0 0 0 1px #ffffff14,0 2px 8px #00000040}.ooo-tile:hover{transform:scale(1.04)}.ooo-tile:active{transform:scale(.96)}.ooo-tile.correct{animation:ooo-pop .26s ease}.ooo-tile.wrong{animation:ooo-shake .36s ease}@keyframes ooo-pop{0%{transform:scale(1)}50%{transform:scale(1.18);box-shadow:0 0 0 4px var(--accent)}to{transform:scale(1)}}@keyframes ooo-shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.ooo-timer-bar{height:6px;background:#ffffff14;border-radius:999px;overflow:hidden}.ooo-timer-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--warning, #f59e0b));transition:width .2s linear}.ooo-timer-fill.low{background:var(--danger, #ef4444)}.ooo-flash{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;border-radius:var(--radius-lg);opacity:0}.ooo-flash.on-correct{animation:ooo-flash-green .3s ease}.ooo-flash.on-wrong{animation:ooo-flash-red .3s ease}@keyframes ooo-flash-green{0%{opacity:0;box-shadow:inset 0 0 #22c55e00}30%{opacity:1;box-shadow:inset 0 0 80px #22c55e59}to{opacity:0}}@keyframes ooo-flash-red{0%{opacity:0}30%{opacity:1;box-shadow:inset 0 0 80px #ef444459}to{opacity:0}}.ak-field{position:relative;width:100%;max-width:560px;margin:0 auto;aspect-ratio:3 / 4;max-height:55vh;border-radius:var(--radius-lg);overflow:hidden;background:#0a2818;box-shadow:inset 0 0 0 1px #ffffff0f,0 12px 40px #0006;-webkit-user-select:none;user-select:none;touch-action:manipulation}@media (min-width: 900px){.ak-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:var(--s-4);align-items:start}.ak-field{max-width:none;max-height:78vh;margin:0}.ak-side{display:flex;flex-direction:column;gap:var(--s-3)}}.ak-sky{position:absolute;top:0;left:0;right:0;height:35%;background:linear-gradient(180deg,#050a14,#0c1a30,#142840);pointer-events:none}.ak-sky:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:radial-gradient(ellipse 8% 30% at 15% 5%,rgba(255,240,180,.35) 0%,transparent 100%),radial-gradient(ellipse 8% 30% at 85% 5%,rgba(255,240,180,.35) 0%,transparent 100%),radial-gradient(ellipse 6% 20% at 35% 8%,rgba(255,240,180,.2) 0%,transparent 100%),radial-gradient(ellipse 6% 20% at 65% 8%,rgba(255,240,180,.2) 0%,transparent 100%);pointer-events:none}.ak-sky:after{content:"";position:absolute;bottom:-40%;left:50%;transform:translate(-50%);width:120%;height:80%;background:radial-gradient(ellipse at 20% 0%,rgba(255,240,180,.04) 0%,transparent 60%),radial-gradient(ellipse at 80% 0%,rgba(255,240,180,.04) 0%,transparent 60%);pointer-events:none}.ak-stands{position:absolute;top:0;left:0;right:0;height:38%;pointer-events:none;overflow:hidden}.ak-stands:before{content:"";position:absolute;top:15%;left:0;right:0;height:70%;background:linear-gradient(180deg,#080e1a,#0e1828,#142030 60%,#0e1828)}.ak-stands:after{content:"";position:absolute;bottom:0;left:0;right:0;height:50%;background:radial-gradient(ellipse 8px 9px at 5% 80%,#1a2838 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 12% 76%,#202e40 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 19% 82%,#182636 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 26% 78%,#222e42 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 33% 80%,#1a2838 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 40% 76%,#202e40 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 47% 83%,#182636 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 54% 78%,#222e42 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 61% 81%,#1a2838 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 68% 77%,#202e40 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 75% 82%,#182636 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 82% 79%,#222e42 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 89% 81%,#1a2838 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 96% 77%,#202e40 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 8% 52%,#141e2e 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 16% 48%,#1a2636 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 24% 54%,#161e30 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 32% 50%,#1c2838 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 40% 52%,#141e2e 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 48% 49%,#1a2636 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 56% 53%,#161e30 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 64% 50%,#1c2838 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 72% 54%,#141e2e 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 80% 48%,#1a2636 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 88% 52%,#161e30 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 6% 28%,#101a26 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 14% 25%,#141e2c 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 22% 30%,#121c28 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 30% 27%,#161e2e 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 38% 29%,#101a26 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 46% 26%,#141e2c 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 54% 30%,#121c28 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 62% 27%,#161e2e 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 70% 29%,#101a26 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 78% 26%,#141e2c 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 86% 30%,#121c28 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 94% 27%,#161e2e 70%,transparent 71%)}.ak-field-turf{position:absolute;bottom:0;left:0;right:0;height:52%;background:linear-gradient(180deg,#0f4020,#14522a,#186630 60%,#1a7636);pointer-events:none;clip-path:polygon(10% 0%,90% 0%,100% 100%,0% 100%)}.ak-field-turf:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(180deg,rgba(255,255,255,.03) 0px,rgba(255,255,255,.03) 2px,transparent 2px,transparent 24px)}.ak-field-turf:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 50% 30% at 50% 30%,rgba(255,255,255,.04) 0%,transparent 100%),linear-gradient(180deg,#ffffff08,#00000014)}.ak-yardlines{position:absolute;bottom:0;left:0;right:0;height:52%;pointer-events:none;clip-path:polygon(10% 0%,90% 0%,100% 100%,0% 100%);background-image:repeating-linear-gradient(to top,rgba(255,255,255,.12) 0px,rgba(255,255,255,.12) 2px,transparent 2px,transparent 52px)}.ak-goalposts{position:absolute;top:8%;left:50%;transform:translate(-50%);width:160px;height:150px;pointer-events:none;z-index:3}.ak-gp-base{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:8px;height:78px;background:linear-gradient(90deg,#c4a020,#fbbf24 40%,#eab308 60%,#c4a020);border-radius:4px;box-shadow:2px 0 6px #0000004d}.ak-gp-crossbar{position:absolute;bottom:76px;left:50%;transform:translate(-50%);width:130px;height:8px;background:linear-gradient(180deg,#fbbf24,#eab308,#c4a020);border-radius:4px;box-shadow:0 2px 6px #0000004d}.ak-gp-upright{position:absolute;width:7px;height:72px;background:linear-gradient(90deg,#c4a020,#fbbf24 40%,#eab308 60%,#c4a020);border-radius:4px 4px 0 0;box-shadow:1px 0 4px #00000040}.ak-gp-upright:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:12px;height:10px;background:#f97316;border-radius:4px}.ak-gp-l{bottom:76px;left:50%;margin-left:-68px}.ak-gp-r{bottom:76px;right:50%;margin-right:-68px}.ak-foot{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:80px;height:50px;pointer-events:none;z-index:4}.ak-foot:before{content:"";position:absolute;bottom:20px;left:50%;transform:translate(-50%);width:26px;height:40px;background:linear-gradient(180deg,#1a1a1a,#222 60%,#1a1a1a);border-radius:8px 8px 0 0}.ak-foot:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40px;height:22px;background:linear-gradient(180deg,#1a1a1a,#111 70%,#0a0a0a);border-radius:8px 8px 4px 4px;box-shadow:0 -2px 4px #0000004d}.ak-ball{position:absolute;width:28px;height:38px;border-radius:50% 50% 45% 45%/60% 60% 40% 40%;background:radial-gradient(ellipse at 35% 30%,#b87a42,#8b5a28,#6b3a18);box-shadow:inset 0 -4px 8px #00000059,inset 0 2px 4px #c8966426,0 4px 10px #0006;transform-origin:50% 50%;will-change:transform,left,top;z-index:5}.ak-ball:before{content:"";position:absolute;top:50%;left:18%;right:18%;height:2px;background:#e8d5b5;transform:translateY(-1px)}.ak-ball:after{content:"";position:absolute;top:30%;bottom:30%;left:50%;width:2px;background:#e8d5b5;transform:translate(-1px);box-shadow:-5px 0 #e8d5b5,5px 0 #e8d5b5}.ak-ball.flying{filter:drop-shadow(0 6px 12px rgba(0,0,0,.35))}.ak-trail{position:absolute;width:16px;height:16px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.45),transparent);pointer-events:none;animation:ak-trail-fade .3s ease-out forwards}@keyframes ak-trail-fade{0%{opacity:.7}to{opacity:0}}.ak-wind{position:absolute;top:var(--s-3);right:var(--s-3);padding:6px 10px;border-radius:var(--radius-pill);background:#0000008c;color:#fff;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;pointer-events:none;z-index:8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ak-distance-chip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:6px 14px;border-radius:var(--radius-pill);background:#00000073;color:#fff;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.08em;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ak-result{position:absolute;top:36%;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-weight:700;font-size:1.6rem;letter-spacing:.12em;padding:10px 22px;border-radius:var(--radius-pill);pointer-events:none;opacity:0;animation:ak-pop .9s ease forwards;white-space:nowrap;z-index:10;text-shadow:0 1px 4px rgba(0,0,0,.3)}.ak-result.good{background:#22c55eeb;color:#052e16}.ak-result.miss{background:#ef4444eb;color:#fff}@keyframes ak-pop{0%{opacity:0;transform:translate(-50%,10px) scale(.8)}20%{opacity:1;transform:translate(-50%) scale(1.05)}80%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-6px) scale(1)}}.ak-field.shake{animation:ak-shake .22s ease}@keyframes ak-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px,2px)}50%{transform:translate(2px,-2px)}75%{transform:translate(-2px,1px)}}.ak-meter{position:relative;width:100%;height:22px;border-radius:var(--radius-pill);background:#ffffff14;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0f}.ak-meter-track{position:absolute;top:0;right:0;bottom:0;left:0}.ak-meter-zone{position:absolute;top:0;bottom:0;background:#22c55e59;border-left:2px solid rgba(34,197,94,.9);border-right:2px solid rgba(34,197,94,.9)}.ak-meter-zone.perfect{background:#eab30873;border-color:#eab308f2}.ak-meter-needle{position:absolute;top:-4px;bottom:-4px;width:4px;background:var(--accent, #fff);border-radius:2px;box-shadow:0 0 8px #ffffff80;transform:translate(-50%)}.ak-meter-label{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim);letter-spacing:.08em;margin-bottom:2px}.ak-controls{display:flex;flex-direction:column;gap:var(--s-3)}.ak-lives{display:inline-flex;gap:4px}.ak-life{width:12px;height:12px;border-radius:50%;background:#ef4444;box-shadow:0 0 0 2px #0003 inset}.ak-life.out{background:transparent;box-shadow:inset 0 0 0 2px #ef444459}.rg-board{position:relative;width:100%;max-width:520px;margin:0 auto;aspect-ratio:1 / 1;-webkit-user-select:none;user-select:none;touch-action:manipulation}.rg-grid{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);gap:var(--s-2)}.rg-cell{position:relative;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:background .12s ease,transform 80ms ease}.rg-cell:active{transform:scale(.97)}.rg-target{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(1);border-radius:50%;background:radial-gradient(circle at 35% 30%,#86efac,#22c55e 60%,#166534);box-shadow:0 0 24px #22c55ea6,inset 0 0 12px #0003;animation:rg-pop-in .14s ease-out;pointer-events:none}.rg-target.decoy{background:radial-gradient(circle at 35% 30%,#fca5a5,#ef4444 55%,#7f1d1d);box-shadow:0 0 24px #ef4444a6,inset 0 0 12px #0003}.rg-target.tiny{width:38%;height:38%}.rg-target.small{width:52%;height:52%}.rg-target.med{width:66%;height:66%}.rg-target.big{width:80%;height:80%}.rg-target.fading{animation:rg-fade-out .18s ease-out forwards}@keyframes rg-pop-in{0%{transform:translate(-50%,-50%) scale(.2);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes rg-fade-out{to{transform:translate(-50%,-50%) scale(.4);opacity:0}}.rg-target-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:2px solid rgba(255,255,255,.4);pointer-events:none;animation:rg-ring .6s linear forwards}@keyframes rg-ring{0%{width:10%;height:10%;opacity:.8}to{width:110%;height:110%;opacity:0}}.rg-burst{position:absolute;top:50%;left:50%;width:12px;height:12px;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%)}.rg-burst.good{background:#86efac;box-shadow:0 0 24px #22c55e;animation:rg-burst-good .48s ease-out forwards}.rg-burst.bad{background:#fecaca;box-shadow:0 0 24px #ef4444;animation:rg-burst-bad .48s ease-out forwards}@keyframes rg-burst-good{0%{transform:translate(-50%,-50%) scale(.4);opacity:1}to{transform:translate(-50%,-50%) scale(5);opacity:0}}@keyframes rg-burst-bad{0%{transform:translate(-50%,-50%) scale(.4);opacity:1}60%{transform:translate(-50%,-50%) scale(3);opacity:.6}to{transform:translate(-50%,-50%) scale(4);opacity:0}}.rg-float{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-weight:800;font-size:1rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6);pointer-events:none;animation:rg-float .8s ease-out forwards;white-space:nowrap}.rg-float.good{color:#bbf7d0}.rg-float.bad{color:#fecaca}@keyframes rg-float{0%{transform:translate(-50%,-40%) scale(.9);opacity:0}15%{transform:translate(-50%,-55%) scale(1.1);opacity:1}to{transform:translate(-50%,-120%) scale(1);opacity:0}}.rg-timer-bar{height:6px;background:#ffffff14;border-radius:999px;overflow:hidden}.rg-timer-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--warning, #f59e0b));transition:width .1s linear}.rg-timer-fill.low{background:var(--danger, #ef4444);animation:rg-low-pulse .6s ease-in-out infinite}@keyframes rg-low-pulse{0%,to{opacity:1}50%{opacity:.55}}.rg-combo{position:absolute;top:var(--s-3);right:var(--s-3);padding:6px 10px;border-radius:var(--radius-pill);background:#00000073;color:#fff;font-family:var(--font-mono);font-size:.85rem;font-weight:800;letter-spacing:.06em;pointer-events:none;transition:transform .12s ease}.rg-combo.bump{transform:scale(1.25)}.rg-combo.hot{background:#ea580cd9;box-shadow:0 0 20px #ea580cb3}.rg-combo.fire{background:#dc2626e6;box-shadow:0 0 28px #ef4444cc}.rg-lives{display:inline-flex;gap:4px}.rg-life{width:12px;height:12px;border-radius:50%;background:#ef4444;box-shadow:0 0 8px #ef444499}.rg-life.out{background:transparent;box-shadow:inset 0 0 0 2px #ef444459}.rg-level-flash{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;font-family:var(--font-mono);font-size:2.2rem;font-weight:900;letter-spacing:.14em;color:var(--accent);text-shadow:0 0 32px var(--accent);animation:rg-level 1s ease-out forwards}@keyframes rg-level{0%{opacity:0;transform:scale(.7)}15%{opacity:1;transform:scale(1.15)}60%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.05)}}.rg-board.shake{animation:rg-shake .24s ease}@keyframes rg-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px,2px)}50%{transform:translate(3px,-3px)}80%{transform:translate(-2px,2px)}}.snk-wrap{display:flex;flex-direction:column;gap:var(--s-3);align-items:center}.snk-board{position:relative;width:100%;max-width:520px;aspect-ratio:1 / 1;border-radius:var(--radius-lg);background:repeating-linear-gradient(0deg,rgba(255,255,255,.02) 0 1px,transparent 1px 40px),repeating-linear-gradient(90deg,rgba(255,255,255,.02) 0 1px,transparent 1px 40px),radial-gradient(ellipse at center,#0c1b24,#05090e);box-shadow:inset 0 0 0 1px var(--border),0 12px 40px #0006;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none}.snk-grid{position:absolute;top:0;right:0;bottom:0;left:0;display:grid}.snk-cell{position:relative}.snk-seg{position:absolute;top:6%;right:6%;bottom:6%;left:6%;border-radius:22%;background:linear-gradient(160deg,#22c55e,#15803d);box-shadow:inset 0 -2px #00000040,inset 0 2px #ffffff2e,0 0 10px #22c55e59}.snk-seg.head{background:linear-gradient(160deg,#86efac,#16a34a);box-shadow:inset 0 -2px #00000040,inset 0 2px #ffffff4d,0 0 18px #86efac99}.snk-seg.head:before,.snk-seg.head:after{content:"";position:absolute;width:18%;height:18%;background:#000;border-radius:50%;top:28%}.snk-seg.head.face-up:before{top:18%;left:28%}.snk-seg.head.face-up:after{top:18%;right:28%;left:auto}.snk-seg.head.face-down:before{bottom:18%;top:auto;left:28%}.snk-seg.head.face-down:after{bottom:18%;top:auto;right:28%;left:auto}.snk-seg.head.face-left:before{top:28%;left:18%}.snk-seg.head.face-left:after{bottom:28%;top:auto;left:18%}.snk-seg.head.face-right:before{top:28%;right:18%;left:auto}.snk-seg.head.face-right:after{bottom:28%;top:auto;right:18%;left:auto}.snk-food{position:absolute;top:12%;right:12%;bottom:12%;left:12%;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fca5a5,#ef4444 60%,#7f1d1d);box-shadow:0 0 16px #ef444480;animation:snk-food-bob 1.4s ease-in-out infinite}.snk-food.gold{background:radial-gradient(circle at 35% 30%,#fde68a,#fbbf24 55%,#92400e);box-shadow:0 0 22px #fbbf24bf}@keyframes snk-food-bob{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.snk-hud{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-2);width:100%;max-width:520px}.snk-dpad{display:grid;grid-template-columns:52px 52px 52px;grid-template-rows:52px 52px 52px;grid-template-areas:".  up ." "lf .  rt" ".  dn .";gap:4px}.snk-dpad .dp{width:52px;height:52px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border-bright);color:var(--text);font-size:1.1rem;display:grid;place-items:center;touch-action:manipulation;padding:0}.snk-dpad .dp:active{background:var(--surface-3);transform:scale(.95)}.snk-dpad .up{grid-area:up}.snk-dpad .dn{grid-area:dn}.snk-dpad .lf{grid-area:lf}.snk-dpad .rt{grid-area:rt}@media (min-width: 720px){.snk-dpad{display:none}}.snk-hint{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;color:var(--text-dim);text-align:center}.snk-speedflash{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;font-family:var(--font-mono);font-size:1.8rem;font-weight:900;letter-spacing:.14em;color:var(--accent);text-shadow:0 0 24px var(--accent);animation:snk-flash .9s ease-out forwards}@keyframes snk-flash{0%{opacity:0;transform:scale(.7)}20%{opacity:1;transform:scale(1.1)}70%{opacity:1;transform:scale(1)}to{opacity:0}}.snk-paused{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0009;color:#fff;font-family:var(--font-mono);letter-spacing:.16em;font-size:1.2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rt-stage{position:relative;width:100%;max-width:520px;margin:0 auto;height:min(62vh,640px);border-radius:var(--radius-lg);overflow:hidden;background:radial-gradient(ellipse at 50% 0%,rgba(255,46,126,.15),transparent 55%),linear-gradient(180deg,#070912,#0c0f1e);border:1px solid var(--border);-webkit-user-select:none;user-select:none;touch-action:manipulation}.rt-lanes{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(4,1fr);gap:2px}.rt-lane{position:relative;cursor:pointer;background:linear-gradient(180deg,#ffffff05,#ffffff0a);border-left:1px solid rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.04);overflow:hidden}.rt-lane:active .rt-lane-glow{opacity:.7}.rt-lane-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 55%,var(--lane-hue) 100%);opacity:.18;pointer-events:none;transition:opacity 90ms ease;mix-blend-mode:screen}.rt-note{position:absolute;left:10%;right:10%;height:10%;border-radius:10px;background:radial-gradient(circle at 50% 40%,#fff 0%,var(--lane-hue) 60%,rgba(0,0,0,.6) 100%);box-shadow:0 0 18px var(--lane-hue),inset 0 0 8px #fff6;transform:translateY(-50%);pointer-events:none}.rt-hitline{position:absolute;left:0;right:0;bottom:12%;height:4px;background:var(--lane-hue);box-shadow:0 0 18px var(--lane-hue),0 0 4px #fff;opacity:.9;pointer-events:none}.rt-key-hint{position:absolute;left:50%;bottom:3%;transform:translate(-50%);font-size:1rem;color:var(--lane-hue);text-shadow:0 0 8px var(--lane-hue);letter-spacing:.12em;pointer-events:none;opacity:.85}.rt-float{position:absolute;left:50%;bottom:22%;transform:translate(-50%);font-weight:700;font-size:.9rem;letter-spacing:.08em;pointer-events:none;animation:rt-float .6s ease-out forwards;white-space:nowrap}.rt-float.perfect{color:#fde68a;text-shadow:0 0 12px #fbbf24}.rt-float.great{color:#86efac;text-shadow:0 0 10px #22c55e}.rt-float.good{color:#93c5fd;text-shadow:0 0 8px #3b82f6}.rt-float.bad{color:#fca5a5;text-shadow:0 0 8px #ef4444}.rt-float-center{position:absolute;left:50%;top:40%;transform:translate(-50%,-50%);font-weight:800;font-size:1.6rem;letter-spacing:.12em;pointer-events:none;animation:rt-float .5s ease-out forwards}.rt-float-center.bad{color:#fca5a5;text-shadow:0 0 16px #ef4444}@keyframes rt-float{0%{opacity:0;transform:translate(-50%) translateY(10px)}20%{opacity:1}to{opacity:0;transform:translate(-50%) translateY(-24px)}}.shake{animation:rt-shake .22s ease}@keyframes rt-shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.lr-stage{position:relative;width:100%;max-width:440px;margin:0 auto;height:min(68vh,680px);border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(180deg,#050810,#0a0f1f);border:1px solid var(--border);-webkit-user-select:none;user-select:none;touch-action:manipulation;--scroll-dur: 1s}.lr-road{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(175,82,222,.08) 0%,transparent 40%),repeating-linear-gradient(90deg,#0a0d18 0,#0a0d18 calc(100% / 3),#0c1022 calc(100% / 3),#0c1022 calc(200% / 3),#0a0d18 calc(200% / 3),#0a0d18);overflow:hidden}.lr-road-dashes{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(180deg,rgba(255,255,255,.6) 50%,transparent 50%),linear-gradient(180deg,rgba(255,255,255,.6) 50%,transparent 50%);background-size:4px 48px,4px 48px;background-repeat:repeat-y,repeat-y;background-position-x:calc(100% / 3 - 2px),calc(200% / 3 - 2px);background-position-y:0,0;opacity:.7;animation:lr-dash var(--scroll-dur) linear infinite;pointer-events:none}@keyframes lr-dash{0%{background-position-y:0,0}to{background-position-y:48px,48px}}.lr-divider{position:absolute;top:0;bottom:0;width:1px;background:#ffffff0d;pointer-events:none;transform:translate(-50%)}.lr-lane-tap{position:absolute;top:0;bottom:0;cursor:pointer;background:transparent;border:none;z-index:1}.lr-item{position:absolute;transform:translate(-50%,-50%);pointer-events:none;z-index:2;display:flex;align-items:center;justify-content:center;font-weight:800}.lr-car{position:absolute;transform:translate(-50%,-50%);pointer-events:none;width:40px;height:64px;border-radius:8px;background:linear-gradient(180deg,#ff3b3b,#b71a1a);box-shadow:0 0 20px #ff3b3b8c,inset 0 -6px 10px #0006,inset 0 6px 10px #ffffff26;border:1px solid rgba(255,255,255,.08)}.lr-car:before,.lr-car:after{content:"";position:absolute;left:4px;right:4px;height:12px;background:#00000080;border-radius:3px}.lr-car:before{top:10px;background:linear-gradient(180deg,#7dd3fc,#0ea5e9);opacity:.55}.lr-car:after{bottom:10px;background:linear-gradient(180deg,#0ea5e9,#7dd3fc);opacity:.35}.lr-player{width:44px;height:68px;background:linear-gradient(180deg,#00ffd5,#0891a7);box-shadow:0 0 28px #00ffd599,inset 0 -6px 10px #00000059,inset 0 6px 10px #ffffff40;z-index:3}.lr-player:before{background:linear-gradient(180deg,#fff,#bae6fd);opacity:.85}.lr-player:after{background:linear-gradient(180deg,#fde68a,#fbbf24);opacity:.7}.lr-player.invuln{animation:lr-blink .16s linear infinite}@keyframes lr-blink{0%,to{opacity:1}50%{opacity:.35}}.lr-coin{width:22px;height:22px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff7c2,#fbbf24 55%,#b45309);box-shadow:0 0 14px #fbbf24b3;color:#78350f;font-size:12px;line-height:1;border:1px solid rgba(255,255,255,.3)}.lr-float{position:absolute;transform:translate(-50%,-50%);font-weight:800;font-size:.95rem;letter-spacing:.08em;pointer-events:none;animation:lr-float .56s ease-out forwards;white-space:nowrap;z-index:4}.lr-float.gold{color:#fde68a;text-shadow:0 0 14px #fbbf24}.lr-float.bad{color:#fca5a5;text-shadow:0 0 14px #ef4444;font-size:1.6rem}@keyframes lr-float{0%{opacity:0;transform:translate(-50%,-30%)}20%{opacity:1}to{opacity:0;transform:translate(-50%,-90%)}}.lr-controls{position:absolute;left:0;right:0;bottom:var(--s-3);display:flex;justify-content:space-between;padding:0 var(--s-3);pointer-events:none;z-index:5}.lr-nav{pointer-events:auto;width:56px;height:56px;border-radius:50%;border:1px solid var(--border);background:#0a0e18b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--text);font-size:1.4rem;cursor:pointer;transition:transform var(--dur-1) var(--ease),background var(--dur-1) var(--ease)}.lr-nav:active{transform:scale(.92);background:#00ffd51f}@media (min-width: 720px){.lr-controls{display:none}}.hrd-field{position:relative;width:100%;max-width:560px;margin:0 auto;aspect-ratio:3 / 4;max-height:55vh;border-radius:var(--radius-lg);overflow:hidden;background:#1a6b30;box-shadow:inset 0 0 0 1px #ffffff0f,0 12px 40px #0006;-webkit-user-select:none;user-select:none;touch-action:manipulation}@media (min-width: 900px){.hrd-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:var(--s-4);align-items:start}.hrd-field{max-width:none;max-height:78vh;margin:0}.hrd-side{display:flex;flex-direction:column;gap:var(--s-3)}}.hrd-sky{position:absolute;top:0;left:0;right:0;height:30%;background:linear-gradient(180deg,#0c1e3c,#162d5a 40%,#1f4080,#2a5298);pointer-events:none}.hrd-sky:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(1px 1px at 15% 20%,rgba(255,255,255,.8),transparent),radial-gradient(1px 1px at 35% 12%,rgba(255,255,255,.6),transparent),radial-gradient(1px 1px at 55% 25%,rgba(255,255,255,.7),transparent),radial-gradient(1px 1px at 75% 15%,rgba(255,255,255,.5),transparent),radial-gradient(1px 1px at 88% 30%,rgba(255,255,255,.6),transparent),radial-gradient(3px 3px at 25% 8%,rgba(255,220,100,.9),transparent),radial-gradient(3px 3px at 75% 8%,rgba(255,220,100,.9),transparent)}.hrd-stands{position:absolute;top:24%;left:0;right:0;height:12%;background:radial-gradient(circle at 5% 90%,#2a2033 0 5px,transparent 6px),radial-gradient(circle at 11% 85%,#332838 0 5px,transparent 6px),radial-gradient(circle at 17% 92%,#2a2033 0 5px,transparent 6px),radial-gradient(circle at 23% 88%,#38283a 0 5px,transparent 6px),radial-gradient(circle at 29% 90%,#2a2033 0 5px,transparent 6px),radial-gradient(circle at 35% 86%,#332838 0 5px,transparent 6px),radial-gradient(circle at 41% 92%,#2a2033 0 5px,transparent 6px),radial-gradient(circle at 47% 87%,#38283a 0 5px,transparent 6px),radial-gradient(circle at 53% 91%,#332838 0 5px,transparent 6px),radial-gradient(circle at 59% 86%,#2a2033 0 5px,transparent 6px),radial-gradient(circle at 65% 90%,#38283a 0 5px,transparent 6px),radial-gradient(circle at 71% 88%,#2a2033 0 5px,transparent 6px),radial-gradient(circle at 77% 92%,#332838 0 5px,transparent 6px),radial-gradient(circle at 83% 87%,#2a2033 0 5px,transparent 6px),radial-gradient(circle at 89% 91%,#38283a 0 5px,transparent 6px),radial-gradient(circle at 95% 86%,#2a2033 0 5px,transparent 6px),linear-gradient(180deg,#1a1225,#221830);pointer-events:none}.hrd-wall{position:absolute;top:34%;left:0;right:0;height:14px;background:linear-gradient(180deg,#3a2814,#5a3c1c 40%,#4a3018);box-shadow:0 3px 6px #0006;pointer-events:none}.hrd-wall:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#fbbf24;box-shadow:0 0 6px #fbbf2466}.hrd-wall:after{content:"";position:absolute;bottom:-8px;left:0;right:0;height:8px;background:#8b6940}.hrd-infield{position:absolute;bottom:5%;left:50%;transform:translate(-50%) rotate(45deg);width:52%;aspect-ratio:1;background:radial-gradient(ellipse at center,#b8915a 0%,#9a7844 60%,transparent 72%);border-radius:8px;pointer-events:none}.hrd-basepath{position:absolute;bottom:18%;height:3px;width:28%;background:#ffffff1f;pointer-events:none;transform-origin:bottom center}.hrd-basepath.bp-1b{left:50%;transform:rotate(-45deg)}.hrd-basepath.bp-3b{right:50%;transform:rotate(45deg);transform-origin:bottom right}.hrd-plate{position:absolute;bottom:14%;left:50%;transform:translate(-50%);width:18px;height:18px;background:#fff;clip-path:polygon(50% 0%,100% 30%,100% 100%,0% 100%,0% 30%);box-shadow:0 0 8px #ffffff4d;pointer-events:none;z-index:2}.hrd-machine{position:absolute;top:38%;left:50%;transform:translate(-50%);width:36px;height:42px;pointer-events:none;z-index:3}.hrd-machine-body{position:absolute;bottom:10px;left:50%;transform:translate(-50%);width:28px;height:22px;background:linear-gradient(180deg,#555,#3a3a3a);border-radius:4px 4px 2px 2px;box-shadow:inset 0 1px #ffffff26,0 2px 6px #0006}.hrd-machine-body:before{content:"";position:absolute;top:4px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:50%;background:#444;box-shadow:inset 0 0 2px #00000080}.hrd-machine.fire .hrd-machine-body:before{background:#ef4444;box-shadow:0 0 10px #ef4444,0 0 20px #ef444480}.hrd-machine-barrel{position:absolute;top:0;left:50%;transform:translate(-50%);width:14px;height:18px;background:linear-gradient(180deg,#666,#555);border-radius:7px 7px 3px 3px;box-shadow:inset 0 1px #fff3}.hrd-machine-barrel:after{content:"";position:absolute;top:2px;left:50%;transform:translate(-50%);width:10px;height:10px;border-radius:50%;background:#222;box-shadow:inset 0 2px 4px #0009}.hrd-machine.fire .hrd-machine-barrel:after{box-shadow:inset 0 2px 4px #0009,0 0 12px #ff963299}.hrd-machine-legs{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:32px;height:12px}.hrd-machine-legs:before,.hrd-machine-legs:after{content:"";position:absolute;bottom:0;width:4px;height:12px;background:#444;border-radius:1px}.hrd-machine-legs:before{left:4px;transform:rotate(-8deg)}.hrd-machine-legs:after{right:4px;transform:rotate(8deg)}.hrd-batter{position:absolute;bottom:12%;left:calc(50% + 20px);width:40px;height:52px;pointer-events:none;z-index:4}.hrd-batter-helmet{position:absolute;top:0;left:8px;width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#1a3a6c,#0f2244);box-shadow:0 2px 4px #0000004d}.hrd-batter-helmet:before{content:"";position:absolute;bottom:0;left:-3px;width:12px;height:4px;background:#0f2244;border-radius:2px 0 0 2px}.hrd-batter-helmet:after{content:"";position:absolute;bottom:1px;right:1px;width:8px;height:8px;border-radius:50%;background:#c68642}.hrd-batter-torso{position:absolute;top:14px;left:8px;width:16px;height:20px;background:linear-gradient(180deg,#e8e8e8,#d0d0d0);border-radius:3px;box-shadow:0 1px 3px #0003}.hrd-batter-torso:before{content:"";position:absolute;top:5px;left:50%;transform:translate(-50%);width:8px;height:8px;border-radius:2px;background:#1a3a6c4d}.hrd-batter-legs{position:absolute;bottom:0;left:6px;width:20px;height:16px}.hrd-batter-legs:before,.hrd-batter-legs:after{content:"";position:absolute;bottom:0;width:7px;height:16px;background:linear-gradient(180deg,#e8e8e8,#ccc);border-radius:2px}.hrd-batter-legs:before{left:0}.hrd-batter-legs:after{right:0}.hrd-bat{position:absolute;top:10px;right:14px;width:40px;height:5px;background:linear-gradient(90deg,#6b3a18,#b8860b 30%,#daa520);border-radius:3px 8px 8px 3px;transform-origin:right center;transform:rotate(-30deg);transition:transform .1s ease-out;box-shadow:0 1px 3px #0000004d}.hrd-bat:before{content:"";position:absolute;right:-3px;top:-2px;width:6px;height:9px;background:#5a3010;border-radius:2px}.hrd-bat:after{content:"";position:absolute;right:2px;top:0;width:14px;height:100%;background:repeating-linear-gradient(90deg,transparent 0 2px,rgba(0,0,0,.12) 2px 3px)}.hrd-batter.swung .hrd-bat{transform:rotate(75deg)}.hrd-ball{position:absolute;left:50%;width:16px;height:16px;margin-left:-8px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fff,#e8e8e8,#ccc);box-shadow:0 0 8px #ffffff80,0 2px 4px #0000004d;z-index:6;will-change:transform,top,left}.hrd-ball:before{content:"";position:absolute;top:3px;left:3px;width:10px;height:10px;border-radius:50%;border-top:1.5px solid #cc0000;border-bottom:1.5px solid #cc0000;border-left:none;border-right:none;transform:rotate(20deg)}.hrd-ball.homer{box-shadow:0 0 20px #34d399cc,0 0 40px #34d3994d}.hrd-trail{position:absolute;width:10px;height:10px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.5),transparent);pointer-events:none;animation:hrd-trail-fade .34s ease-out forwards}@keyframes hrd-trail-fade{0%{opacity:.7}to{opacity:0;transform:translate(-50%,-50%) scale(.3)}}.hrd-result{position:absolute;top:46%;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-weight:700;font-size:1.6rem;letter-spacing:.12em;padding:8px 18px;border-radius:var(--radius-pill);pointer-events:none;opacity:0;animation:hrd-pop .9s ease forwards;white-space:nowrap;z-index:10}.hrd-result.good{background:#22c55ee6;color:#052e16}.hrd-result.great{background:#eab308e6;color:#422006}.hrd-result.miss{background:#ef4444e6;color:#fff}.hrd-result.foul{background:#9ca3afd9;color:#1f2937}@keyframes hrd-pop{0%{opacity:0;transform:translate(-50%,10px) scale(.8)}20%{opacity:1;transform:translate(-50%) scale(1.05)}80%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-6px) scale(1)}}.hrd-dist-chip{position:absolute;top:54%;left:50%;transform:translate(-50%);padding:4px 10px;border-radius:999px;background:#0000008c;color:#fff;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;pointer-events:none;opacity:0;animation:hrd-dist-in .6s ease forwards;animation-delay:.3s;z-index:10}@keyframes hrd-dist-in{0%{opacity:0;transform:translate(-50%,6px)}to{opacity:1;transform:translate(-50%)}}.hrd-pitch-chip{position:absolute;top:var(--s-3);right:var(--s-3);padding:6px 10px;border-radius:var(--radius-pill);background:#00000080;color:#fff;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;pointer-events:none;z-index:8}.hrd-combo-fire{position:absolute;top:var(--s-3);left:var(--s-3);padding:6px 10px;border-radius:var(--radius-pill);background:#eab308e6;color:#422006;font-family:var(--font-mono);font-weight:700;font-size:.8rem;letter-spacing:.08em;pointer-events:none;animation:hrd-combo-pulse .6s ease infinite alternate;z-index:8}@keyframes hrd-combo-pulse{0%{transform:scale(1)}to{transform:scale(1.08);box-shadow:0 0 16px #eab30880}}.hrd-field.shake{animation:hrd-shake .22s ease}@keyframes hrd-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px,2px)}50%{transform:translate(2px,-2px)}75%{transform:translate(-2px,1px)}}.hrd-timing{position:relative;width:100%;height:26px;border-radius:var(--radius-pill);background:#ffffff14;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0f}.hrd-timing-track{position:absolute;top:0;right:0;bottom:0;left:0}.hrd-timing-zone{position:absolute;top:0;bottom:0;background:#22c55e59;border-left:2px solid rgba(34,197,94,.9);border-right:2px solid rgba(34,197,94,.9)}.hrd-timing-zone.sweet{background:#eab30873;border-color:#eab308f2}.hrd-timing-needle{position:absolute;top:-4px;bottom:-4px;width:4px;background:var(--accent, #fff);border-radius:2px;box-shadow:0 0 8px #ffffff80;transform:translate(-50%)}.hrd-timing-label{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim);letter-spacing:.08em;margin-bottom:4px}.hrd-controls{display:flex;flex-direction:column;gap:var(--s-3)}.bt-field{position:relative;width:100%;max-width:560px;margin:0 auto;aspect-ratio:3 / 4;max-height:55vh;border-radius:var(--radius-lg);overflow:hidden;background:#1a1225;box-shadow:inset 0 0 0 1px #ffffff0f,0 12px 40px #0006;-webkit-user-select:none;user-select:none;touch-action:manipulation}@media (min-width: 900px){.bt-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:var(--s-4);align-items:start}.bt-field{max-width:none;max-height:78vh;margin:0}.bt-side{display:flex;flex-direction:column;gap:var(--s-3)}}.bt-arena-bg{position:absolute;top:0;left:0;right:0;height:55%;background:linear-gradient(180deg,#080410,#10092a 30%,#1a1240);pointer-events:none}.bt-arena-bg:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:radial-gradient(ellipse 30% 60% at 25% 0%,rgba(255,240,180,.08) 0%,transparent 100%),radial-gradient(ellipse 30% 60% at 75% 0%,rgba(255,240,180,.08) 0%,transparent 100%),radial-gradient(ellipse 20% 40% at 50% 0%,rgba(255,240,180,.06) 0%,transparent 100%);pointer-events:none}.bt-arena-bg:after{content:"";position:absolute;bottom:-20%;left:50%;transform:translate(-50%);width:100%;height:50%;background:radial-gradient(ellipse at 50% 0%,rgba(255,220,130,.05) 0%,transparent 70%);pointer-events:none}.bt-stands{position:absolute;top:0;left:0;right:0;height:40%;pointer-events:none;overflow:hidden}.bt-stands:before{content:"";position:absolute;top:0;left:0;right:0;height:75%;background:linear-gradient(180deg,#0c0818,#140e28,#1a1434,#140e28,#100a20)}.bt-stands:after{content:"";position:absolute;bottom:0;left:0;right:0;height:45%;background:radial-gradient(ellipse 8px 9px at 4% 82%,#2e1e44 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 12% 78%,#36264e 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 20% 84%,#2a1c40 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 28% 80%,#342450 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 36% 82%,#2e1e44 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 44% 77%,#36264e 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 52% 83%,#2a1c40 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 60% 79%,#322248 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 68% 81%,#2e1e44 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 76% 78%,#36264e 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 84% 84%,#2a1c40 70%,transparent 71%),radial-gradient(ellipse 8px 9px at 92% 80%,#322248 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 8% 52%,#241a38 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 16% 48%,#2a1e40 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 24% 54%,#221836 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 32% 50%,#2c2042 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 40% 52%,#241a38 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 48% 48%,#2a1e40 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 56% 53%,#221836 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 64% 49%,#2c2042 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 72% 54%,#241a38 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 80% 50%,#2a1e40 70%,transparent 71%),radial-gradient(ellipse 6px 7px at 88% 52%,#221836 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 6% 28%,#1c1430 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 14% 25%,#201636 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 22% 30%,#1e1432 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 30% 26%,#221838 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 38% 29%,#1c1430 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 46% 25%,#201636 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 54% 30%,#1e1432 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 62% 27%,#221838 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 70% 29%,#1c1430 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 78% 26%,#201636 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 86% 30%,#1e1432 70%,transparent 71%),radial-gradient(ellipse 4px 5px at 94% 27%,#221838 70%,transparent 71%)}.bt-court-floor{position:absolute;bottom:0;left:0;right:0;height:48%;background:repeating-linear-gradient(90deg,#a87d50,#b8895a,#c49462,#b8895a,#a87d50,#9e7348,#b08454,#c09060,#b08454 16px);pointer-events:none;clip-path:polygon(8% 0%,92% 0%,100% 100%,0% 100%)}.bt-court-floor:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 40% at 50% 20%,rgba(255,255,255,.08) 0%,transparent 100%),linear-gradient(180deg,#ffffff0f,#0000001f)}.bt-court-floor:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#ffffff26}.bt-court-line{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:30%;height:36%;border:2px solid rgba(255,255,255,.12);border-bottom:none;pointer-events:none;clip-path:polygon(10% 0%,90% 0%,100% 100%,0% 100%)}.bt-court-line:before{content:"";position:absolute;top:-2px;left:50%;transform:translate(-50%);width:80%;height:30%;border:2px solid rgba(255,255,255,.1);border-radius:50%;border-bottom-color:transparent}.bt-court-line:after{content:"";position:absolute;top:-40%;left:50%;transform:translate(-50%);width:200%;height:100%;border:2px solid rgba(255,255,255,.07);border-radius:50%;border-bottom:none;clip-path:inset(35% 0 0 0)}.bt-hoop-assembly{position:absolute;top:8%;left:50%;margin-left:-70px;width:140px;height:160px;pointer-events:none;z-index:3;transition:transform .05s linear}.bt-pole{position:absolute;left:50%;margin-left:-4px;top:50px;width:8px;height:110px;background:linear-gradient(90deg,#555,#888 40%,#666 60%,#444);border-radius:4px;box-shadow:2px 0 6px #0006}.bt-pole:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:10px;background:#666;border-radius:3px 3px 0 0}.bt-backboard{position:absolute;top:8px;left:50%;transform:translate(-50%);width:100px;height:62px;background:linear-gradient(180deg,#c8dcf02e,#a0b4c81f,#8ca0b426);border:3px solid rgba(255,255,255,.3);border-radius:4px;box-shadow:0 4px 16px #0006,inset 0 0 20px #ffffff08}.bt-backboard-square{position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:38px;height:26px;border:3px solid rgba(239,68,68,.75);border-radius:2px}.bt-backboard-square:before{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border:1px solid rgba(239,68,68,.35);border-radius:1px}.bt-rim{position:absolute;top:70px;left:50%;transform:translate(-50%);width:60px;height:8px;background:linear-gradient(180deg,#f97316,#ea580c 40%,#c2410c);border-radius:5px;box-shadow:0 3px 8px #00000080,0 0 14px #ea580c4d,inset 0 1px #ffc89666}.bt-rim:before{content:"";position:absolute;left:-3px;top:50%;transform:translateY(-50%);width:10px;height:10px;background:radial-gradient(circle,#f97316 30%,#c2410c);border-radius:50%;box-shadow:0 0 6px #ea580c80}.bt-rim:after{content:"";position:absolute;right:-3px;top:50%;transform:translateY(-50%);width:10px;height:10px;background:radial-gradient(circle,#f97316 30%,#c2410c);border-radius:50%;box-shadow:0 0 6px #ea580c80}.bt-net{position:absolute;top:77px;left:50%;transform:translate(-50%);width:48px;height:42px;background:repeating-linear-gradient(170deg,rgba(255,255,255,.22) 0 1px,transparent 1px 6px),repeating-linear-gradient(10deg,rgba(255,255,255,.22) 0 1px,transparent 1px 6px),repeating-linear-gradient(180deg,rgba(255,255,255,.12) 0 1px,transparent 1px 8px);clip-path:polygon(0 0,100% 0,75% 100%,25% 100%);opacity:.7;pointer-events:none;transition:transform .15s ease}.bt-net.swish{animation:bt-net-swish .4s ease}@keyframes bt-net-swish{0%{transform:translate(-50%) scaleY(1)}30%{transform:translate(-50%) scaleY(1.15) scaleX(.85)}60%{transform:translate(-50%) scaleY(.9) scaleX(1.1)}to{transform:translate(-50%) scaleY(1) scaleX(1)}}.bt-hands{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:120px;height:80px;pointer-events:none;z-index:4}.bt-hands:before{content:"";position:absolute;bottom:0;left:10px;width:28px;height:65px;background:linear-gradient(180deg,#d4944e,#c4844a 30%,#1d4ed8 32%,#1e40af);border-radius:10px 10px 0 0;transform:rotate(6deg);transform-origin:bottom center}.bt-hands:after{content:"";position:absolute;bottom:0;right:10px;width:28px;height:65px;background:linear-gradient(180deg,#d4944e,#c4844a 30%,#1d4ed8 32%,#1e40af);border-radius:10px 10px 0 0;transform:rotate(-6deg);transform-origin:bottom center}.bt-ball{position:absolute;width:36px;height:36px;border-radius:50%;background:radial-gradient(circle at 38% 32%,#fbbf24,#f59e0b 25%,#ea580c 55%,#9a3412);box-shadow:inset 0 -4px 8px #00000059,inset 0 2px 4px #ffc86426,0 3px 8px #00000059;z-index:5;will-change:transform,top,left}.bt-ball:before{content:"";position:absolute;top:50%;left:4px;right:4px;height:2px;background:#00000040;transform:translateY(-50%);border-radius:1px}.bt-ball:after{content:"";position:absolute;left:50%;top:4px;bottom:4px;width:2px;background:#00000040;transform:translate(-50%);border-radius:1px}.bt-ball.flying{filter:drop-shadow(0 6px 14px rgba(0,0,0,.4))}.bt-trail{position:absolute;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.45),transparent);pointer-events:none;animation:bt-trail-fade .3s ease-out forwards}@keyframes bt-trail-fade{0%{opacity:.7}to{opacity:0}}.bt-result{position:absolute;top:44%;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-weight:700;font-size:1.6rem;letter-spacing:.12em;padding:10px 22px;border-radius:var(--radius-pill);pointer-events:none;opacity:0;animation:bt-pop .9s ease forwards;white-space:nowrap;z-index:10;text-shadow:0 1px 4px rgba(0,0,0,.3)}.bt-result.good{background:#22c55eeb;color:#052e16}.bt-result.miss{background:#ef4444eb;color:#fff}@keyframes bt-pop{0%{opacity:0;transform:translate(-50%,10px) scale(.8)}20%{opacity:1;transform:translate(-50%) scale(1.05)}80%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-6px) scale(1)}}.bt-timer-chip{position:absolute;top:var(--s-3);right:var(--s-3);padding:6px 12px;border-radius:var(--radius-pill);background:#0000008c;color:#fff;font-family:var(--font-mono);font-weight:700;font-size:.85rem;letter-spacing:.06em;pointer-events:none;z-index:8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.bt-timer-chip.danger{background:#ef4444d9;animation:bt-timer-pulse .5s ease infinite alternate}@keyframes bt-timer-pulse{0%{transform:scale(1)}to{transform:scale(1.08)}}.bt-streak-fire{position:absolute;top:var(--s-3);left:var(--s-3);padding:6px 10px;border-radius:var(--radius-pill);background:#eab308eb;color:#422006;font-family:var(--font-mono);font-weight:700;font-size:.8rem;letter-spacing:.08em;pointer-events:none;animation:bt-streak-pulse .6s ease infinite alternate;z-index:8}.bt-streak-fire.moving{background:#ef4444eb;color:#fff}@keyframes bt-streak-pulse{0%{transform:scale(1)}to{transform:scale(1.08);box-shadow:0 0 16px #eab30880}}.bt-field.shake{animation:bt-shake .22s ease}@keyframes bt-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px,2px)}50%{transform:translate(2px,-2px)}75%{transform:translate(-2px,1px)}}.bt-meter{position:relative;width:100%;height:26px;border-radius:var(--radius-pill);background:#ffffff14;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0f}.bt-meter-track{position:absolute;top:0;right:0;bottom:0;left:0}.bt-meter-zone{position:absolute;top:0;bottom:0;background:#22c55e59;border-left:2px solid rgba(34,197,94,.9);border-right:2px solid rgba(34,197,94,.9)}.bt-meter-zone.perfect{background:#eab30873;border-color:#eab308f2}.bt-meter-needle{position:absolute;top:-4px;bottom:-4px;width:4px;background:var(--accent, #fff);border-radius:2px;box-shadow:0 0 8px #ffffff80;transform:translate(-50%)}.bt-meter-label{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim);letter-spacing:.08em;margin-bottom:4px}.bt-controls{display:flex;flex-direction:column;gap:var(--s-3)}.plaza-wrap{position:relative;max-width:100%;margin:0 auto;padding:var(--s-3);display:flex;flex-direction:column;gap:var(--s-2);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}@media (max-width: 720px){.app-root .main:has(.plaza-wrap){padding:0}html:has(.plaza-wrap),body:has(.plaza-wrap){overflow:hidden;overscroll-behavior:none;height:100%}.plaza-wrap{padding:0;gap:0;max-width:100%;touch-action:none;overscroll-behavior:none}.plaza-viewport{aspect-ratio:auto;width:100%;height:calc(100vh - 56px);height:calc(100svh - 56px);min-height:480px;border-radius:0;outline:none}.plaza-footer{display:none}}.plaza-viewport{position:relative;width:100%;height:calc(100vh - 220px);height:calc(100svh - 220px);min-height:520px;border-radius:var(--radius-lg);overflow:hidden;background:#08121a;box-shadow:0 18px 60px #00000073;isolation:isolate;outline:1px solid var(--border);touch-action:none;margin-bottom:var(--s-3)}.plaza-viewport canvas{width:100%!important;height:100%!important;display:block}.cab-marquee{font-family:var(--font-mono);font-size:10px;font-weight:800;letter-spacing:.16em;color:#fff;background:#000000c7;padding:3px 8px;border-radius:3px;border:1px solid rgba(255,255,255,.18);pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap;text-shadow:0 0 4px rgba(255,255,255,.5);transform:translateY(-4px)}.cab-marquee.pink{background:#ff2e7e;color:#fff;border-color:#ff2e7e;box-shadow:0 0 12px #ff2e7e}.wall-poster{font-family:var(--font-mono);font-size:22px;font-weight:900;color:#0b0d18;text-shadow:0 0 4px rgba(255,255,255,.6);pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap}.wall-poster.ad{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 12px;text-align:center;font-size:18px;color:#0b0d18;background:#ffffffeb;border-radius:6px;width:180px;box-sizing:border-box;text-shadow:none}.wall-poster.ad .ad-eyebrow{font-size:14px;letter-spacing:.22em;color:#ff2e7e;font-weight:900}.wall-poster.ad .ad-body{font-size:20px;line-height:1.15;white-space:normal;font-weight:700}.wall-poster.ad .ad-price{font-size:17px;color:#0b0d18;margin-top:4px;white-space:nowrap}.wall-poster.ad .ad-price b{color:#ff2e7e;font-weight:900;letter-spacing:.02em;font-size:19px}.wall-poster.ad .ad-terms{font-size:13px;opacity:.75;letter-spacing:.06em}.wall-poster.ad .ad-contact{font-size:13px;letter-spacing:.1em;color:#0b0d18;opacity:.8;white-space:nowrap}.wall-sign{font-family:var(--font-mono);font-size:28px;font-weight:900;letter-spacing:.28em;color:#fff;text-shadow:0 0 8px rgba(255,255,255,.9),0 0 18px rgba(255,255,255,.45);pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap}.cab-screen-icon{font-size:28px;line-height:1;filter:drop-shadow(0 0 6px rgba(255,255,255,.8));pointer-events:none;-webkit-user-select:none;user-select:none}.cab-wardrobe-face{font-size:32px;line-height:1;filter:drop-shadow(0 0 8px #ff2e7e);pointer-events:none;-webkit-user-select:none;user-select:none}.player-3d-face{font-size:22px;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.55));pointer-events:none;-webkit-user-select:none;user-select:none}.player-3d-emoji{font-size:40px;line-height:1;filter:drop-shadow(0 4px 6px rgba(0,0,0,.6)) drop-shadow(0 0 12px rgba(255,255,255,.35));pointer-events:none;-webkit-user-select:none;user-select:none;transform:translateY(-10px)}.plaza-map{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;gap:0}.t{position:relative;overflow:hidden}.t-grass{background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.04) 0 20%,transparent 22%),radial-gradient(circle at 70% 60%,rgba(0,0,0,.06) 0 18%,transparent 20%),linear-gradient(180deg,#1f6b3a,#2a8a4c)}html[data-theme=minimal] .t-grass{background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.18) 0 20%,transparent 22%),radial-gradient(circle at 70% 60%,rgba(0,0,0,.05) 0 18%,transparent 20%),linear-gradient(180deg,#3cb968,#4cd07a)}.t-wall{background:linear-gradient(135deg,#2a2330,#1a1420);box-shadow:inset 0 0 0 1px #ffffff0a}.t-wall:after{content:"";position:absolute;top:15%;right:15%;bottom:15%;left:15%;border-radius:3px;background:repeating-linear-gradient(45deg,rgba(255,255,255,.04) 0 6px,transparent 6px 12px)}.deco{position:absolute;top:50%;left:50%;transform:translate(-50%,-55%);font-size:clamp(18px,4vw,32px);filter:drop-shadow(0 3px 2px rgba(0,0,0,.4))}.deco.tree{animation:sway 4s ease-in-out infinite;transform-origin:50% 90%}@keyframes sway{0%,to{transform:translate(-50%,-55%) rotate(-2deg)}50%{transform:translate(-50%,-55%) rotate(2deg)}}.deco.fountain{animation:pulse 2.2s ease-in-out infinite}@keyframes pulse{0%,to{transform:translate(-50%,-55%) scale(1)}50%{transform:translate(-50%,-55%) scale(1.06);filter:drop-shadow(0 0 12px rgba(120,200,255,.6))}}.deco.cabinet{font-size:clamp(20px,5vw,36px);filter:drop-shadow(0 4px 6px rgba(0,0,0,.55)) drop-shadow(0 0 8px var(--accent));padding:4px 6px;background:linear-gradient(180deg,#1a1f2e,#0a0d14);border-radius:6px;border:1px solid var(--accent);box-shadow:inset 0 0 8px #0009;transform:translate(-50%,-60%)}.deco.cabinet.wardrobe{border-color:var(--accent-2);filter:drop-shadow(0 4px 6px rgba(0,0,0,.55)) drop-shadow(0 0 8px var(--accent-2))}.cabinet-sign{position:absolute;bottom:6%;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:clamp(7px,.9vw,10px);letter-spacing:.08em;color:#fff;background:#000000a6;padding:1px 6px;border-radius:3px;white-space:nowrap;pointer-events:none}.player{position:absolute;transition:left .17s cubic-bezier(.3,.7,.4,1),top .17s cubic-bezier(.3,.7,.4,1);pointer-events:none;z-index:5}.player-shadow{position:absolute;bottom:6%;left:50%;transform:translate(-50%);width:60%;height:10%;border-radius:50%;background:radial-gradient(ellipse at center,rgba(0,0,0,.45),transparent 70%)}.player-body{position:absolute;top:18%;left:18%;right:18%;bottom:18%;background:linear-gradient(160deg,var(--avatar-color) 0%,color-mix(in oklab,var(--avatar-color) 60%,black) 100%);border-radius:8px;box-shadow:inset 0 -4px #00000040,inset 0 2px #ffffff40,0 0 18px var(--avatar-soft),0 4px 10px #00000080;display:grid;place-items:center}.player-face{font-size:clamp(14px,2.6vw,22px);filter:drop-shadow(0 1px 1px rgba(0,0,0,.4))}.player.bob .player-body{animation:player-bob .17s ease}@keyframes player-bob{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-4%) scale(.96,1.04)}}.player.face-left .player-body:before,.player.face-right .player-body:before,.player.face-up .player-body:before,.player.face-down .player-body:before{content:"";position:absolute;width:18%;height:8%;background:#ffffffd9;border-radius:50%}.player.face-down .player-body:before{top:30%;left:25%;box-shadow:30% 0 0 #ffffffd9}.player.face-up .player-body:before{top:85%;left:41%;opacity:0}.player.face-left .player-body:before{top:32%;left:18%;width:12%}.player.face-right .player-body:before{top:32%;right:18%;left:auto;width:12%}.plaza-intro{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2147483600;display:flex;align-items:center;justify-content:center;padding:var(--s-4);background:#04060cd1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:intro-fade .22s ease-out}@keyframes intro-fade{0%{opacity:0}to{opacity:1}}.plaza-intro-card{max-width:420px;width:100%;background:linear-gradient(180deg,#141022,#0b0d18);border:1px solid var(--accent, #00ffd5);border-radius:var(--radius-lg);padding:var(--s-5) var(--s-4);box-shadow:0 24px 80px #0009,0 0 40px #00ffd52e;color:#fff;text-align:center}.plaza-intro-kicker{display:inline-block;font-size:.72rem;letter-spacing:.18em;color:#00ffd5;padding:2px 8px;border:1px solid #00ffd555;border-radius:var(--radius-pill);margin-bottom:var(--s-3)}.plaza-intro-title{margin:0 0 var(--s-3) 0;font-size:1.5rem;background:linear-gradient(90deg,#00ffd5,#ff2e7e);-webkit-background-clip:text;background-clip:text;color:transparent}.plaza-intro-list{list-style:none;padding:0;margin:0 0 var(--s-4) 0;text-align:left;display:flex;flex-direction:column;gap:var(--s-2);font-size:.95rem;line-height:1.45;color:#d6dbf0}.plaza-intro-list li{padding-left:0}.plaza-intro-skip{display:block;margin:var(--s-3) auto 0;background:none;border:none;color:#8b93b1;font-size:.85rem;text-decoration:underline;cursor:pointer}.plaza-intro-skip:hover{color:#fff}.plaza-help{position:absolute;top:var(--s-3);right:var(--s-3);z-index:7;width:34px;height:34px;border-radius:50%;border:1px solid rgba(0,255,213,.5);background:#0000008c;color:#00ffd5;font-weight:800;font-size:1rem;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.plaza-help:hover{background:#00ffd526}.plaza-prompt{position:absolute;bottom:var(--s-3);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--s-2);padding:var(--s-2) var(--s-3);background:#000000c7;color:#fff;border-radius:var(--radius-pill);font-size:.9rem;border:1px solid var(--accent);box-shadow:0 0 24px #00ffd54d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:prompt-pop .2s ease-out;z-index:6;pointer-events:none}@keyframes prompt-pop{0%{opacity:0;transform:translate(-50%,6px)}to{opacity:1;transform:translate(-50%)}}.kbd{font-family:var(--font-mono);background:var(--accent);color:#001814;padding:2px 8px;border-radius:4px;font-weight:800;letter-spacing:.05em;font-size:.82rem}.plaza-touch{display:none;justify-content:space-between;align-items:flex-end;padding:0 var(--s-2);pointer-events:none}.plaza-touch>*{pointer-events:auto}@media (pointer: coarse),(max-width: 720px){.plaza-touch{display:flex;position:absolute;left:0;right:0;bottom:calc(env(safe-area-inset-bottom,0) + var(--s-3));padding:0 var(--s-3);z-index:20}}.dpad{position:relative;width:156px;height:156px}.dp{position:absolute;width:52px;height:52px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border-bright);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;color:var(--text);font-size:1.1rem;display:grid;place-items:center;touch-action:manipulation}.dp:active{background:var(--surface-3);transform:scale(.95)}.dp-up{top:0;left:52px}.dp-down{bottom:0;left:52px}.dp-left{top:52px;left:0}.dp-right{top:52px;right:0}.a-btn{width:84px;height:84px;border-radius:50%;background:var(--accent);color:#001814;border:none;font-weight:900;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;font-size:1.8rem;box-shadow:0 6px 20px #00ffd573;touch-action:manipulation}.a-btn:active{transform:scale(.95)}.plaza-footer{text-align:center;font-size:.8rem}@media (max-width: 720px){.plaza-footer{display:none}}.wardrobe-preview{width:120px;height:120px;margin:0 auto;position:relative}.wardrobe-preview .player-body{top:10%;right:10%;bottom:10%;left:10%}.wardrobe-preview .player-face{font-size:2.2rem}.wardrobe-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:var(--s-2)}@media (max-width: 480px){.wardrobe-grid{grid-template-columns:repeat(6,1fr)}}.wardrobe-option{aspect-ratio:1 / 1;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);font-size:1.5rem;cursor:pointer;transition:all .12s ease}.wardrobe-option:hover{background:var(--surface-3)}.wardrobe-option.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 2px var(--accent)}.wardrobe-grid.colors{grid-template-columns:repeat(8,1fr)}.wardrobe-grid.avatars{grid-template-columns:repeat(5,1fr)}@media (max-width: 480px){.wardrobe-grid.avatars{grid-template-columns:repeat(3,1fr)}}.wardrobe-cats{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--s-3)}.wardrobe-cat{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;color:inherit;cursor:pointer;font-size:.82rem;transition:all .12s ease}.wardrobe-cat:hover{background:var(--surface-3)}.wardrobe-cat.active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent)}.wardrobe-cat-icon{font-size:1rem;line-height:1}.wardrobe-cat-count{font-size:.7rem;opacity:.65;padding:1px 6px;border-radius:999px;background:#ffffff0f}.wardrobe-cat.active .wardrobe-cat-count{background:#ffffff24;opacity:.9}.wardrobe-avatar{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .12s ease;color:inherit}.wardrobe-avatar:hover{background:var(--surface-3)}.wardrobe-avatar.selected{border-color:var(--accent, #00ffd5);box-shadow:0 0 0 2px #00ffd540}.wardrobe-avatar-emoji{font-size:1.6rem;line-height:1}.wardrobe-avatar-thumb{width:64px;height:64px;object-fit:cover;border-radius:8px;pointer-events:none}.wardrobe-current-thumb{width:80px;height:80px;object-fit:cover;border-radius:12px}@media (max-width: 480px){.wardrobe-avatar-thumb{width:52px;height:52px}.wardrobe-current-thumb{width:64px;height:64px}}.lb-picker-grid{display:grid;grid-template-columns:1fr;gap:var(--s-2);margin-top:var(--s-3)}.lb-picker-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:inherit;cursor:pointer;transition:all .12s ease;font-family:var(--font-mono)}.lb-picker-item:hover{background:var(--surface-3);border-color:#fbbf24;transform:translate(2px)}.lb-picker-name{font-size:.95rem;letter-spacing:.04em}.lb-picker-arrow{color:#fbbf24;font-weight:900}.lb-back{background:transparent;border:none;color:var(--text-dim, #9aa3b2);font-family:var(--font-mono);font-size:.85rem;cursor:pointer;padding:4px 0;margin-bottom:var(--s-3)}.lb-back:hover{color:#fbbf24}.wardrobe-current{display:flex;flex-direction:column;align-items:center;gap:4px}.wardrobe-current-emoji{font-size:3rem;line-height:1;filter:drop-shadow(0 0 12px var(--avatar-color))}.wardrobe-current-name{font-family:var(--font-mono);font-size:.95rem;letter-spacing:.04em;color:var(--avatar-color)}.wardrobe-avatar-name{font-size:.72rem;opacity:.85;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.wardrobe-color{aspect-ratio:1 / 1;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:transform .12s ease,border-color .12s ease}.wardrobe-color:hover{transform:scale(1.08)}.wardrobe-color.selected{border-color:#fff;transform:scale(1.1)}.jukebox{display:flex;flex-direction:column;gap:var(--s-3)}.jukebox-now{display:flex;flex-direction:column;gap:var(--s-1);padding:var(--s-3) var(--s-4);border-radius:var(--radius-md);background:linear-gradient(135deg,#00ffd51f,#af52de1f);border:1px solid var(--border)}.jukebox-kicker{font-size:.7rem;color:var(--accent);letter-spacing:.18em}.jukebox-title{font-size:1.05rem;font-weight:700;color:var(--text)}.jukebox-list{display:flex;flex-direction:column;gap:var(--s-1);max-height:52vh;overflow-y:auto;padding-right:var(--s-1)}.jukebox-item{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);cursor:pointer;text-align:left;transition:background var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease),transform var(--dur-1) var(--ease)}.jukebox-item:hover{background:#00ffd50f;border-color:var(--accent)}.jukebox-item.active{background:#00ffd524;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 18px #00ffd533}.jukebox-item-icon{width:22px;text-align:center;color:var(--accent);font-size:1rem}.jukebox-item-title{flex:1;font-size:.95rem}.wardrobe-avatar.locked{opacity:.78}.wardrobe-avatar.locked:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:repeating-linear-gradient(45deg,transparent 0 8px,rgba(0,0,0,.08) 8px 10px);pointer-events:none}.wardrobe-avatar{position:relative}.wardrobe-avatar-price{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:2px 8px;border-radius:999px;background:color-mix(in oklab,var(--accent) 15%,transparent);border:1px solid var(--border);font-size:.72rem;font-weight:700;color:var(--text)}.wardrobe-msg{margin-top:var(--s-3);padding:8px 12px;border-radius:10px;font-size:.9rem;text-align:center}.wardrobe-msg.ok{background:#32c87824;color:#3fd39a}.wardrobe-msg.error{background:#ff506424;color:#ff8a8a}.jukebox-cost{display:block;margin-top:4px;font-size:.82rem}.jukebox-msg{margin:var(--s-2) 0;padding:8px 12px;border-radius:10px;background:#ff506424;color:#ff8a8a;font-size:.9rem;text-align:center}.jukebox-confirm{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);padding:var(--s-3);margin:var(--s-2) 0;border-radius:12px;border:1px solid var(--accent);background:color-mix(in oklab,var(--accent) 10%,transparent)}.jukebox-confirm-body{display:flex;flex-direction:column;gap:2px;min-width:0}.jukebox-confirm-title{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jukebox-item:disabled{opacity:.5;cursor:not-allowed}.cab-cost-coin{width:48px;height:48px;perspective:220px;pointer-events:none;filter:drop-shadow(0 0 10px rgba(255,215,80,.6))}.cab-cost-coin-face{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffe066,#f5c542 45%,#b88512);color:#2a1a00;font-weight:900;font-family:var(--font-mono);border:2px solid #ffe999;box-shadow:inset 0 0 8px #ffffff8c,inset 0 -6px 10px #00000040,0 0 16px #ffc85073;transform-style:preserve-3d;animation:cab-coin-spin 2.6s linear infinite}.cab-cost-amount{font-size:16px;line-height:1;letter-spacing:.04em}.cab-cost-sub{font-size:10px;line-height:1;margin-top:2px;filter:saturate(.6)}@keyframes cab-coin-spin{0%{transform:rotateY(0)}50%{transform:rotateY(180deg)}to{transform:rotateY(360deg)}}.wardrobe-avatar.rarity-rare{border-color:color-mix(in oklab,#af52de 60%,var(--border))}.wardrobe-avatar.rarity-epic{border-color:color-mix(in oklab,#fbbf24 70%,var(--border));box-shadow:0 0 12px #fbbf2440}.wardrobe-avatar-price.rarity-rare{background:color-mix(in oklab,#af52de 22%,transparent);border-color:#af52de;color:#e9d5ff}.wardrobe-avatar-price.rarity-epic{background:color-mix(in oklab,#fbbf24 24%,transparent);border-color:#fbbf24;color:#fde68a}.wardrobe-avatar.rarity-legendary{border-color:color-mix(in oklab,#ff2e7e 70%,var(--border));box-shadow:0 0 18px #ff2e7e59}.wardrobe-avatar-price.rarity-legendary{background:color-mix(in oklab,#ff2e7e 26%,transparent);border-color:#ff2e7e;color:#ffd1e1}.wardrobe-avatar-owned{margin-top:4px;padding:2px 8px;border-radius:999px;background:color-mix(in oklab,var(--accent) 16%,transparent);border:1px solid var(--border);font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text)}.splash-root{position:fixed;top:0;right:0;bottom:0;left:0;background:#05070a;display:grid;place-items:center;overflow:hidden;z-index:9999}.splash-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.splash-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,255,213,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,213,.08) 1px,transparent 1px);background-size:42px 42px;mask-image:radial-gradient(ellipse 60% 50% at 50% 50%,black 20%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 60% 50% at 50% 50%,black 20%,transparent 75%)}.splash-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.45}.splash-orb.a{width:420px;height:420px;background:#00ffd5;top:-120px;right:-120px}.splash-orb.b{width:380px;height:380px;background:#ff2e7e;bottom:-120px;left:-120px;opacity:.35}.splash-content{position:relative;display:flex;flex-direction:column;align-items:center;gap:20px}.splash-logo{width:clamp(120px,28vw,180px);height:auto;animation:splash-pulse 1.8s ease-in-out infinite;filter:drop-shadow(0 0 24px rgba(0,255,213,.35))}@keyframes splash-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 24px rgba(0,255,213,.35))}50%{transform:scale(1.05);filter:drop-shadow(0 0 36px rgba(0,255,213,.55))}}.splash-wordmark{font-family:var(--font-mono, "JetBrains Mono", ui-monospace, monospace);font-size:.9rem;letter-spacing:.34em;color:#e6edf3;text-shadow:0 0 12px rgba(0,255,213,.25)}.splash-dots{display:inline-flex;gap:8px;margin-top:6px}.splash-dots span{width:8px;height:8px;border-radius:50%;background:#00ffd5;box-shadow:0 0 10px #00ffd599;animation:splash-dot 1.2s ease-in-out infinite}.splash-dots span:nth-child(2){animation-delay:.15s}.splash-dots span:nth-child(3){animation-delay:.3s}@keyframes splash-dot{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.up-header{display:grid;grid-template-columns:72px 1fr auto;align-items:center;gap:var(--s-4)}@media (max-width: 640px){.up-header{grid-template-columns:56px 1fr}.up-summary{grid-column:1 / -1}}.up-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--accent-soft),transparent);border:1px solid var(--border);display:grid;place-items:center;font-size:2rem;font-weight:800;color:var(--accent);overflow:hidden}.up-avatar img{width:100%;height:100%;object-fit:cover}@media (max-width: 640px){.up-avatar{width:56px;height:56px;font-size:1.5rem}}.up-handle{font-weight:800;font-size:1.4rem;letter-spacing:-.01em}.up-summary{display:flex;gap:var(--s-4);flex-wrap:wrap}.up-game-grid{display:grid;grid-template-columns:1fr;gap:var(--s-3)}@media (min-width: 640px){.up-game-grid{grid-template-columns:1fr 1fr}}@media (min-width: 960px){.up-game-grid{grid-template-columns:repeat(3,1fr)}}.up-game-card{display:flex;flex-direction:column;gap:var(--s-2);padding:var(--s-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text);text-decoration:none;transition:transform var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease),box-shadow var(--dur-1) var(--ease)}.up-game-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-1)}.up-game-head{display:flex;align-items:center;gap:var(--s-3)}.up-game-icon{font-size:1.6rem}.up-game-name{font-weight:700;font-size:1.05rem;flex:1}.up-rank-badge{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;padding:3px 8px;border-radius:var(--radius-pill);background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim)}.up-rank-badge.rank-1{background:#fbbf24;color:#1a1200;border-color:#fbbf24}.up-rank-badge.rank-2{background:#e5e7eb;color:#111;border-color:#e5e7eb}.up-rank-badge.rank-3{background:#f59e42;color:#1a0b00;border-color:#f59e42}.up-best .stat-label{font-size:.72rem;letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase}.up-best-score{font-family:var(--font-mono);font-size:1.6rem;font-weight:800;color:var(--text);letter-spacing:-.01em}html[data-theme=hud] .up-best-score{color:var(--accent)}.up-game-meta{font-size:.82rem}.up-empty{font-size:.9rem}.legal{max-width:720px;padding-bottom:var(--s-8)}.legal h1{font-size:1.8rem;margin-bottom:var(--s-2)}.legal h2{font-size:1.1rem;margin:var(--s-6) 0 var(--s-2);color:var(--accent)}html[data-theme=minimal] .legal h2{color:var(--text)}.legal p,.legal ul{color:var(--text-dim);line-height:1.65;margin-bottom:var(--s-3)}.legal ul{padding-left:var(--s-5)}.legal li{margin-bottom:var(--s-2)}.legal a{color:var(--accent)}.legal strong{color:var(--text)}.gg{display:flex;justify-content:center;padding:var(--s-4) var(--s-3);min-height:60vh;align-items:flex-start}.gg-card{width:100%;max-width:480px;border-radius:var(--radius-lg, 16px);border:1px solid var(--border);background:var(--surface-2);overflow:hidden;box-shadow:0 4px 24px #0000004d,0 0 0 1px #ffffff0a inset}.gg-demo{position:relative;overflow:hidden}.gg-demo .demo-scene{height:200px;border:none;border-radius:0;background:var(--surface)}.gg-demo-placeholder{height:200px;background:var(--surface)}.gg-demo-fade{position:absolute;bottom:0;left:0;right:0;height:48px;background:linear-gradient(transparent,var(--surface-2));pointer-events:none}.gg-body{display:flex;flex-direction:column;gap:var(--s-4);padding:var(--s-4) var(--s-5) var(--s-5)}.gg-head{display:flex;align-items:center;gap:var(--s-3)}.gg-icon{width:48px;height:48px;border-radius:12px;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.gg-head-text{display:flex;flex-direction:column;gap:2px;min-width:0}.gg-title{margin:0;font-size:1.3rem;font-weight:800;line-height:1.2}.gg-tagline{margin:0;font-size:.85rem;color:var(--text-dim);line-height:1.4}.gg-steps{display:flex;flex-direction:column;gap:6px}.gg-step{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.82rem;line-height:1.45;color:var(--text)}.gg-step-num{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:var(--accent);color:var(--surface);display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:800;line-height:1}.gg-step-text{flex:1;min-width:0}.gg-footer{display:flex;flex-direction:column;gap:var(--s-3)}.gg-tokens{display:flex;align-items:center;gap:0;border-radius:12px;border:1px solid var(--border);background:var(--surface);overflow:hidden}.gg-token-row{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 12px}.gg-token-label{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);font-family:var(--font-mono)}.gg-token-value{font-size:1.1rem;font-weight:800}.gg-token-value.bad{color:#ff6b6b}.gg-token-divider{width:1px;align-self:stretch;background:var(--border)}.gg-warn{margin:0;font-size:.82rem;color:var(--text-dim);text-align:center;line-height:1.4}.gg-actions{display:flex;align-items:center;gap:var(--s-3)}.gg-back{background:none;border:none;color:var(--text-dim);font-size:.85rem;cursor:pointer;padding:8px 4px;transition:color .15s;white-space:nowrap}.gg-back:hover{color:var(--text)}.gg-play{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;border:none;border-radius:12px;font-size:1rem;font-weight:800;cursor:pointer;color:var(--surface);background:linear-gradient(135deg,var(--accent),#0ea5e9);box-shadow:0 2px 12px #00ffd540,0 0 0 1px #ffffff14 inset;transition:all .15s ease}.gg-play:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #00ffd559,0 0 0 1px #ffffff1f inset}.gg-play:active:not(:disabled){transform:translateY(0)}.gg-play:disabled{opacity:.45;cursor:not-allowed}.gg-play-inner{display:flex;align-items:center;gap:4px}.gg-broke-icon{font-size:3rem;margin-bottom:var(--s-2)}@media (max-width: 480px){.gg{padding:var(--s-2)}.gg-card{max-width:100%}.gg-demo .demo-scene{height:160px}.gg-body{padding:var(--s-3) var(--s-3) var(--s-4)}.gg-title{font-size:1.15rem}.gg-step{font-size:.78rem;padding:6px 10px}}:root{--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 24px;--s-6: 32px;--s-7: 48px;--s-8: 64px;--tap: 44px;--max-w: 560px;--max-w-wide: 880px;--dur-1: .12s;--dur-2: .22s;--dur-3: .4s;--ease: cubic-bezier(.22, .61, .36, 1);--z-sheet: 80;--z-modal: 100;--z-toast: 120}html[data-theme=hud]{color-scheme:dark;--bg: #05070a;--bg-grad: radial-gradient(1200px 800px at 70% -10%, #0a1828 0%, #05070a 55%);--surface: #0e141c;--surface-2: #131b25;--surface-3: #1a2330;--border: #1e2a38;--border-bright:#2a3b50;--text: #e6edf3;--text-dim: #8a97a8;--text-faint: #5a6776;--accent: #00ffd5;--accent-soft: rgba(0, 255, 213, .14);--accent-2: #ff2e7e;--success: #00ff88;--danger: #ff3b3b;--warning: #ffaa00;--ring: 0 0 0 1px var(--accent), 0 0 20px rgba(0,255,213,.25);--shadow-1: 0 6px 24px rgba(0,0,0,.5);--shadow-2: 0 12px 48px rgba(0,0,0,.6);--radius: 4px;--radius-lg: 8px;--radius-pill: 999px;--font-sans: "Rajdhani", "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", ui-monospace, monospace;--btn-bg: transparent;--btn-bg-hover:var(--accent-soft);--btn-border: var(--accent);--btn-text: var(--accent);--btn-primary-bg: var(--accent);--btn-primary-text: #001814;--grid-line: rgba(0, 255, 213, .06)}html[data-theme=minimal]{color-scheme:light;--bg: #fbfbfd;--bg-grad: linear-gradient(180deg, #fbfbfd 0%, #f3f3f7 100%);--surface: #ffffff;--surface-2: #f5f5f8;--surface-3: #eeeef2;--border: #e5e5ea;--border-bright:#d1d1d6;--text: #111114;--text-dim: #6b6b73;--text-faint: #a0a0a8;--accent: #0a84ff;--accent-soft: rgba(10, 132, 255, .1);--accent-2: #af52de;--success: #34c759;--danger: #ff3b30;--warning: #ff9500;--ring: 0 0 0 3px rgba(10,132,255,.25);--shadow-1: 0 1px 2px rgba(0,0,0,.04), 0 4px 16px rgba(0,0,0,.06);--shadow-2: 0 8px 24px rgba(0,0,0,.08), 0 24px 64px rgba(0,0,0,.1);--radius: 14px;--radius-lg: 22px;--radius-pill: 999px;--font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, sans-serif;--font-mono: ui-monospace, "SF Mono", "JetBrains Mono", monospace;--btn-bg: var(--surface);--btn-bg-hover:var(--surface-2);--btn-border: var(--border);--btn-text: var(--text);--btn-primary-bg: var(--accent);--btn-primary-text: #ffffff;--grid-line: rgba(0,0,0,.04)}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;height:100%}html{-webkit-text-size-adjust:100%;background:var(--bg)}body{font-family:var(--font-sans);color:var(--text);background:var(--bg-grad, var(--bg));background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none;line-height:1.45;font-size:16px}html[data-theme=hud] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);z-index:0}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:none;border:0}button:disabled{cursor:not-allowed;opacity:.45}a{color:var(--accent);text-decoration:none}h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em}html[data-theme=hud] h1,html[data-theme=hud] h2,html[data-theme=hud] h3{font-weight:700;letter-spacing:.02em;text-transform:uppercase}p{margin:0}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.dim{color:var(--text-dim)}.faint{color:var(--text-faint)}.app-root{min-height:100%;min-height:100dvh;display:flex;flex-direction:column;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);position:relative;z-index:1}.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--s-4)}.container-wide{max-width:var(--max-w-wide)}.stack{display:flex;flex-direction:column;gap:var(--s-3)}.stack-lg{display:flex;flex-direction:column;gap:var(--s-5)}.row{display:flex;align-items:center;gap:var(--s-3)}.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3)}.grow{flex:1}.section-title{font-size:.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.12em;margin-bottom:var(--s-2)}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--radius)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);min-height:var(--tap);padding:0 var(--s-4);border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-text);border-radius:var(--radius);font-weight:600;font-size:.95rem;transition:background var(--dur-1) var(--ease),transform var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease),box-shadow var(--dur-1) var(--ease);white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn:hover:not(:disabled){background:var(--btn-bg-hover)}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-color:var(--btn-primary-bg)}html[data-theme=hud] .btn-primary{box-shadow:0 0 24px #00ffd559}.btn-primary:hover:not(:disabled){filter:brightness(1.08);background:var(--btn-primary-bg)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-dim)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-danger:hover:not(:disabled){background:#ff3b3014}.btn-block{width:100%}.btn-sm{min-height:36px;padding:0 var(--s-3);font-size:.85rem}.btn-icon{width:var(--tap);height:var(--tap);padding:0;border-radius:var(--radius)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--s-5);box-shadow:var(--shadow-1)}.card-tight{padding:var(--s-4)}.card-flat{box-shadow:none}.input{width:100%;min-height:var(--tap);padding:0 var(--s-4);background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-size:1rem;transition:border-color var(--dur-1) var(--ease),background var(--dur-1) var(--ease)}.input:focus{border-color:var(--accent);outline:none;background:var(--surface)}.input::placeholder{color:var(--text-faint)}.field{display:flex;flex-direction:column;gap:var(--s-2)}.field-label{font-size:.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--s-4);animation:fade var(--dur-2) var(--ease)}.modal{width:100%;max-width:520px;max-height:calc(100dvh - var(--s-8));overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-2);padding:var(--s-5);animation:pop var(--dur-2) var(--ease)}.modal-title{font-size:1.2rem;margin-bottom:var(--s-2)}.modal-body{color:var(--text-dim);margin-bottom:var(--s-4)}.modal-actions{display:flex;gap:var(--s-2);justify-content:flex-end}.modal-close{margin-left:auto}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-sheet);animation:fade var(--dur-2) var(--ease)}.sheet{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-top:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--s-5) var(--s-4) calc(var(--s-5) + env(safe-area-inset-bottom));z-index:calc(var(--z-sheet) + 1);animation:slideUp var(--dur-3) var(--ease);box-shadow:var(--shadow-2);max-height:85vh;overflow-y:auto}.sheet-handle{width:40px;height:4px;border-radius:999px;background:var(--border-bright);margin:0 auto var(--s-4)}.chip{display:inline-flex;align-items:center;gap:var(--s-1);padding:4px 10px;border-radius:var(--radius-pill);background:var(--surface-2);border:1px solid var(--border);font-size:.78rem;color:var(--text-dim);font-family:var(--font-mono)}.chip-accent{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.chip-danger{color:var(--danger);border-color:var(--danger);background:#ff3b3014}.stat{display:flex;flex-direction:column;gap:2px;padding:var(--s-2) var(--s-3);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);min-width:0}.stat-label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim)}.stat-value{font-family:var(--font-mono);font-size:1.1rem;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}html[data-theme=hud] .stat-value{color:var(--accent)}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
