:root{color-scheme:dark;--bg: #07101f;--panel: rgba(10, 18, 32, .92);--panel-border: rgba(148, 163, 184, .14);--text: #e6eef9;--muted: #a6b4c9;--primary: #24c66f;--primary-2: #148c49;--danger: #ef4444;--mobile-top-safe: 78px;--mobile-bottom-safe: 154px}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;min-height:100dvh;overflow:hidden;overscroll-behavior:none}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top,rgba(36,198,111,.08),transparent 30%),linear-gradient(180deg,#0a1020,#050914);color:var(--text);position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;touch-action:none}button{border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:.9rem 1rem;background:#ffffff0a;color:var(--text);font:inherit;font-weight:700;cursor:pointer;transition:.18s ease}button:hover{transform:translateY(-1px);background:#ffffff14}button.primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border-color:#24c66f59;box-shadow:0 14px 32px #24c66f2e}.app-shell{width:min(100%,1320px);height:100dvh;padding:18px;margin:0 auto;display:flex;flex-direction:column;overflow:hidden}.topbar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.topbar h1{margin:8px 0 6px;font-size:clamp(1.9rem,2.5vw,2.6rem)}.topbar p{margin:0;color:var(--muted);line-height:1.6;max-width:720px}.controls-hint{margin-top:8px;color:#e6eef9ad;font-size:.9rem;font-weight:700}.mobile-controls-hint{display:none}.topbar-actions{display:flex;gap:12px;align-items:center}.language-button{min-width:72px}.chip{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:999px;font-size:.86rem;font-weight:700;background:#24c66f24;color:#8ff0b9}.card{background:var(--panel);border:1px solid var(--panel-border);border-radius:28px;box-shadow:0 24px 60px #00000052;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.game-layout{flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center}.ghost-button{min-width:120px}.game-stage{width:100%;height:100%;min-height:0;padding:14px;container-type:size;display:flex;align-items:center;justify-content:center;overflow:hidden}.game-stage-frame{position:relative;width:auto;height:100%;max-width:100%;max-height:100%;aspect-ratio:16 / 9;overflow:hidden;border-radius:24px;border:1px solid rgba(255,255,255,.08);background:#050914}@supports (width: 100cqw){.game-stage-frame{width:min(100cqw,177.7778cqh);height:auto}}.game-canvas{width:100%;height:100%;display:block;touch-action:none;-webkit-user-select:none;user-select:none}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;background:#080c1699;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}.overlay-card{width:min(92%,560px);padding:30px;border-radius:28px;background:#0e1422f7;border:1px solid rgba(255,255,255,.12);text-align:center}.overlay-alert{background:radial-gradient(circle at top,#ef44441a,#0e1422fa 45%)}.overlay-card h2{margin:12px 0 8px;font-size:clamp(1.8rem,2.3vw,2.5rem)}.overlay-card p{margin:0;color:var(--muted);line-height:1.8}.overlay-badge{display:inline-flex;margin-bottom:8px;padding:6px 12px;border-radius:999px;background:#ffffff0f;color:var(--muted);font-size:.84rem}.overlay-sub-badge{margin:0 auto 4px;width:fit-content;padding:4px 10px;border-radius:999px;background:#ef444424;color:#fca5a5;font-size:.78rem;font-weight:700}.overlay-keyhint{margin-top:14px;color:#ffffff8c;font-size:.85rem;letter-spacing:.06em}.overlay-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:22px}.hud-panel{position:absolute;z-index:6;min-width:190px;padding:12px 14px;border-radius:18px;background:#040a14bd;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hud-top-left{top:14px;left:14px}.hud-top-right{top:14px;right:14px;min-width:150px}.hud-row{display:flex;justify-content:space-between;gap:12px;align-items:center;color:var(--text);font-size:.92rem}.hud-strong-row strong{font-size:1.15rem}.hud-track{margin-top:7px;height:12px;border-radius:999px;background:#ffffff14;overflow:hidden}.hud-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#f97316,#ef4444)}.hud-fill.green{background:linear-gradient(90deg,#22c55e,#16a34a)}.hud-track.danger .hud-fill{background:linear-gradient(90deg,#fb923c,#ef4444)}.hud-breath-status{margin-top:6px;color:#bbf7d0;font-size:.78rem;font-weight:800}.mt-12{margin-top:12px}.hud-meta-label{color:var(--muted);font-size:.84rem}.hud-meta-grid{display:grid;gap:8px}.hud-meta-value{margin-top:4px;font-weight:800;font-size:1.1rem}.hud-meta-chip{margin-top:6px;width:fit-content;padding:5px 10px;border-radius:999px;font-size:.82rem;font-weight:700}.danger-low{background:#3b82f629;color:#93c5fd}.danger-medium{background:#fbbf2429;color:#fde68a}.danger-high{background:#ef444429;color:#fca5a5}.hud-objective{position:absolute;left:50%;bottom:16px;transform:translate(-50%);z-index:6;width:min(88%,560px);padding:12px 16px;border-radius:18px;text-align:center;background:#040a14c7;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hud-objective-title{font-weight:800;font-size:1.05rem}.hud-objective-body{margin-top:4px;color:var(--text)}.hud-objective-status{margin-top:6px;color:var(--muted);font-size:.88rem}.mobile-controls{position:absolute;inset:auto 0 0;z-index:8;display:none;align-items:flex-end;justify-content:space-between;gap:18px;padding:0 clamp(14px,4vw,28px) clamp(14px,4vw,24px);pointer-events:none;touch-action:none;-webkit-user-select:none;user-select:none}.mobile-run-hint{position:absolute;left:50%;bottom:clamp(12px,3vw,22px);transform:translate(-50%);max-width:42%;padding:5px 8px;border-radius:999px;background:#040a1485;color:#e6eef9bd;font-size:.68rem;font-weight:800;line-height:1.2;text-align:center;pointer-events:none}.mobile-dpad{pointer-events:auto;display:grid;grid-template-columns:repeat(3,52px);grid-template-rows:repeat(3,52px);gap:6px;touch-action:none}.mobile-control-button{pointer-events:auto;display:grid;place-items:center;width:52px;height:52px;padding:0;border-radius:14px;border-color:#ffffff3d;background:#040a14ad;box-shadow:0 10px 24px #00000047;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-tap-highlight-color:transparent;touch-action:none;-webkit-user-select:none;user-select:none}.mobile-control-button:hover{transform:none}.mobile-control-button:active,.mobile-control-button[data-active=true],.mobile-control-button[data-pressed=true]{background:#24c66f57;border-color:#8ff0b9b8;box-shadow:0 0 0 3px #8ff0b924,0 10px 24px #00000052;transform:translateY(1px) scale(.98)}.mobile-control-button span{overflow:hidden;width:1px;height:1px;clip-path:inset(50%);white-space:nowrap}.mobile-control-button:before{display:block;width:0;height:0;border-style:solid}.mobile-dpad-up{grid-column:2;grid-row:1}.mobile-dpad-left{grid-column:1;grid-row:2}.mobile-dpad-right{grid-column:3;grid-row:2}.mobile-dpad-down{grid-column:2;grid-row:3}.mobile-dpad-up:before{content:"";border-width:0 10px 14px;border-color:transparent transparent var(--text)}.mobile-dpad-left:before{content:"";border-width:10px 14px 10px 0;border-color:transparent var(--text) transparent transparent}.mobile-dpad-right:before{content:"";border-width:10px 0 10px 14px;border-color:transparent transparent transparent var(--text)}.mobile-dpad-down:before{content:"";border-width:14px 10px 0;border-color:var(--text) transparent transparent}.mobile-sprint-button{width:88px;height:88px;border-radius:50%}.mobile-sprint-button[data-active=true],.mobile-sprint-button[data-pressed=true]{background:#24c66f85;border-color:#bbf7d0e0}.mobile-sprint-button:before{content:"RUN";width:auto;height:auto;border:0;font-size:.95rem;font-weight:900;letter-spacing:.04em}@media (pointer: coarse){.is-playing .mobile-controls{display:flex}}@media (max-width: 900px){.topbar{align-items:flex-start;flex-direction:column}.topbar-actions{width:100%}.topbar-actions button{flex:1}.hud-top-left,.hud-top-right{transform:scale(.92);transform-origin:top}}@media (max-width: 640px){.app-shell{padding:10px}.game-stage{padding:8px}.hud-panel{min-width:auto;padding:10px 12px}.hud-top-left{left:8px;top:8px}.hud-top-right{right:8px;top:8px}.hud-objective{bottom:106px;width:min(94%,440px)}.mobile-dpad{grid-template-columns:repeat(3,48px);grid-template-rows:repeat(3,48px)}.mobile-control-button{width:48px;height:48px}.mobile-sprint-button{width:82px;height:82px}}@media (max-height: 620px){.app-shell{padding:10px}.topbar{margin-bottom:8px}.topbar h1{margin:0 0 2px;font-size:clamp(1.35rem,3.4vw,1.8rem)}.topbar p{font-size:.9rem;line-height:1.35}.topbar button{padding:.65rem .8rem}.game-stage{padding:8px}}@media (max-height: 480px){.topbar p,.hud-objective{display:none}.mobile-controls{padding-bottom:8px}.mobile-dpad{grid-template-columns:repeat(3,42px);grid-template-rows:repeat(3,42px)}.mobile-control-button{width:42px;height:42px}.mobile-sprint-button{width:68px;height:68px}}@media (pointer: coarse) and (max-width: 900px){:root{--mobile-top-safe: 76px;--mobile-bottom-safe: 150px}body{background:#050914}button:hover{transform:none}.app-shell{width:100%;height:100dvh;padding:max(8px,env(safe-area-inset-top)) max(8px,env(safe-area-inset-right)) max(8px,env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left));max-width:none;background:#050914}.topbar{display:none}.screen-menu{justify-content:center;padding:max(14px,env(safe-area-inset-top)) 18px max(18px,env(safe-area-inset-bottom));background:radial-gradient(circle at 50% 12%,rgba(36,198,111,.16),transparent 32%),linear-gradient(180deg,#0b1424,#050914)}.screen-menu .topbar{display:flex;flex-direction:column;align-items:stretch;justify-content:center;flex:0 0 auto;gap:18px;margin:0}.screen-menu .topbar h1{margin:0 0 8px;font-size:clamp(2rem,10vw,3rem);line-height:.98}.screen-menu .topbar p{max-width:30rem;font-size:.98rem;line-height:1.45}.controls-hint{margin-top:10px;font-size:.88rem;line-height:1.35}.desktop-controls-hint{display:none}.mobile-controls-hint{display:inline}.screen-menu .topbar-actions{width:100%;display:grid;grid-template-columns:1fr auto auto;gap:10px}.screen-menu .topbar-actions button{min-height:52px;padding:.75rem .9rem;border-radius:14px}.screen-menu .ghost-button{min-width:0;background:linear-gradient(135deg,var(--primary),var(--primary-2));border-color:#8ff0b975}.screen-menu .game-layout{display:none}.game-layout{width:100%;height:100%}.game-stage{width:100%;height:100%;padding:0;border:0;border-radius:0;box-shadow:none;background:#050914;-webkit-backdrop-filter:none;backdrop-filter:none}.game-stage-frame{width:100%;height:100%;max-width:none;max-height:none;aspect-ratio:auto;border:0;border-radius:0}.overlay{align-items:center;padding:max(14px,env(safe-area-inset-top)) 16px max(14px,env(safe-area-inset-bottom));background:#050914b8}.overlay-card{width:min(100%,440px);max-height:calc(100dvh - 32px - env(safe-area-inset-top) - env(safe-area-inset-bottom));padding:20px;border-radius:20px;overflow:hidden}.overlay-card h2{margin:8px 0 6px;font-size:clamp(1.55rem,8vw,2.25rem);line-height:1.05}.overlay-card p{display:-webkit-box;line-height:1.45;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.overlay-actions{margin-top:16px}.overlay-actions button{min-height:48px;padding:.7rem .9rem;border-radius:14px}.hud-panel{padding:8px 9px;border-radius:12px;background:#040a1494;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}.hud-top-left{top:max(8px,env(safe-area-inset-top));left:max(8px,env(safe-area-inset-left));width:min(45vw,170px);min-width:132px;transform:none}.hud-top-right{top:max(8px,env(safe-area-inset-top));right:max(8px,env(safe-area-inset-right));width:min(38vw,144px);min-width:122px;transform:none}.hud-row{gap:8px;font-size:.72rem}.hud-strong-row strong,.hud-meta-value{font-size:.86rem}.hud-track{height:7px;margin-top:4px}.hud-breath-status{margin-top:4px;font-size:.66rem}.mt-12{margin-top:7px}.hud-meta-label{font-size:.68rem}.hud-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.hud-meta-chip{margin-top:4px;padding:3px 7px;font-size:.66rem}.hud-top-right .hud-meta-label.mt-12{display:none}.hud-top-right .hud-meta-chip{max-width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.hud-objective{top:calc(max(8px,env(safe-area-inset-top)) + 58px);bottom:auto;left:50%;width:min(calc(100% - 18px),390px);padding:7px 10px;border-radius:12px;background:#040a1480}.hud-objective-title{display:none}.hud-objective-body,.hud-objective-status{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-size:.72rem}.hud-objective-body{margin-top:0;font-weight:700}.hud-objective-status{margin-top:2px;color:#e6eef9b8}.is-playing .hud-objective{display:none}.mobile-controls{min-height:var(--mobile-bottom-safe);padding:0 max(18px,env(safe-area-inset-right)) max(14px,env(safe-area-inset-bottom)) max(18px,env(safe-area-inset-left));background:linear-gradient(180deg,transparent 0%,rgba(5,9,20,.36) 45%,rgba(5,9,20,.72) 100%)}.mobile-run-hint{bottom:max(12px,env(safe-area-inset-bottom))}.mobile-dpad{grid-template-columns:repeat(3,46px);grid-template-rows:repeat(3,46px);gap:5px}.mobile-control-button{width:46px;height:46px;border-radius:13px;background:#070e1a94;border-color:#e6eef93d;box-shadow:0 8px 20px #0000003d}.mobile-sprint-button{width:76px;height:76px;margin-bottom:14px;background:#24c66f38;border-color:#8ff0b96b}}@media (pointer: coarse) and (max-width: 900px) and (orientation: landscape){:root{--mobile-top-safe: 56px;--mobile-bottom-safe: 104px}.app-shell{padding:max(6px,env(safe-area-inset-top)) max(8px,env(safe-area-inset-right)) max(6px,env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left))}.hud-top-left,.hud-top-right{top:max(6px,env(safe-area-inset-top))}.hud-objective{display:none}.mobile-controls{min-height:var(--mobile-bottom-safe);padding-bottom:max(8px,env(safe-area-inset-bottom))}.mobile-run-hint{display:none}.mobile-dpad{grid-template-columns:repeat(3,40px);grid-template-rows:repeat(3,40px)}.mobile-control-button{width:40px;height:40px}.mobile-sprint-button{width:66px;height:66px;margin-bottom:12px}}
