:root{--bg: #0d0f14;--panel: #171a22;--line: #262b36;--text: #e8ecf2;--muted: #8a93a6;--accent: #7cf6c8;--high: #7cf6c8;--mid: #ffd25a;--low: #ff6b7a}*{box-sizing:border-box}html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-tap-highlight-color:transparent}#app{height:100vh;height:100dvh}.screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;gap:16px}.menu-screen{justify-content:flex-start;padding-top:8vh}.menu-title{font-size:2.4rem;margin:0;letter-spacing:.04em}.menu-tagline{color:var(--muted);margin:0 0 8px;text-align:center}.seed-list{width:100%;max-width:420px;display:flex;flex-direction:column;gap:10px}.record-btn{width:100%;max-width:420px;padding:14px 18px;background:var(--low);color:#2a0a0e;border:none;border-radius:14px;font-weight:700;font-size:1rem;cursor:pointer}.record-btn:active{transform:scale(.99)}.seed-card{display:flex;align-items:stretch;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}.seed-main{flex:1;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;background:transparent;border:none;color:var(--text);font-size:1.05rem;cursor:pointer;text-align:left}.seed-main:active{transform:scale(.99)}.seed-name{font-weight:600}.seed-meta{color:var(--muted);font-size:.85rem}.seed-delete,.seed-export,.seed-publish{flex:0 0 auto;width:44px;border:none;border-left:1px solid var(--line);background:transparent;color:var(--muted);font-size:1rem;cursor:pointer}.seed-publish:active{color:var(--accent)}.seed-publish:disabled{color:var(--accent);opacity:.8}.seed-export:active{color:var(--accent)}.seed-delete:active{color:var(--low)}.menu-note{color:var(--muted);font-size:.8rem;text-align:center;max-width:360px}.telemetry-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;width:100%;max-width:420px;color:var(--muted);font-size:.8rem}.telemetry-link{background:transparent;border:1px solid var(--line);color:var(--text);border-radius:8px;padding:4px 10px;font-size:.78rem;cursor:pointer}.telemetry-link:active{transform:scale(.98)}.play-screen{padding:0;gap:0;position:relative;overflow:hidden;background:#000}.player-stage{position:absolute;inset:0;background:#000;overflow:hidden}.player-stage.mirror{transform:scaleX(-1)}.camera,.ghost,.target-full{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.ghost{pointer-events:none}.cam-hidden{inset:auto auto 0 0;width:2px;height:2px;opacity:.01;pointer-events:none}.flip-x{transform:scaleX(-1)}.target-hint{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:3;background:#00000080;border:1px solid var(--line);border-radius:999px;padding:8px 14px;color:var(--text);font-size:.85rem;text-align:center;white-space:nowrap}.instant-score{position:absolute;top:12px;right:14px;z-index:4;display:flex;flex-direction:column;align-items:flex-end;line-height:1}.instant-num{font-size:3rem;font-weight:800;font-variant-numeric:tabular-nums;text-shadow:0 2px 12px rgba(0,0,0,.6)}.instant-cap{margin-top:3px;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-shadow:0 1px 6px rgba(0,0,0,.7)}.instant-score[data-tier=high] .instant-num{color:var(--high)}.instant-score[data-tier=mid] .instant-num{color:var(--mid)}.instant-score[data-tier=low] .instant-num{color:var(--low)}.instant-score[data-tier=none] .instant-num{font-size:1rem;color:var(--muted);font-weight:600}.countdown{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:6rem;font-weight:800;color:var(--accent);background:#00000073;z-index:5}.play-controls{position:absolute;top:10px;left:10px;z-index:4}.btn-ghost{background:#0006;border:1px solid var(--line);color:var(--muted);border-radius:10px;padding:6px 10px;font-size:.8rem}.perf-readout{position:absolute;top:48px;left:10px;z-index:4;font-family:ui-monospace,monospace;font-size:.72rem;color:var(--muted);background:#00000073;border:1px solid var(--line);border-radius:8px;padding:4px 8px}.debug-bars{position:absolute;left:10px;bottom:10px;width:70%;max-width:300px;z-index:4;display:none}.debug-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.debug-label{width:92px;font-size:.68rem;color:var(--muted);text-align:right}.debug-track{position:relative;flex:1;height:10px;background:#ffffff14;border-radius:5px;overflow:hidden}.debug-ghost{position:absolute;inset:0 auto 0 0;background:#7cf6c859}.debug-fill{position:absolute;inset:0 auto 0 0;background:#5aa0ff}.result-screen{gap:14px}.result-total{display:flex;flex-direction:column;align-items:center}.result-num{font-size:4.5rem;font-weight:800;color:var(--accent);line-height:1}.result-cap{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-size:.75rem}.result-sub{display:flex;gap:16px;color:var(--muted);font-size:.9rem}.result-sub .warn{color:var(--mid)}.result-graph{width:100%;max-width:480px;background:var(--panel);border:1px solid var(--line);border-radius:14px}.result-buttons{display:flex;gap:12px}.rec-indicator{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:4;display:flex;align-items:center;gap:8px;background:#00000080;border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-variant-numeric:tabular-nums;font-weight:700}.rec-dot{width:12px;height:12px;border-radius:50%;background:var(--low);animation:rec-pulse 1s infinite}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.3}}.rec-stop{position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:4;padding:12px 28px;background:var(--low);color:#2a0a0e;border:none;border-radius:999px;font-weight:700;font-size:1rem;cursor:pointer}.save-screen{gap:14px}.save-heading{font-size:1.3rem;font-weight:700}.save-preview{width:100%;max-width:300px;aspect-ratio:3 / 4;object-fit:cover;background:#000;border-radius:16px;border:1px solid var(--line)}.save-title{width:100%;max-width:300px;padding:12px 14px;background:var(--panel);border:1px solid var(--line);border-radius:12px;color:var(--text);font-size:1rem}.save-warn{color:var(--mid);font-size:.85rem;text-align:center;max-width:300px}.btn{padding:12px 22px;background:var(--accent);color:#06281f;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer}.btn:active{transform:scale(.98)}.loading,.error-screen{color:var(--muted);text-align:center;gap:16px}
