:root{color-scheme:dark;--bg: #07131d;--panel: rgba(10, 18, 30, .86);--panel-2: rgba(17, 27, 42, .95);--line: rgba(103, 149, 197, .34);--text: #eef7ff;--muted: #9eb5ca;--accent: #7bf0b8;--accent-2: #ffbf4a;--danger: #ff8a80}*{box-sizing:border-box}html,body{min-height:100%}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;font-family:Inter,system-ui,sans-serif;color:var(--text);background:radial-gradient(circle at top,rgba(53,102,158,.8),transparent 40%),linear-gradient(180deg,#102237,var(--bg))}button{border:0;border-radius:999px;padding:.62rem .96rem;font-weight:900;letter-spacing:.01em;background:linear-gradient(135deg,var(--accent),#63c8ff);color:#05111c;cursor:pointer;box-shadow:0 10px 22px #63c8ff2e}#repair-button{background:linear-gradient(135deg,#ffbf4a,#ff8c5a);color:#1d0a12;box-shadow:0 10px 22px #ff7c3d33}select{border:1px solid rgba(123,240,184,.28);border-radius:999px;padding:.58rem .9rem;font-weight:800;color:var(--text);background:#08111dd1}button:disabled{cursor:not-allowed;opacity:.55;box-shadow:none}.shell{width:min(1180px,calc(100% - 16px));margin:10px auto 16px}.topbar,.hud,.game-card,.briefing-bar,.mobile-hero{background:var(--panel);border:1px solid var(--line);border-radius:24px;box-shadow:0 18px 46px #00000047;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;margin-bottom:8px}.topbar-copy{min-width:0}.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.difficulty-picker{display:flex;align-items:center;gap:8px;padding:6px 8px 6px 12px;border-radius:999px;background:#0b1624b8;border:1px solid rgba(103,149,197,.28)}.difficulty-picker span{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:800}.eyebrow,.label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}h1{margin:.05rem 0;font-size:clamp(1.25rem,3.2vw,1.95rem)}.subcopy{margin:0;color:var(--muted);max-width:72ch;font-size:.88rem}.hud{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:6px;padding:6px;margin-bottom:8px}.briefing-bar{display:grid;grid-template-columns:1.2fr .9fr 1fr;gap:8px;padding:8px;margin-bottom:8px}.mobile-hero{display:none}.hero-chip{min-width:0;background:#0a1421e0;border:1px solid rgba(103,149,197,.24);border-radius:14px;padding:7px 9px}.hero-chip strong{display:block;margin-top:2px;font-size:.84rem;line-height:1.1}.hero-chip-primary{background:linear-gradient(180deg,#122926f5,#0c1b26f0);border-color:#7bf0b857}.hero-chip-wide strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.briefing-pill{background:#08111dd6;border:1px solid rgba(103,149,197,.28);border-radius:16px;padding:10px 12px;box-shadow:0 12px 28px #0000002e}.briefing-pill strong{display:block;margin-top:4px;font-size:.92rem}.controls-pill strong{color:var(--muted);font-size:.84rem}.stat{background:var(--panel-2);border:1px solid rgba(72,105,140,.55);border-radius:12px;padding:7px 8px}.stat-primary{background:linear-gradient(180deg,#122926f5,#0c1b26f5);border-color:#7bf0b861}.value{display:block;margin-top:3px;font-size:.92rem;font-weight:900}.money-value{color:var(--accent)}.status-stat .value{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-card{position:relative;padding:8px}.game-area{position:relative;overflow:hidden;width:100%;height:min(82vh,860px);min-height:420px;border-radius:18px;background:linear-gradient(180deg,#9ed6fb,#dff2ff);touch-action:none}#game-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}.overlay{position:absolute;inset:0;display:grid;place-items:center;background:#040a1233;z-index:10;pointer-events:none}.overlay.hidden{display:none}.overlay-card{width:min(540px,calc(100% - 36px));text-align:center;padding:20px 24px;border-radius:22px;background:#070f1ad6;border:1px solid rgba(111,162,212,.42);box-shadow:0 18px 44px #00000047}.overlay-card h2{margin-top:0}.overlay-card p{margin-bottom:0;color:var(--muted)}.controls-layer{position:absolute;inset:0;pointer-events:none;z-index:8}.inplay-controls{position:absolute;left:14px;right:14px;bottom:calc(env(safe-area-inset-bottom,0px) + 12px);display:flex;justify-content:flex-end;align-items:end;pointer-events:none}.repair-fab{pointer-events:auto;min-height:48px;padding:.72rem 1rem;border-radius:18px;box-shadow:0 14px 28px #ff7c3d42}.joystick{position:absolute;left:-999px;top:-999px;transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;transition:opacity .1s ease}.joystick.visible{opacity:1}.joystick-base{position:relative;width:132px;height:132px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 30% 30%,#ffffff29,#040a128f);border:1px solid rgba(255,255,255,.14);box-shadow:0 14px 30px #00000047;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.joystick-ring{position:absolute;inset:16%;border-radius:50%;border:2px dashed rgba(255,255,255,.18)}.joystick-stick{position:absolute;width:44%;height:44%;min-width:48px;min-height:48px;border-radius:50%;background:linear-gradient(180deg,#7bf0b8eb,#63c8ffe6);box-shadow:0 12px 20px #0000003d;transition:transform 45ms linear,box-shadow .12s ease}.joystick.active .joystick-stick{box-shadow:0 0 0 10px #7bf0b81f,0 16px 24px #0000004d}.joystick-caption{display:flex;gap:8px;align-items:center;padding:6px 10px;border-radius:999px;background:#070f1a9e;border:1px solid rgba(255,255,255,.12)}.joystick-title,.joystick-label{font-size:.78rem;font-weight:800}.joystick-title{color:#eef7ff}.joystick-label{color:var(--accent)}@media(max-width:920px){.topbar{flex-direction:column;align-items:stretch}.topbar-actions{width:100%;justify-content:flex-start}.hud{grid-template-columns:repeat(4,minmax(0,1fr))}.briefing-bar{grid-template-columns:1fr}.game-area{height:min(84vh,900px);min-height:460px}}@media(max-width:640px){html,body{height:100%;overflow:hidden}body{background:linear-gradient(180deg,#040a12,#08111e)}.shell{width:100%;height:100dvh;margin:0;padding:6px;display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:5px}.topbar,.hud,.briefing-bar,.game-card,.mobile-hero{border-radius:18px;border:1px solid rgba(98,142,186,.18);box-shadow:0 10px 18px #0000002e}.topbar{margin:0;padding:6px;gap:5px;background:#080f1bc7}.topbar-copy{display:flex;align-items:center;gap:8px;min-width:0}.topbar-copy:before{content:"🚕";font-size:1rem;flex:0 0 auto}.eyebrow,.subcopy{display:none}h1{font-size:.92rem;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:5px;align-items:stretch}.difficulty-picker{grid-column:1 / -1;min-width:0;min-height:38px;padding:4px 8px 4px 10px;gap:6px;justify-content:space-between}.difficulty-picker span{font-size:.52rem}button,select{min-height:38px;font-size:16px;line-height:1.05;touch-action:manipulation}button{padding:.34rem .5rem;box-shadow:none}select{padding:.34rem .5rem;font-size:16px}#repair-button,#pause-button,#reset-button,#start-button{min-width:0;padding-inline:.62rem}.mobile-hero{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;padding:5px;background:#080f1bc7}.hero-chip-wide{grid-column:1 / -1}.hud,.briefing-bar{display:none}.game-card{min-height:0;padding:3px;margin:0;background:#060c1638}.game-area{height:100%;min-height:0;max-height:none;border-radius:15px}.overlay{align-items:end;padding:8px;background:linear-gradient(180deg,#040a1214,#040a1257)}.overlay-card{width:100%;max-width:none;padding:10px 12px;border-radius:15px;text-align:left;background:#070f1ac2}.overlay-card h2{margin:0 0 4px;font-size:.94rem}.overlay-card p{font-size:.74rem;line-height:1.24}body.is-playing .shell,body.is-paused .shell{grid-template-rows:auto auto minmax(0,1fr)}body.is-playing .mobile-hero,body.is-paused .mobile-hero{display:grid;grid-template-columns:auto auto minmax(0,1fr);align-items:stretch;padding:4px 5px;gap:5px;background:#070e18a3}body.is-playing .mobile-hero .hero-chip,body.is-paused .mobile-hero .hero-chip{border-radius:12px;padding:5px 7px;min-width:0;background:#0a1421c7}body.is-playing .mobile-hero .hero-chip .label,body.is-paused .mobile-hero .hero-chip .label{font-size:.46rem;letter-spacing:.08em}body.is-playing .mobile-hero .hero-chip strong,body.is-paused .mobile-hero .hero-chip strong{margin-top:1px;font-size:.72rem;line-height:1.05}body.is-playing .mobile-hero .hero-chip-wide,body.is-paused .mobile-hero .hero-chip-wide{grid-column:auto}body.is-playing .mobile-hero .hero-chip-wide strong,body.is-paused .mobile-hero .hero-chip-wide strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}body.is-playing .topbar,body.is-paused .topbar{padding:5px;background:#070e18a3}body.is-playing .topbar-copy,body.is-paused .topbar-copy{display:none}body.is-playing .topbar-actions,body.is-paused .topbar-actions{grid-template-columns:minmax(0,1.3fr) repeat(2,minmax(0,.85fr))}body.is-playing .difficulty-picker,body.is-paused .difficulty-picker{grid-column:auto;min-height:34px;padding:3px 7px 3px 9px}body.is-playing #reset-button,body.is-paused #reset-button{display:none}.inplay-controls{left:10px;right:10px;bottom:calc(env(safe-area-inset-bottom,0px) + 12px);justify-content:center}.repair-fab{min-width:min(210px,58vw);min-height:46px;padding:.72rem 1rem;border-radius:16px;font-size:.95rem}body.is-prestart .repair-fab,body.is-playing .overlay:not(.hidden)~.controls-layer .repair-fab{opacity:.6}body.is-playing .game-card,body.is-paused .game-card,body.is-prestart .game-card{padding:0;border-radius:20px;background:#060c162e}body.is-playing .game-area,body.is-paused .game-area,body.is-prestart .game-area{border-radius:19px}body.is-playing .overlay.hidden,body.is-prestart .overlay{pointer-events:none}.joystick{gap:6px}.joystick-base{width:108px;height:108px}.joystick-stick{min-width:40px;min-height:40px}.joystick-caption{padding:4px 8px}.joystick-title,.joystick-label{font-size:.66rem}}@media(min-width:641px){.inplay-controls{left:auto;right:18px;bottom:18px}.repair-fab{min-width:168px}}@media(max-width:420px){.topbar-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.difficulty-picker{grid-column:1 / -1}#repair-button,#pause-button,#reset-button,#start-button{width:100%}.hud{grid-template-columns:repeat(3,minmax(0,1fr))}.briefing-bar{grid-template-columns:1fr}}
