@font-face{font-family:SourceSerifDisplay;font-weight:400;src:url(../assets/fonts/SourceSerif4Display-Regular.ttf) format("truetype")}@font-face{font-family:SourceSerifDisplay;font-weight:600;src:url(../assets/fonts/SourceSerif4Display-Semibold.ttf) format("truetype")}@font-face{font-family:SourceSerifDisplay;font-weight:700;src:url(../assets/fonts/SourceSerif4Display-Bold.ttf) format("truetype")}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;background:#0d0721;color:#fff;font-family:SourceSerifDisplay,Times New Roman,serif;overflow:hidden;overscroll-behavior:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:none}#game-root{position:fixed;inset:0;width:100vw;height:100vh;overflow:hidden;background:#07041a}#game-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}#hud-root{position:absolute;inset:0;pointer-events:none}#hud-root>*{pointer-events:auto}#loading-screen{position:absolute;inset:0;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;background:#07041a;transition:opacity .5s ease}#loading-screen.hidden{opacity:0;pointer-events:none}.loading-title{font-family:SourceSerifDisplay,serif;font-weight:600;font-size:36px;letter-spacing:.2em;text-transform:uppercase;color:#ffffffd9}.loading-bar{width:200px;height:2px;background:#ffffff1f;border-radius:1px;overflow:hidden}#loading-bar-fill{height:100%;width:0;background:#ffffffd9;transition:width .2s ease-out}.top-left-hud{position:absolute;top:env(safe-area-inset-top,12px);left:env(safe-area-inset-left,16px);padding:16px 0 0 8px;pointer-events:none;font-family:SourceSerifDisplay,serif}.score-row{display:flex;align-items:center;gap:6px;color:#ffffff8c;font-size:11px;letter-spacing:.05em}.score-row .arrow-icon{width:10px;height:10px;display:inline-block}.score-value{font-size:28px;font-weight:600;color:#fffffff2;font-variant-numeric:tabular-nums;letter-spacing:.02em;margin-top:-2px;line-height:1.05}.multiplier-row{display:flex;align-items:center;gap:8px;margin-top:4px}.multiplier-value{font-size:14px;font-weight:600;color:#f4c842;font-variant-numeric:tabular-nums}.multiplier-row.decaying .multiplier-value{color:#f56}.decay-bar{width:56px;height:2px;background:#f4c8422e;border-radius:1px;overflow:hidden}.multiplier-row.decaying .decay-bar{background:#ff55662e}.decay-fill{height:100%;width:100%;background:#f4c842;transition:width .2s linear,background .2s ease}.multiplier-row.decaying .decay-fill{background:#f56}.multiplier-row.hidden{display:none}.top-right-hud{position:absolute;top:env(safe-area-inset-top,12px);right:env(safe-area-inset-right,16px);padding:16px 8px 0 0;pointer-events:none;text-align:right;font-family:SourceSerifDisplay,serif}.top-right-hud .label{font-size:11px;color:#ffffff8c;letter-spacing:.05em}.top-right-hud .value{font-size:28px;font-weight:600;color:#fffffff2;font-variant-numeric:tabular-nums;margin-top:-2px;line-height:1.05}.best-chip{margin-top:6px;font-family:SourceSerifDisplay,serif;font-size:10px;color:#ffffff59;letter-spacing:.12em;text-transform:uppercase}.best-chip .v{font-size:12px;color:#fff9;margin-left:4px}.fuel-gauge{position:absolute;left:max(env(safe-area-inset-left,16px),16px);bottom:max(env(safe-area-inset-bottom,24px),24px);display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none}.fuel-bar{width:8px;height:140px;background:#ffffff14;border-radius:4px;overflow:hidden;position:relative}.fuel-bar-fill{position:absolute;left:0;right:0;bottom:0;background:#ff8a00;border-radius:4px;transition:height .2s ease-out,background .2s ease-out}.fuel-bar.danger .fuel-bar-fill{background:#ff3b30}.fuel-label{display:flex;align-items:center;gap:4px;font-size:10px;color:#ffffff80;letter-spacing:.08em;text-transform:lowercase;font-family:SourceSerifDisplay,serif}.fuel-flame{width:8px;height:9px;fill:#ff8a00}.fuel-gauge.danger .fuel-flame{fill:#ff3b30}.fuel-gauge.danger .fuel-label{color:#ff5050a6}.joystick{position:absolute;right:max(env(safe-area-inset-right,24px),24px);bottom:max(env(safe-area-inset-bottom,40px),40px);width:60px;height:240px;display:flex;align-items:center;justify-content:center;touch-action:none}.joystick-track{position:absolute;width:8px;height:200px;background:#ffffff14;border-radius:4px}.joystick-glow{position:absolute;width:18px;height:200px;background:#ff8a0000;border-radius:9px;filter:blur(8px);transition:background .1s}.joystick.active .joystick-glow{background:#ff8a0059}.joystick-thumb{position:absolute;width:28px;height:16px;background:#ffffffe6;border-radius:8px;box-shadow:0 0 8px #ffffff59;pointer-events:none;will-change:transform}.game-over{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#07041a8c;backdrop-filter:blur(2px);font-family:SourceSerifDisplay,serif;animation:fade-in .5s ease;padding:0 24px}.game-over-status{font-size:22px;font-weight:400;color:#ffffffe6;margin-bottom:24px;letter-spacing:.01em}.game-over-score{font-size:84px;font-weight:700;color:#fffffff7;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-.01em}.game-over-best-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#ffffff80;margin-top:14px}.game-over-new-best{color:#f4c842}.game-over-stats{width:min(360px,80vw);margin-top:36px;display:flex;flex-direction:column;gap:14px}.game-over-row{display:flex;justify-content:space-between;align-items:baseline;font-size:16px;color:#ffffffc7}.game-over-row .v{font-variant-numeric:tabular-nums;color:#ffffffeb;font-weight:600}.play-again{width:min(360px,80vw);margin-top:36px;padding:18px 0;border:none;border-top:1px solid rgba(255,255,255,.18);border-bottom:1px solid rgba(255,255,255,.18);border-radius:0;background:transparent;color:#fffffff2;font-family:SourceSerifDisplay,serif;font-size:22px;font-weight:600;letter-spacing:.01em;cursor:pointer;outline:none;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none;transition:color .15s ease}.play-again:hover{color:#fff}.play-again:active{transform:scale(.99)}.play-again:focus,.play-again:focus-visible{outline:none;border-top-color:#ffffff59;border-bottom-color:#ffffff59}.pause-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;backdrop-filter:blur(4px);font-family:SourceSerifDisplay,serif;font-size:24px;letter-spacing:.2em;text-transform:uppercase;opacity:.85}@keyframes fade-in{0%{opacity:0}to{opacity:1}}
