:root{color-scheme:dark;--ink: #f3f0e8;--muted: #b9b3a6;--panel: rgba(23, 25, 27, .82);--panel-solid: #1b1e20;--line: rgba(255, 255, 255, .14);--warm: #e3b448;--teal: #2fbf9f;--danger: #ff4f8f;--button: #343b38;--button-active: #405247;--dock-pad: max(8px, env(safe-area-inset-bottom, 0px));font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;overflow:hidden;background:#101214;color:var(--ink)}button{border:1px solid var(--line);border-radius:8px;background:var(--button);color:var(--ink);cursor:pointer;font:inherit;min-height:36px;padding:8px 10px;touch-action:manipulation;transition:background .14s ease,border-color .14s ease,color .14s ease}button:hover:not(:disabled),button.active{background:var(--button-active);border-color:#e3b4488c}button:disabled{cursor:not-allowed}#app,#battlefield{height:100vh;height:100dvh;width:100vw}#battlefield{display:block}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0}.panel-summary{color:var(--warm);font-size:11px;font-weight:800}.fps-counter{background:#10121485;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#f3f0e8a8;font-size:10px;font-variant-numeric:tabular-nums;font-weight:800;left:max(8px,env(safe-area-inset-left,0px));line-height:1;min-width:46px;padding:5px 6px;pointer-events:none;position:fixed;text-align:center;top:max(8px,env(safe-area-inset-top,0px));z-index:3}.fps-counter.warn{border-color:#ff4f8f61;color:#ffbed2e0}.squad-strip{position:fixed;top:max(8px,env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);display:flex;justify-content:center;max-width:min(100vw,560px);padding:2px 6px;z-index:3;pointer-events:none}.squad-strip.collapsed{max-height:none}.chip-track{display:flex;gap:8px;overflow-x:auto;padding:2px;scroll-snap-type:x proximity;scrollbar-width:none;-webkit-overflow-scrolling:touch;pointer-events:auto}.chip-track::-webkit-scrollbar{display:none}.squad-card{position:relative;flex:0 0 auto;width:46px;height:46px;min-height:46px;padding:0;display:grid;place-items:center;border:2px solid var(--chip, var(--line));border-radius:50%;background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--ink);scroll-snap-align:center;transition:transform .14s ease,box-shadow .14s ease}.chip-id{font-size:13px;font-weight:900;letter-spacing:.02em;line-height:1}.chip-hp{position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:50%;background:conic-gradient(var(--hp-color, var(--teal)) calc(var(--hp, 100) * 3.6deg),rgba(255,255,255,.14) 0);-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 calc(100% - 3px));mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 calc(100% - 3px));pointer-events:none}.squad-card.low .chip-hp{--hp-color: var(--danger)}.chip-dot{position:absolute;bottom:-1px;right:-1px;width:11px;height:11px;border-radius:50%;border:2px solid var(--panel-solid);background:var(--teal)}.squad-card.guard .chip-dot{background:var(--warm)}.squad-card.alert .chip-dot{background:var(--danger)}.squad-card.active{transform:translateY(-3px);box-shadow:0 0 0 2px var(--teal),0 6px 16px #2fbf9f66}.squad-card.down{opacity:.42}.squad-card.down .chip-dot{background:var(--danger)}.status-pill{position:fixed;top:max(8px,env(safe-area-inset-top,0px));right:max(8px,env(safe-area-inset-right,0px));z-index:5;display:flex;align-items:center;gap:7px;height:34px;padding:0 11px;border-radius:999px;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--line);color:var(--muted)}.pill-ico{width:15px;height:15px;flex:0 0 auto}.pill-ico.gear{opacity:.78}.pill-text{display:flex;align-items:baseline;gap:7px;font-size:11px;font-weight:800;white-space:nowrap}.pill-round{color:var(--ink)}.pill-signals{color:var(--warm)}.hud-dock{position:fixed;left:50%;bottom:0;transform:translate(-50%);width:min(720px,calc(100vw - 64px));display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:0 8px var(--dock-pad);z-index:4;pointer-events:none}.hud-dock>*{pointer-events:auto}.command-bar{display:flex;flex-direction:column;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--line);border-bottom:0;border-radius:12px 12px 0 0;box-shadow:0 16px 48px #00000052;overflow:hidden}.unit-header{display:flex;align-items:center;gap:8px;min-height:26px;padding:5px 10px;border-bottom:1px solid var(--line);font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden}.unit-header .uh-name{color:var(--ink);font-weight:800;overflow:hidden;text-overflow:ellipsis}.unit-header .uh-role{overflow:hidden;text-overflow:ellipsis}.unit-header .uh-spacer{flex:1 1 auto}.unit-header .uh-tu{font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums}.unit-header .action-pips{margin-top:0}.unit-header.empty{color:var(--muted);font-style:italic}.action-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;padding:7px 6px}.action-row button{position:relative;width:44px;height:44px;min-width:44px;min-height:44px;padding:0;display:grid;place-items:center;border-radius:11px;color:var(--muted);background:#ffffff08}.action-row button .act-ico{width:22px;height:22px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.6))}.action-row button:hover:not(:disabled){color:var(--ink);background:#ffffff14;border-color:#e3b44873}.action-row button.active{color:var(--teal);background:#2fbf9f2e;border-color:#2fbf9fb3;box-shadow:inset 0 -3px 0 var(--teal)}.action-row button:disabled{opacity:.38;color:#77756f}.action-row button.weapon-slot-button.active{border-color:#2fbf9fc7}.action-row button.extract{color:var(--teal);background:#2fbf9f33;border-color:#2fbf9fb8}.badge{position:absolute;bottom:-3px;right:-3px;min-width:15px;height:15px;padding:0 3px;border-radius:8px;background:var(--panel-solid);border:1px solid var(--line);color:var(--warm);font-size:9px;font-weight:900;font-style:normal;line-height:13px;text-align:center;font-variant-numeric:tabular-nums}.badge.cd{color:var(--muted)}.badge.charge{color:var(--warm)}.badge.mode{color:var(--teal)}.end-turn{display:inline-flex;align-items:center;justify-content:center;position:fixed;right:max(12px,env(safe-area-inset-right,0px));bottom:max(12px,env(safe-area-inset-bottom,0px));z-index:6;width:46px;height:42px;min-height:42px;padding:0;border-radius:12px;border:1px solid rgba(227,180,72,.6);background:#e3b44833;color:var(--warm);box-shadow:0 10px 30px #00000052}.end-turn:hover:not(:disabled){background:#e3b44857;color:var(--ink)}.end-turn:disabled{opacity:.4;background:#ffffff0a;border-color:var(--line);color:var(--muted)}.end-ico{width:18px;height:18px}.target-strip{align-content:flex-start;display:flex;align-items:flex-start;flex-wrap:wrap;gap:5px;justify-content:flex-end;align-self:center;max-height:min(30vh,184px);max-width:100%;padding:5px;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:9px;box-shadow:0 12px 36px #0000004d;overflow-x:hidden;overflow-y:auto;scrollbar-width:thin}.target-strip[hidden]{display:none}.target-token{align-items:center;display:grid;flex:0 1 122px;gap:6px;grid-template-columns:24px minmax(56px,1fr) auto;min-height:36px;min-width:108px;padding:4px 7px;border-radius:8px;text-align:left}.target-token.active{background:#e3b4482e;border-color:#e3b448b8}.target-glyph{align-items:center;background:#ff4f8f2e;border:1px solid rgba(255,79,143,.5);border-radius:999px;color:#ffd4e5;display:inline-flex;font-size:12px;font-weight:900;height:24px;justify-content:center;width:24px}.target-copy{display:grid;gap:2px;min-width:0}.target-copy>span:first-child{font-size:10px;font-weight:900;line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.target-token strong{color:var(--warm);font-size:11px;font-variant-numeric:tabular-nums}.log-toasts{position:absolute;left:0;right:0;bottom:100%;margin-bottom:8px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:0 8px;pointer-events:none;z-index:4}.log-toast{max-width:min(640px,calc(100vw - 24px));padding:7px 14px;border-radius:999px;background:#101214d6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);box-shadow:0 8px 24px #00000061;color:var(--muted);font-size:12px;line-height:1.35;text-align:center;animation:toast-life 4.6s ease forwards}.log-toast strong{color:var(--ink)}@keyframes toast-life{0%{opacity:0;transform:translateY(8px)}9%{opacity:1;transform:translateY(0)}72%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}@keyframes toast-fade{0%{opacity:0}9%{opacity:1}72%{opacity:1}to{opacity:0}}.unit-dot{border-radius:99px;height:12px;width:12px;flex:0 0 auto}.health-pips{align-items:center;display:inline-flex;gap:3px;vertical-align:-1px}.armor-pips{align-items:center;display:inline-flex;gap:3px;margin-left:4px;vertical-align:-1px}.health-pip{background:#ffffff1a;border:1px solid rgba(255,255,255,.28);display:inline-block;height:10px;width:10px}.armor-pip{background:#ffffff14;border:1px solid rgba(255,255,255,.3);display:inline-block;height:10px;transform:skew(-10deg);width:9px}.health-pip.full{background:#2fbf9f;border-color:#2fbf9feb}.armor-pip.full{background:#8fb3ff;border-color:#8fb3fff2}.action-pips{display:inline-flex;gap:4px}.action-pip{background:#ffffff29;border-radius:99px;display:block;height:7px;width:18px}.action-pip.full{background:var(--warm)}.tu-meter{background:#ffffff1f;border-radius:99px;display:inline-block;height:8px;overflow:hidden;position:relative;vertical-align:-1px;width:54px}.tu-fill{background:linear-gradient(90deg,var(--warm),var(--teal));display:block;height:100%}.tu-text{display:none}.action-tooltip{background:var(--panel-solid);border:1px solid var(--line);border-radius:6px;box-shadow:0 12px 36px #0000006b;color:var(--muted);font-size:11px;line-height:1.25;max-width:230px;padding:7px 9px;pointer-events:none;position:fixed;z-index:9}.action-tooltip[hidden]{display:none}.action-tooltip strong{color:var(--ink);display:block;font-size:11px;margin-bottom:2px}.action-tooltip span{display:block}.sensor-overlay{align-items:center;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:var(--panel);border:1px solid rgba(227,180,72,.72);border-radius:10px;box-shadow:0 16px 48px #00000047;color:var(--warm);display:flex;font-size:13px;font-weight:900;gap:12px;left:50%;padding:10px 14px;position:fixed;text-transform:uppercase;top:54px;transform:translate(-50%);z-index:6}.start-mission-button{border-color:#2fbf9fb3;background:#2fbf9f33;color:var(--ink);font-size:12px;font-weight:900;min-height:36px;padding:6px 12px;text-transform:uppercase}.settings-overlay{align-items:center;background:#0000006b;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;position:fixed;z-index:10}.settings-overlay[hidden],.sensor-overlay[hidden]{display:none}.settings-modal{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 16px 48px #00000047;padding:16px;position:relative;width:min(340px,calc(100vw - 28px))}.settings-status{border:1px solid var(--line);border-radius:6px;color:var(--muted);display:grid;font-size:12px;gap:6px;margin-bottom:12px;padding:10px}.settings-heading{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.settings-heading h2{font-size:18px;margin:0}.toggle-row{align-items:center;border-top:1px solid var(--line);display:flex;font-size:14px;justify-content:space-between;min-height:48px}.toggle-row input{accent-color:var(--teal);height:20px;width:20px}@media(min-width:760px){.hud-dock{padding-left:0;padding-right:0}.command-bar{border-radius:12px;border-bottom:1px solid var(--line);margin-bottom:6px}}@media(max-width:420px){.squad-strip{max-width:calc(100vw - 12px)}.pill-text{flex-direction:column;gap:0;line-height:1.15}.status-pill{height:38px}.target-strip{max-height:104px}.target-token{flex-basis:106px;min-width:100px}}@media(pointer:coarse){.command-bar,.target-strip,.status-pill,.squad-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@media(prefers-reduced-motion:reduce){.squad-card{transition:none}.squad-card.active{transform:none}.log-toast{animation-name:toast-fade}}
