@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)}.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)}}.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-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}}.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:linear-gradient(180deg,#0b3d1e,#156b2f 55%,#1b8a3d);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-meter{height:22px}.ak-meter-label{margin-bottom:2px}html[data-theme=minimal] .ak-field{background:linear-gradient(180deg,#2f9f52,#3cb968 55%,#4cd07a)}.ak-yardlines{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(to top,rgba(255,255,255,.16) 0px,rgba(255,255,255,.16) 2px,transparent 2px,transparent 48px);pointer-events:none}.ak-goalposts{position:absolute;top:6%;left:50%;transform:translate(-50%);width:62%;height:18%;pointer-events:none}.ak-goalposts .ak-crossbar{position:absolute;top:45%;left:0;right:0;height:6px;background:#fbbf24;border-radius:2px;box-shadow:0 2px #00000040}.ak-goalposts .ak-upright{position:absolute;top:0;width:6px;height:100%;background:#fbbf24;border-radius:2px;box-shadow:0 2px #00000040}.ak-goalposts .ak-upright.l{left:0}.ak-goalposts .ak-upright.r{right:0}.ak-goalposts .ak-base{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:6px;height:55%;background:#fbbf24;border-radius:2px}.ak-ball{position:absolute;left:50%;bottom:6%;transform:translate(-50%);width:26px;height:36px;border-radius:50% 50% 45% 45%/60% 60% 40% 40%;background:radial-gradient(ellipse at 30% 30%,#a66a3a,#6b3a18 75%);box-shadow:inset 0 -4px 8px #0000004d,0 4px 10px #00000073;transform-origin:50% 50%;will-change:transform,left,bottom}.ak-ball:before,.ak-ball:after{content:"";position:absolute;background:#e8d5b5}.ak-ball:before{top:50%;left:15%;right:15%;height:2px;transform:translateY(-1px)}.ak-ball:after{top:35%;bottom:35%;left:50%;width:2px;transform:translate(-1px);box-shadow:-4px 0 #e8d5b5,4px 0 #e8d5b5}.ak-ball.flying{filter:drop-shadow(0 6px 10px rgba(0,0,0,.3))}.ak-trail{position:absolute;left:50%;bottom:6%;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 50% 50%,#ffffff8c,#fff0);pointer-events:none;animation:ak-trail-fade .34s ease-out forwards}@keyframes ak-trail-fade{0%{opacity:.7}to{opacity:0;transform:translate(-50%) scale(.4)}}.ak-shadow{position:absolute;left:50%;bottom:calc(6% - 6px);width:28px;height:8px;border-radius:50%;background:radial-gradient(ellipse at center,#0000008c,#0000 70%);pointer-events:none}.ak-sky{position:absolute;top:0;left:0;right:0;height:28%;background:linear-gradient(180deg,#0c1e3c8c,#0c1e3c00);pointer-events:none}html[data-theme=minimal] .ak-sky{background:linear-gradient(180deg,#78b4ff73,#78b4ff00)}.ak-crowd{position:absolute;top:22%;left:0;right:0;height:18px;background:radial-gradient(circle at 4% 100%,#1a2230 0 7px,transparent 8px),radial-gradient(circle at 12% 100%,#222a3a 0 7px,transparent 8px),radial-gradient(circle at 20% 100%,#1a2230 0 7px,transparent 8px),radial-gradient(circle at 28% 100%,#2a3240 0 7px,transparent 8px),radial-gradient(circle at 36% 100%,#1a2230 0 7px,transparent 8px),radial-gradient(circle at 44% 100%,#222a3a 0 7px,transparent 8px),radial-gradient(circle at 52% 100%,#1a2230 0 7px,transparent 8px),radial-gradient(circle at 60% 100%,#2a3240 0 7px,transparent 8px),radial-gradient(circle at 68% 100%,#1a2230 0 7px,transparent 8px),radial-gradient(circle at 76% 100%,#222a3a 0 7px,transparent 8px),radial-gradient(circle at 84% 100%,#1a2230 0 7px,transparent 8px),radial-gradient(circle at 92% 100%,#2a3240 0 7px,transparent 8px),linear-gradient(180deg,#0b121d,#0b121d);pointer-events:none}.ak-net{position:absolute;top:45%;bottom:0;left:3px;right:3px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 1px,transparent 1px 10px),repeating-linear-gradient(0deg,rgba(255,255,255,.18) 0 1px,transparent 1px 10px);opacity:.5;pointer-events:none;border-radius:0 0 6px 6px}.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-distance-chip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:6px 12px;border-radius:999px;background:#00000073;color:#fff;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.08em;pointer-events:none}.ak-wind{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:.78rem;letter-spacing:.06em;display:flex;align-items:center;gap:6px;pointer-events:none}.ak-result{position:absolute;top:28%;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:ak-pop .9s ease forwards}.ak-result.good{background:#22c55ee6;color:#052e16}.ak-result.miss{background:#ef4444e6;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-meter{position:relative;width:100%;height:26px;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:4px}.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)}}.gl-wrap{display:flex;flex-direction:column;gap:var(--s-3)}.gl-tabs{display:flex;gap:var(--s-2);overflow-x:auto;padding-bottom:var(--s-1);scrollbar-width:thin}.gl-tabs::-webkit-scrollbar{height:6px}.gl-tabs::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}.gl-tab{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-pill);background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:.88rem;white-space:nowrap;transition:border-color var(--dur-1) var(--ease),color var(--dur-1) var(--ease),background var(--dur-1) var(--ease)}.gl-tab:hover{color:var(--text);border-color:var(--border-bright)}.gl-tab.active{background:var(--accent-soft);border-color:var(--accent);color:var(--text)}html[data-theme=hud] .gl-tab.active{box-shadow:0 0 0 1px var(--accent),0 0 20px #00ffd538}.gl-tab-icon{font-size:1.05rem;line-height:1}.gl-tab-name{font-weight:700;letter-spacing:-.005em}@media (max-width: 480px){.gl-tab-name{display:none}}.gl-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--s-3) var(--s-3) var(--s-4)}.gl-panel-head{margin-bottom:var(--s-2)}.gl-panel-title{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim)}.gl-panel-icon{font-size:1.1rem}.hub-hero-wrap{position:relative;border-bottom:1px solid var(--border);padding:var(--s-5) 0 var(--s-4)}.hub-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 30%,transparent 80%)}.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.35;pointer-events:none}.orb-1{width:360px;height:360px;background:var(--accent);top:-180px;right:-120px}.orb-2{width:320px;height:320px;background:var(--accent-2);bottom:-180px;left:-120px;opacity:.28}html[data-theme=minimal] .orb{opacity:.22}.hub-hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:var(--s-3)}.hub-title{font-size:clamp(1.8rem,5.5vw,3rem);font-weight:900;line-height:1.05;letter-spacing:-.02em;margin:0;max-width:22ch}.grad-text{background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}html[data-theme=hud] .grad-text{filter:drop-shadow(0 0 20px rgba(0,255,213,.3))}.hub-sub{font-size:.98rem;line-height:1.5;color:var(--text-dim);max-width:56ch;margin:0}.hub-ctas{display:flex;flex-wrap:wrap;gap:var(--s-2);margin-top:var(--s-1)}.btn-lg{min-height:44px;padding:0 var(--s-4);font-size:.98rem;border-radius:var(--radius-lg)}.arcade-band{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);padding:var(--s-4);border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent-soft),color-mix(in oklab,var(--accent-2) 15%,transparent));border:1px solid var(--accent);flex-wrap:wrap}.arcade-band-title{font-weight:800;font-size:1.15rem;margin-top:2px}.arcade-band-sub{font-size:.85rem;margin-top:2px;max-width:48ch}.cat-grid{display:grid;grid-template-columns:1fr;gap:var(--s-4)}@media (min-width: 720px){.cat-grid{grid-template-columns:1fr 1fr}}@media (min-width: 1100px){.cat-grid{grid-template-columns:repeat(3,1fr)}}.cat-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--s-3);display:flex;flex-direction:column;gap:var(--s-3);height:100%}.cat-head{display:flex;flex-direction:column;gap:2px;min-height:44px;margin-bottom:0;flex-wrap:nowrap}.cat-section .cat-blurb{display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;font-size:.8rem;line-height:1.3}.cat-section .game-grid{grid-template-columns:1fr!important;gap:var(--s-2);flex:1;align-content:start}.cat-section .game-card{background:var(--surface-2);border-color:var(--border);min-height:86px}.cat-section .game-desc{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.3em}.container.hub-body{margin-top:var(--s-5);margin-bottom:var(--s-5);padding-top:var(--s-4)}.cat-head{display:flex;align-items:baseline;gap:var(--s-3);margin-bottom:var(--s-2);flex-wrap:wrap}.cat-kicker{color:var(--accent);font-size:.68rem;letter-spacing:.22em}.cat-blurb{font-size:.85rem}.game-grid{display:grid;grid-template-columns:1fr;gap:var(--s-2)}@media (min-width: 640px){.game-grid{grid-template-columns:1fr 1fr}}@media (min-width: 960px){.game-grid{grid-template-columns:repeat(3,1fr)}}.game-card{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:var(--s-3);padding:var(--s-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);text-decoration:none;transition:border-color var(--dur-1) var(--ease),transform var(--dur-1) var(--ease)}.game-card:hover{border-color:var(--accent);transform:translateY(-1px)}html[data-theme=hud] .game-card:hover{box-shadow:0 0 0 1px var(--accent),0 0 24px #00ffd52e}.game-icon{width:44px;height:44px;display:grid;place-items:center;background:var(--accent-soft);border-radius:var(--radius);font-size:1.4rem}.game-name{font-weight:700;font-size:.98rem;letter-spacing:-.005em}.game-desc{font-size:.82rem;margin-top:2px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.game-arrow{color:var(--text-dim);font-size:.85rem;transition:color var(--dur-1) var(--ease),transform var(--dur-1) var(--ease)}.game-card:hover .game-arrow{color:var(--accent);transform:translate(2px)}.cta-band{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);padding:var(--s-5);border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent-soft),transparent),var(--surface);border:1px solid var(--border);flex-wrap:wrap}.cta-kicker{color:var(--accent);font-size:.68rem;letter-spacing:.22em;margin-bottom:2px}.cta-title{font-weight:800;font-size:clamp(1.05rem,2.4vw,1.35rem);max-width:28ch;line-height:1.2}@media (max-width: 640px){.cta-band{padding:var(--s-4)}.cta-band .btn-lg{width:100%}}.transparency p{line-height:1.55;margin:0 0 var(--s-3)}.transparency p:last-child{margin-bottom:0}.transparency a{color:var(--accent)}.data-list{list-style:none;padding:0;margin:0 0 var(--s-3);display:flex;flex-direction:column;gap:var(--s-2)}.data-list li{padding:var(--s-3);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);line-height:1.5;font-size:.95rem}.plaza-wrap{position:relative;max-width:960px;margin:0 auto;padding:var(--s-4);display:flex;flex-direction:column;gap:var(--s-3)}@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%;aspect-ratio:15 / 12;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}.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}.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);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;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-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)}.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)}: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}}
