.hud{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;font-family:ui-monospace,monospace;color:#cdebff;text-shadow:0 0 8px rgba(47,210,255,.6);-webkit-user-select:none;user-select:none}.hud-top{position:absolute;top:16px;left:0;right:0;display:flex;justify-content:space-between;padding:0 24px;font-size:15px;letter-spacing:2px}.hud-stat b{color:#fff;font-size:18px}.hud-sub{opacity:.7}.hud-bottom{position:absolute;bottom:22px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:6px;font-size:13px;letter-spacing:2px}.hud-bar-row{display:grid;grid-template-columns:46px 280px 56px;align-items:center;gap:10px}.hud-bar{height:14px;border:1px solid #2fd2ff66;background:#0a1622;box-shadow:0 0 12px #2fd2ff44}.hud-bar-fill{height:100%;transition:width .15s linear}.hud-bar-fill.hp{background:linear-gradient(90deg,#ff3a4a,#ffe14a,#4af2ff)}.hud-bar-fill.core{background:linear-gradient(90deg,#ff6a2a,#2fd2ff)}.hud-bar-num{color:#fff;text-align:right;font-size:13px}.hud-banner{position:absolute;top:28%;left:0;right:0;text-align:center;font-size:34px;letter-spacing:6px;color:#2fd2ff;animation:hud-pulse 1.2s ease-in-out infinite}@keyframes hud-pulse{0%,to{opacity:.35}50%{opacity:1}}.hud-titlecard{position:absolute;top:24%;left:0;right:0;text-align:center;color:#cdebff;text-shadow:0 0 16px rgba(47,210,255,.85);animation:hud-titlecard-in 2s ease-out forwards}.hud-titlecard-num{font-size:28px;letter-spacing:8px;color:#2fd2ff;opacity:.85}.hud-titlecard-name{font-size:56px;letter-spacing:10px;margin-top:8px}@keyframes hud-titlecard-in{0%{opacity:0;transform:translateY(-12px)}15%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0}}.hud-clearcard{position:absolute;top:26%;left:0;right:0;text-align:center;color:#b7ffd2;text-shadow:0 0 18px rgba(80,255,160,.7);animation:hud-clearcard-in 2.8s ease-out forwards}.hud-clearcard-tag{font-size:52px;letter-spacing:12px;font-weight:700}.hud-clearcard-sub{font-size:22px;letter-spacing:6px;margin-top:10px;color:#cdebff}@keyframes hud-clearcard-in{0%{opacity:0;transform:scale(.96)}12%{opacity:1;transform:scale(1)}85%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.02)}}.hud-stat.hud-railplus b{color:#bff5ff;text-shadow:0 0 14px #2fd2ffcc;animation:hud-railplus-pulse 1.4s ease-in-out infinite}@keyframes hud-railplus-pulse{0%,to{text-shadow:0 0 10px #2fd2ff88}50%{text-shadow:0 0 22px #2fd2ffff}}.hud-end{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#05060ac7;pointer-events:auto}.hud-end h1{font-size:64px;letter-spacing:10px;margin:0}.hud-end h1.win{color:#2fd2ff}.hud-end h1.lose{color:#ff3a4a;text-shadow:0 0 14px #ff3a4a88}.hud-end p{font-size:20px;letter-spacing:4px}.hud-end button{margin-top:16px;padding:12px 34px;font:inherit;font-size:18px;letter-spacing:3px;color:#05060a;background:#2fd2ff;border:0;cursor:pointer;box-shadow:0 0 20px #2fd2ff88}.hud-end button:hover{background:#7fe4ff}@media (max-height: 540px){.hud-top{font-size:12px;letter-spacing:1px;padding:0 14px}.hud-stat b{font-size:14px}.hud-sub{display:none}.hud-bottom{bottom:12px;gap:4px;font-size:11px}.hud-bar-row{grid-template-columns:38px 190px 42px;gap:8px}.hud-bar{height:11px}.hud-end h1{font-size:44px}.hud-end p{font-size:16px}}.tc-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;pointer-events:none;touch-action:none;user-select:none;-webkit-user-select:none}.tc-stick{position:absolute;bottom:26px;width:88px;height:88px;border-radius:50%;pointer-events:auto;touch-action:none;background:radial-gradient(circle,#0a14204d,#05060a14);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:.4;transition:opacity .16s ease}.tc-stick.is-engaged{opacity:.96}.tc-move{left:26px;--c: #46e0ff;--glow: rgba(70, 224, 255, .55)}.tc-aim{right:26px;--c: #ffb765;--glow: rgba(255, 183, 101, .5)}.tc-art{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;fill:none;pointer-events:none}.tc-rim{stroke:var(--c);stroke-width:1.4;opacity:.75}.tc-guide{stroke:var(--c);stroke-width:1;opacity:.22;stroke-dasharray:2 5}.tc-tick line,.tc-cross line{stroke:var(--c);stroke-width:1.5;stroke-linecap:round;opacity:.7}.tc-bracket path{stroke:var(--c);stroke-width:1.6;stroke-linecap:round;opacity:.85}.tc-dot{fill:var(--c);opacity:.9}.tc-knob{position:absolute;left:50%;top:50%;width:30px;height:30px;margin:-15px 0 0 -15px;border-radius:50%;background:radial-gradient(circle at 50% 38%,#ffffff,var(--c) 70%);border:1px solid rgba(255,255,255,.65);box-shadow:0 0 12px var(--glow);will-change:transform}.tc-fire{position:absolute;right:112px;bottom:80px;width:70px;height:70px;border-radius:50%;padding:0;border:0;background:transparent;pointer-events:auto;touch-action:none;display:grid;place-items:center;opacity:.6;transition:opacity .16s ease,transform .09s ease;--c: #ff4d5e}.tc-fire:active{opacity:1;transform:scale(.93)}.tc-fire-art{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;fill:none;pointer-events:none}.tc-fire-rim{stroke:var(--c);stroke-width:1.6;opacity:.8}.tc-fire-tick line{stroke:var(--c);stroke-width:1.8;stroke-linecap:round;opacity:.7}.tc-fire-core{stroke:var(--c);stroke-width:1;opacity:.5;fill:#ff4d5e00;transition:fill .09s ease}.tc-fire:active .tc-fire-core{fill:#ff4d5ed9}.tc-fire-label{position:relative;z-index:1;font-family:ui-monospace,monospace;font-size:11px;font-weight:700;letter-spacing:2px;color:#ffdadf;text-shadow:0 0 6px rgba(255,77,94,.6)}@media (max-height: 480px){.tc-stick{width:76px;height:76px;bottom:16px}.tc-move{left:16px}.tc-aim{right:16px}.tc-knob{width:26px;height:26px;margin:-13px 0 0 -13px}.tc-fire{width:60px;height:60px;right:92px;bottom:62px}.tc-fire-label{font-size:10px}}@media (prefers-reduced-motion: reduce){.tc-stick,.tc-fire,.tc-fire-core{transition:none}}.orient-hint{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#05060aeb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;pointer-events:auto;color:#cdebff;font-family:ui-monospace,monospace;text-shadow:0 0 12px rgba(47,210,255,.55)}.orient-icon{font-size:72px;color:#2fd2ff;animation:orient-rock 2s ease-in-out infinite}.orient-text{font-size:24px;letter-spacing:6px}.orient-sub{font-size:14px;letter-spacing:2px;opacity:.7}@keyframes orient-rock{0%,to{transform:rotate(-22deg)}50%{transform:rotate(68deg)}}
