:root{--bg: #0a0e27;--surface: #131736;--surface-2: #1b2147;--accent: #00c9a7;--accent-dim: #0a8a76;--text: #e4e7f1;--text-dim: #8a91b8;--danger: #ff5757;--warning: #ffb830;--border: #2a3166;--radius: 14px;--radius-sm: 8px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 8px 24px rgba(0, 0, 0, .35);--font-ui: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-num: "SF Mono", ui-monospace, "Roboto Mono", monospace;--ease: cubic-bezier(.22, 1, .36, 1);--press-scale: .96;--t-fast: .12s;--t-base: .2s}.fk-num{font-family:var(--font-num);font-variant-numeric:tabular-nums;letter-spacing:.02em}.fk-btn{appearance:none;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-family:var(--font-ui);font-weight:600;cursor:pointer;transition:transform var(--t-fast) var(--ease),background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease)}.fk-btn:active{transform:scale(var(--press-scale))}.fk-btn--primary{background:var(--accent);border-color:var(--accent);color:#03150f}.fk-btn--primary:active{background:var(--accent-dim)}@media (prefers-reduced-motion: reduce){.fk-btn{transition:none}}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-ui);overscroll-behavior:none;user-select:none;-webkit-user-select:none;touch-action:none}#app{height:100%;display:flex;flex-direction:column;align-items:center}.stage{position:relative;width:100%;max-width:390px;height:100%;margin:0 auto;display:flex;flex-direction:column}.hud{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);gap:var(--space-2)}.hud .mode{font-size:13px;color:var(--text-dim);font-weight:600;letter-spacing:.04em}.hud .steps{font-size:15px;color:var(--text)}.hud .steps b{color:var(--accent)}.hud .par{color:var(--text-dim);font-size:12px}canvas#maze{display:block;flex:1 1 auto;width:100%;touch-action:none}.plantbar{position:absolute;left:0;right:0;bottom:0;padding:var(--space-3) var(--space-4) calc(var(--space-4) + env(safe-area-inset-bottom));background:linear-gradient(180deg,transparent,rgba(10,14,39,.92) 40%);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);transform:translateY(120%);transition:transform var(--t-base) var(--ease);pointer-events:none}.plantbar.show{transform:translateY(0);pointer-events:auto}.plantbar .label{font-size:13px;color:var(--text-dim)}.plantbar .dirs{display:flex;gap:var(--space-3)}.dirbtn{width:56px;height:56px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:26px;display:flex;align-items:center;justify-content:center;transition:transform var(--t-fast) var(--ease),background var(--t-fast)}.dirbtn:active{transform:scale(.9);background:var(--accent);color:#03150f}.dirbtn.skip{font-size:14px;width:auto;padding:0 var(--space-4);color:var(--text-dim);background:var(--surface)}.toast{position:absolute;left:50%;top:18%;transform:translate(-50%,-8px);background:#131736e6;border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-size:13px;color:var(--text);opacity:0;pointer-events:none;transition:opacity var(--t-base),transform var(--t-base);max-width:80%;text-align:center;line-height:1.4}.toast.show{opacity:1;transform:translate(-50%)}.votepop{position:absolute;background:#131736f5;border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-size:13px;color:var(--text);display:none;flex-direction:column;gap:var(--space-2);z-index:5;box-shadow:var(--shadow-md)}.votepop.show{display:flex}.votepop .counts{display:flex;gap:var(--space-3);font-variant-numeric:tabular-nums}.votepop .counts .up{color:var(--accent)}.votepop .counts .down{color:var(--danger)}.votepop .by{color:var(--text-dim);font-size:11px}.votepop .vbtns{display:flex;gap:var(--space-2)}.votepop .vbtns button{flex:1;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:var(--radius-sm);padding:var(--space-2);font-size:16px}.votepop .vbtns button:active{transform:scale(.92)}.overlay{position:absolute;inset:0;background:#0a0e27f0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-6);text-align:center;z-index:10}.overlay.show{display:flex}.overlay h1{font-size:28px;font-weight:800;letter-spacing:.02em}.overlay .stars{font-size:34px;letter-spacing:.1em}.overlay .stat{color:var(--text-dim);font-size:15px;line-height:1.6}.overlay .stat b{color:var(--accent);font-variant-numeric:tabular-nums}.overlay .row{display:flex;gap:var(--space-3)}.overlay .btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-6);font-size:15px;font-weight:600;transition:transform var(--t-fast) var(--ease)}.overlay .btn:active{transform:scale(.95)}.overlay .btn.primary{background:var(--accent);border-color:var(--accent);color:#03150f}.title{position:absolute;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);z-index:20;padding:var(--space-6);text-align:center}.title.hide{display:none}.title .logo{font-size:44px;font-weight:800;letter-spacing:.12em}.title .logo small{display:block;font-size:14px;color:var(--text-dim);letter-spacing:.3em;margin-top:6px}.title .sub{color:var(--text-dim);font-size:14px;line-height:1.7;max-width:280px}.title .start{background:var(--accent);border:none;color:#03150f;font-weight:700;border-radius:var(--radius);padding:var(--space-4) var(--space-8);font-size:18px;transition:transform var(--t-fast) var(--ease)}.title .start:active{transform:scale(.95)}.title .practice{background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-4);font-size:13px}
