:root{color-scheme:dark;--bg: #0d0f10;--surface: #151819;--surface-2: #1b2021;--surface-3: #222827;--line: rgba(255, 255, 255, .12);--line-strong: rgba(255, 255, 255, .2);--text: #f2f5ef;--muted: #a9b1aa;--soft: #747f79;--green: #49d37d;--teal: #58c4ff;--gold: #f0b84a;--red: #ff665c;--violet: #b58aff;--amber-dark: #3a2914;--shadow: 0 22px 70px rgba(0, 0, 0, .34);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:geometricPrecision}*{box-sizing:border-box}html{min-height:100%;background:var(--bg)}body{min-width:320px;min-height:100vh;margin:0;color:var(--text);background:linear-gradient(180deg,rgba(255,255,255,.04),transparent 180px),linear-gradient(90deg,rgba(73,211,125,.035),transparent 32%,rgba(181,138,255,.025)),var(--bg);letter-spacing:0}button,a{font:inherit;letter-spacing:0}button{color:inherit}button:focus-visible,a:focus-visible,.district:focus-visible{outline:2px solid var(--teal);outline-offset:2px}#root{min-height:100vh}.app-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr}.topbar{min-height:82px;display:grid;grid-template-columns:minmax(260px,1fr) auto auto;gap:18px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line);background:#0d0f10db;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);position:sticky;top:0;z-index:20}.brand-block{display:flex;align-items:center;gap:13px;min-width:0}.brand-mark{width:48px;height:48px;display:grid;place-items:center;flex:0 0 auto;color:var(--green);border:1px solid rgba(73,211,125,.44);border-radius:8px;background:linear-gradient(135deg,#49d37d33,#58c4ff1f),#101513}.eyebrow{display:block;color:var(--gold);font-size:.72rem;line-height:1.1;font-weight:700;text-transform:uppercase;letter-spacing:0}h1,h2,h3,h4,p{margin:0}h1{font-size:1.22rem;line-height:1.15;font-weight:760;overflow-wrap:anywhere}.phase-switcher{display:grid;grid-template-columns:repeat(4,minmax(84px,1fr));gap:6px;padding:5px;border:1px solid var(--line);border-radius:8px;background:#ffffff0a}.phase-switcher button{border:0;border-radius:6px;min-height:48px;padding:7px 9px;cursor:pointer;color:var(--muted);background:transparent;display:grid;align-content:center;gap:2px}.phase-switcher button span{display:block;color:var(--soft);font-size:.68rem}.phase-switcher button.is-active{color:var(--text);background:linear-gradient(135deg,#58c4ff2e,#f0b84a24);box-shadow:inset 0 0 0 1px #ffffff1f}.phase-switcher button.is-active span{color:var(--gold)}.top-actions{display:flex;gap:8px;justify-self:end}.icon-action,.text-button{border:1px solid var(--line);border-radius:8px;background:var(--surface-2);color:var(--text);min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;cursor:pointer}.icon-action:hover,.text-button:hover{border-color:var(--line-strong);background:var(--surface-3)}.icon-action.quiet{width:42px;padding:0;color:var(--muted)}.app-main{display:grid;grid-template-columns:88px 1fr;grid-template-rows:auto 1fr auto;gap:14px;padding:14px;min-height:0}.view-rail{grid-row:1 / 4;display:grid;gap:9px;align-content:start;padding:8px;border:1px solid var(--line);border-radius:8px;background:#ffffff09}.view-rail button{min-height:68px;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;gap:5px;padding:8px 5px}.view-rail button span{font-size:.68rem;line-height:1.05}.view-rail button.is-active{color:var(--text);border-color:#58c4ff52;background:#58c4ff1f}.status-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.status-strip article{min-height:58px;display:grid;grid-template-columns:auto 1fr auto;gap:9px;align-items:center;padding:11px 13px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.status-strip svg{color:var(--teal)}.status-strip span{color:var(--muted);min-width:0}.status-strip strong{color:var(--text);font-size:1.05rem}.workbench{min-height:0;animation:pulse-in .22s ease-out}@keyframes pulse-in{0%{transform:translateY(3px);opacity:.86}to{transform:translateY(0);opacity:1}}.operations-layout{display:grid;grid-template-columns:minmax(480px,1.45fr) minmax(360px,.95fr);gap:14px;min-height:720px}.map-shell,.ops-panel,.workspace-view{border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,#ffffff0b,#ffffff05),var(--surface);box-shadow:var(--shadow)}.map-shell{position:relative;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto;min-height:720px}.particle-field{position:absolute;inset:0;width:100%;height:100%;opacity:.72;pointer-events:none}.map-head{position:relative;z-index:1;display:flex;justify-content:space-between;gap:12px;align-items:start;padding:17px}.map-head h2,.view-title h2,.phase-card h2{font-size:1.32rem;line-height:1.12}.map-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:end}.map-badges span{padding:6px 8px;border-radius:999px;color:var(--text);background:#ffffff14;border:1px solid var(--line);font-size:.78rem}.map-stage{position:relative;z-index:1;min-height:0;display:grid;place-items:center;padding:4px 14px 10px}.city-map{width:100%;max-height:560px;aspect-ratio:1.38 / 1;overflow:visible;border-radius:8px;background:linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.03) 1px,transparent 1px),#101314;background-size:36px 36px}.water-body{fill:url(#waterGradient)}.canal-line,.ridge-line{fill:none;stroke:#fff3;stroke-width:.8;stroke-dasharray:2 2}.district{cursor:pointer;stroke:#ffffff57;stroke-width:.44;transition:opacity .16s ease,stroke-width .16s ease,filter .16s ease}.district:hover,.district.is-selected{stroke:var(--text);stroke-width:1.1;filter:url(#softGlow)}.route-layer path,.grid-layer path{fill:none;stroke:#ffffff38;stroke-width:1.1;stroke-linecap:round;stroke-dasharray:3 2}.route-layer .route-hot{stroke:var(--green);stroke-width:1.7;stroke-dasharray:5 2;animation:dash 3s linear infinite}.route-layer .route-hot.grid,.grid-layer .grid-stable{stroke:var(--teal)}@keyframes dash{to{stroke-dashoffset:-20}}.hazard-flood path,.hazard-flood circle{fill:#58c4ff6b}.hazard-fire path{fill:#ff665c8a}.hazard-fire circle{fill:#f0b84ab8}.grid-layer path{stroke:#f0b84a85;stroke-width:.9}.map-facility{width:100%;height:100%;border:1px solid currentColor;border-radius:6px;background:#0d0f10e0;display:grid;place-items:center;padding:0;cursor:pointer}.map-facility.is-boosted{background:#49d37d2e;box-shadow:0 0 14px #49d37d59}.sensor-layer circle{fill:var(--teal);stroke:var(--bg);stroke-width:.8}.sensor-layer text,.map-labels text,.graph-link text{fill:#f2f5efb8;font-size:2.25px;font-weight:700;pointer-events:none}.map-labels text{text-anchor:middle;font-size:2.65px;fill:#f2f5efdb;paint-order:stroke;stroke:#0d0f10e6;stroke-width:.7}.map-unit{width:100%;height:100%;display:grid;place-items:center;color:var(--text);background:#0d0f10e0;border:1px solid rgba(255,255,255,.28);border-radius:999px;animation:unit-breathe 1.9s ease-in-out infinite}@keyframes unit-breathe{50%{transform:scale(1.08)}}.district-strip{position:relative;z-index:1;display:grid;grid-template-columns:minmax(170px,.8fr) minmax(260px,1.2fr);gap:14px;padding:14px 17px 16px;border-top:1px solid var(--line);background:#0d0f107a}.district-strip strong{display:block;margin-top:3px;font-size:1.1rem}.district-strip dl{margin:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.district-strip dt{color:var(--muted);font-size:.68rem}.district-strip dd{margin:3px 0 0;font-size:1rem;font-weight:800}.district-strip p{grid-column:1 / -1;color:var(--muted);line-height:1.4}.ops-panel{min-height:720px;overflow:hidden auto;padding:13px}.phase-card{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center;padding:14px;border-radius:8px;background:linear-gradient(135deg,#f0b84a1f,#58c4ff14),var(--surface-2);border:1px solid var(--line)}.phase-card p{color:var(--muted);margin-top:9px;line-height:1.4}.gauge-ring{width:118px;height:118px;position:relative;display:grid;place-items:center;flex:0 0 auto}.gauge-ring svg{width:112px;height:112px;transform:rotate(-90deg)}.gauge-track,.gauge-fill{fill:none;stroke-width:9}.gauge-track{stroke:#ffffff1a}.gauge-fill{stroke:var(--green);stroke-linecap:round;transition:stroke-dashoffset .26s ease}.gauge-label{position:absolute;inset:0;display:grid;place-content:center;text-align:center}.gauge-label strong{font-size:1.55rem;line-height:1}.gauge-label span,.gauge-label small{display:block;color:var(--muted);font-size:.68rem;margin-top:3px}.metrics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;margin-top:11px}.metric-card{min-height:132px;display:grid;gap:7px;padding:11px;border-radius:8px;border:1px solid var(--line);background:#ffffff09}.metric-topline{display:flex;justify-content:space-between;gap:7px;align-items:center;color:var(--muted);font-size:.76rem}.metric-pill{border-radius:999px;padding:3px 6px;font-size:.66rem;background:#ffffff14}.metric-value{font-size:2.1rem;line-height:1;font-weight:850}.metric-value span{margin-left:3px;color:var(--muted);font-size:.84rem}.sparkline{width:100%;height:38px;align-self:end}.tone-good{--tone: var(--green)}.tone-warn{--tone: var(--gold)}.tone-danger{--tone: var(--red)}.tone-calm{--tone: var(--teal)}.metric-card.tone-good{border-color:#49d37d47}.metric-card.tone-warn{border-color:#f0b84a57}.metric-card.tone-danger{border-color:#ff665c5c}.panel-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.section-title,.view-title,.playbook-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-title h3{font-size:.92rem}.section-title span{color:var(--muted);font-size:.76rem}.layer-buttons{margin-top:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.icon-toggle,.playbook-chip{min-height:42px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:#ffffff0a;display:flex;align-items:center;justify-content:center;gap:7px;padding:0 8px;cursor:pointer}.icon-toggle span,.playbook-chip span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-toggle.is-on,.playbook-chip.is-active{color:var(--text);border-color:#58c4ff57;background:#58c4ff1c}.incident-list,.quick-playbooks{display:grid;gap:8px;margin-top:10px}.incident-card{display:grid;grid-template-columns:auto 1fr;gap:10px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#ffffff09}.incident-priority{min-width:40px;height:40px;display:grid;place-items:center;color:var(--gold);border-radius:8px;background:#f0b84a1f}.priority-p1 .incident-priority{color:var(--red);background:#ff665c21}.incident-card h4{font-size:.86rem;line-height:1.25}.incident-card p{margin-top:5px;color:var(--muted);font-size:.75rem;line-height:1.35}.quick-playbooks{grid-template-columns:1fr}.lives-card{margin-top:10px;display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px;border-radius:8px;background:#49d37d17;border:1px solid rgba(73,211,125,.24)}.lives-card span{color:var(--muted)}.lives-card strong{font-size:1.35rem}.workspace-view{min-height:720px;padding:18px;overflow:hidden}.view-title{margin-bottom:16px}.view-title h2{margin-top:3px}.forecast-layout{display:grid;grid-template-columns:minmax(420px,1fr) minmax(280px,.42fr);gap:14px}.forecast-map,.forecast-controls,.graph-canvas,.dependency-panel,.simulation-ledger,.research-card,.audit-card{border:1px solid var(--line);border-radius:8px;background:#ffffff09}.forecast-map{min-height:442px;display:grid;place-items:center;padding:16px}.forecast-map svg,.graph-canvas svg{width:100%;height:100%;min-height:390px}.forecast-land{fill:#ffffff14;stroke:#ffffff2e}.forecast-surge{fill:#58c4ff6b}.forecast-fire{fill:#ff665c8c}.forecast-road{fill:none;stroke:var(--green);stroke-width:1.4;stroke-dasharray:4 2}.forecast-road.risk{stroke:var(--red);stroke-width:.9}.forecast-point{fill:#f0b84a5c;stroke:#ffffff80;stroke-width:.5}.forecast-controls{padding:14px;align-content:start}.horizon-buttons{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.horizon-buttons button{min-height:48px;border:1px solid var(--line);border-radius:8px;background:#ffffff0a;color:var(--muted);cursor:pointer}.horizon-buttons button.is-active{color:var(--text);border-color:#f0b84a66;background:#f0b84a1f}.forecast-readouts{display:grid;gap:10px;margin-top:14px}.forecast-readouts article{padding:13px;border-radius:8px;background:var(--surface-2);display:flex;justify-content:space-between}.forecast-readouts span{color:var(--muted)}.forecast-readouts strong{font-size:1.2rem}.branch-grid{margin-top:14px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.branch-card{padding:14px;border-radius:8px;border:1px solid var(--line);background:var(--surface-2)}.bar-row,.outcome-row{display:grid;grid-template-columns:74px 1fr 48px;gap:10px;align-items:center;margin-top:13px;color:var(--muted)}.bar-row div,.outcome-row div{height:8px;border-radius:999px;overflow:hidden;background:#ffffff14}.bar-row i,.outcome-row i{display:block;height:100%;border-radius:inherit;background:var(--tone, var(--teal))}.bar-row strong,.outcome-row strong{color:var(--text);text-align:right}.network-score,.playbook-score,.evidence-stamp{display:grid;justify-items:end}.network-score strong,.playbook-score strong,.evidence-stamp strong{font-size:1.6rem;line-height:1}.network-score span,.playbook-score span,.evidence-stamp span{color:var(--muted);font-size:.76rem}.network-grid{display:grid;grid-template-columns:minmax(460px,1fr) minmax(320px,.46fr);gap:14px}.graph-canvas{min-height:584px;padding:14px}.graph-link path{fill:none;stroke-width:1.35;stroke:var(--tone, var(--teal));opacity:.78}.graph-link text{text-anchor:middle;font-size:2.8px;fill:var(--muted)}.graph-node circle{fill:#ffffff0f;stroke:#ffffff38;stroke-width:.8}.graph-node.type-power circle{stroke:var(--gold)}.graph-node.type-medical circle{stroke:var(--red)}.graph-node.type-shelter circle{stroke:var(--green)}.graph-node.type-comms circle{stroke:var(--teal)}.graph-node text{fill:var(--text);text-anchor:middle;font-size:3px;font-weight:800;paint-order:stroke;stroke:#0d0f10cc;stroke-width:.6}.dependency-panel{padding:14px;display:grid;align-content:start;gap:10px}.cascade-card{display:grid;grid-template-columns:1fr auto;gap:12px;padding:13px;border-radius:8px;background:var(--surface-2);border:1px solid var(--line)}.cascade-card h3{font-size:.92rem}.cascade-card p{margin-top:6px;color:var(--muted);line-height:1.42;font-size:.82rem}.cascade-card strong{font-size:1.35rem;color:var(--gold)}.playbook-layout{display:grid;grid-template-columns:minmax(460px,1fr) minmax(360px,.58fr);gap:14px}.playbook-stack{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.playbook-card{min-height:254px;padding:14px;border-radius:8px;border:1px solid var(--line);background:#ffffff09}.playbook-card.is-active{border-color:#49d37d57;background:#49d37d14}.playbook-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:8px;color:var(--gold);background:#f0b84a1c;flex:0 0 auto}.playbook-card-head{justify-content:start}.playbook-card-head h3{font-size:1rem}.playbook-card-head p{margin-top:4px;color:var(--muted);font-size:.78rem}.switch-button{margin-left:auto;width:42px;height:24px;border:1px solid var(--line);border-radius:999px;background:#ffffff14;padding:2px;cursor:pointer}.switch-button span{display:block;width:18px;height:18px;border-radius:50%;background:var(--muted);transition:transform .16s ease}.switch-button[aria-pressed=true]{border-color:#49d37d80;background:#49d37d2e}.switch-button[aria-pressed=true] span{transform:translate(16px);background:var(--green)}.effect-line{margin-top:14px;padding:9px;border-radius:8px;color:var(--muted);background:#ffffff0d;font-size:.77rem}.playbook-card ol{margin:13px 0 0;padding-left:21px;color:var(--text)}.playbook-card li{margin-top:8px;color:var(--muted);line-height:1.3}.simulation-ledger{padding:14px}.ledger-hero{min-height:152px;display:grid;place-content:center;text-align:center;border-radius:8px;background:linear-gradient(135deg,#49d37d2e,#b58aff1c),var(--surface-2)}.ledger-hero strong{display:block;margin-top:8px;font-size:2.7rem;line-height:1}.ledger-hero p{margin-top:7px;color:var(--muted)}.outcome-matrix{margin-top:14px}.outcome-row{grid-template-columns:90px 1fr 62px}.outcome-row strong small{display:block;color:var(--soft);font-size:.62rem}.ledger-timeline{margin-top:16px;display:grid;gap:9px}.ledger-timeline article{display:grid;grid-template-columns:auto 1fr;gap:10px;padding:11px;border:1px solid var(--line);border-radius:8px;background:#ffffff09}.ledger-timeline article>span{color:var(--green);font-weight:800}.ledger-timeline h3{font-size:.9rem}.ledger-timeline p{margin-top:4px;color:var(--muted);font-size:.78rem}.evidence-layout{display:grid;grid-template-columns:minmax(360px,.78fr) minmax(500px,1.22fr);gap:14px}.source-grid{display:grid;gap:10px}.source-card{display:block;min-height:126px;padding:14px;color:inherit;text-decoration:none;border:1px solid var(--line);border-radius:8px;background:#ffffff09}.source-card:hover{border-color:#58c4ff5c;background:#58c4ff14}.source-card span{color:var(--gold);font-size:.72rem;text-transform:uppercase;font-weight:800}.source-card h3{margin-top:8px;font-size:1rem}.source-card p{margin-top:8px;color:var(--muted);line-height:1.42;font-size:.83rem}.research-column{display:grid;grid-template-columns:1fr .88fr;gap:14px}.research-card,.audit-card{padding:14px}.research-card article,.audit-card article{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:12px 0;border-top:1px solid var(--line)}.research-card article:first-of-type,.audit-card article:first-of-type{margin-top:8px}.research-card strong,.audit-card time{color:var(--gold);font-weight:800}.research-card p,.audit-card p{color:var(--muted);line-height:1.43;font-size:.83rem}.audit-card h3{font-size:.9rem}.bottom-command{min-height:58px;display:grid;grid-template-columns:auto auto 1fr;gap:12px;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.bottom-command div{display:flex;align-items:center;gap:8px}.bottom-command span,.bottom-command p{color:var(--muted);line-height:1.35}.bottom-command strong{color:var(--text)}@media(max-width:1180px){.topbar{grid-template-columns:1fr}.phase-switcher,.top-actions{justify-self:stretch}.top-actions{justify-content:end}.operations-layout,.forecast-layout,.network-grid,.playbook-layout,.evidence-layout,.research-column{grid-template-columns:1fr}.map-shell,.ops-panel,.workspace-view{min-height:auto}}@media(max-width:820px){.app-main{grid-template-columns:1fr}.view-rail{grid-row:auto;grid-template-columns:repeat(5,minmax(0,1fr));order:-2}.view-rail button{min-height:58px}.status-strip{grid-template-columns:repeat(2,minmax(0,1fr));order:-1}.phase-switcher{grid-template-columns:repeat(2,minmax(0,1fr))}.operations-layout,.playbook-stack,.branch-grid,.district-strip{grid-template-columns:1fr}.district-strip dl,.layer-buttons,.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.bottom-command{grid-template-columns:1fr}}@media(max-width:520px){.topbar,.app-main,.workspace-view{padding:10px}.brand-mark{width:42px;height:42px}h1{font-size:1.04rem}.phase-switcher,.status-strip,.metrics-grid,.district-strip dl,.layer-buttons{grid-template-columns:1fr}.view-rail{grid-template-columns:repeat(3,minmax(0,1fr))}.view-rail button{min-height:54px}.map-head,.section-title,.view-title{align-items:flex-start;flex-direction:column}.city-map{min-height:360px}}
