/* All Forward — Operations Center · Phase 1
   Design tokens are LOCKED. Aesthetic: professional intel workstation. */
:root{
  --bg:#1a1f2e; --surface:#242b3d; --border:#343d52;
  --text:#f0f2f5; --text-2:#9aa3b8;
  --blue:#2563eb; --gold:#d4a843; --alert-red:#dc2626; --amber:#f59e0b; --teal:#0d9488;
  --slate:#3a445e;            /* map: clear */
  --radius:10px;
  --mono:"SF Mono",ui-monospace,"JetBrains Mono",Menlo,Consolas,monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:1280px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body.ops{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--sans); line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--blue); text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}

/* ---------- Header ---------- */
.ops-header{
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,#1d2333,#1a1f2e);
  position:sticky; top:0; z-index:40;
}
.ops-header .wrap{display:flex; align-items:center; justify-content:space-between; padding-top:14px; padding-bottom:14px; gap:16px; flex-wrap:wrap}
.ops-title{display:flex; align-items:center; gap:12px}
.ops-title .live-dot{width:9px;height:9px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(13,148,136,.6);animation:pulse-slow 2.4s infinite}
.ops-title h1{font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; margin:0; font-weight:700}
.ops-title .sub{display:block; font-size:.72rem; letter-spacing:.08em; color:var(--text-2); font-weight:500; text-transform:none; margin-top:2px}
.brand{display:flex; align-items:center; gap:10px; font-weight:700; letter-spacing:.02em}
.brand img{height:30px; width:auto; display:block}
.brand .home-link{color:var(--text); font-size:.95rem}
.ops-clock{font-family:var(--mono); font-size:.72rem; color:var(--text-2)}

/* ---------- Intro ---------- */
.ops-intro{padding:34px 0 6px}
.ops-intro h2{font-size:clamp(1.5rem,3vw,2.1rem); margin:0 0 8px; letter-spacing:-.01em}
.ops-intro p{color:var(--text-2); max-width:760px; margin:0}

/* ---------- Module row ---------- */
.modules{display:grid; grid-template-columns:repeat(5,1fr); gap:14px; padding:24px 0}
.module{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:16px; position:relative; overflow:hidden; cursor:default;
  transition:border-color .18s, transform .18s;
}
.module:hover{border-color:#46527a; transform:translateY(-2px)}
.module .ico{width:34px;height:34px;margin-bottom:10px;display:flex;align-items:center;justify-content:center}
.module .ico svg{width:28px;height:28px}
.module .label{font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-2)}
.module .value{font-size:1.7rem; font-weight:700; font-family:var(--mono); line-height:1.1; margin-top:2px}
.module .value small{font-size:.7rem; font-family:var(--sans); color:var(--text-2); font-weight:500}
.module .status{font-size:.68rem; color:var(--text-2); margin-top:4px}
.module.is-action{cursor:pointer; border-color:#3c5bd6}
.module.is-action:hover{background:#283357}

/* module accent bars */
.module[data-mod="storms"]{border-top:2px solid var(--blue)}
.module[data-mod="wildfire"]{border-top:2px solid var(--amber)}
.module[data-mod="flood"]{border-top:2px solid var(--teal)}
.module[data-mod="funding"]{border-top:2px solid var(--gold)}
.module[data-mod="alerts"]{border-top:2px solid var(--blue)}

/* ---- animations ---- */
@keyframes pulse-slow{0%{box-shadow:0 0 0 0 rgba(37,99,235,.5)}70%{box-shadow:0 0 0 9px rgba(37,99,235,0)}100%{box-shadow:0 0 0 0 rgba(37,99,235,0)}}
@keyframes pulse-fast{0%{box-shadow:0 0 0 0 rgba(220,38,38,.6)}60%{box-shadow:0 0 0 11px rgba(220,38,38,0)}100%{box-shadow:0 0 0 0 rgba(220,38,38,0)}}
.storm-eye{border-radius:50%}
.module[data-mod="storms"] .storm-eye{animation:pulse-slow 2.6s infinite}
.module[data-mod="storms"].active .storm-eye{animation:pulse-fast 1.1s infinite}

@keyframes flicker{0%,100%{opacity:1;filter:drop-shadow(0 0 2px var(--amber))}25%{opacity:.78;filter:drop-shadow(0 0 6px #ff8c1a)}50%{opacity:.92;filter:drop-shadow(0 0 9px var(--alert-red))}75%{opacity:.7;filter:drop-shadow(0 0 4px var(--amber))}}
.module[data-mod="wildfire"] .ico svg{animation:flicker 1.7s infinite}

@keyframes ripple{0%{transform:scale(.6);opacity:.7}100%{transform:scale(2.4);opacity:0}}
.module[data-mod="flood"] .ico{position:relative}
.module[data-mod="flood"] .ico::after{content:"";position:absolute;inset:2px;border:2px solid var(--teal);border-radius:50%;animation:ripple 2.2s infinite}

@keyframes shimmer{0%{background-position:-120% 0}100%{background-position:220% 0}}
.module[data-mod="funding"] .value{
  background:linear-gradient(100deg,var(--gold) 30%,#fff3cf 50%,var(--gold) 70%);
  background-size:220% 100%;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  animation:shimmer 3.4s linear infinite;
}
@keyframes bell-ring{0%,60%,100%{transform:rotate(0)}5%,25%{transform:rotate(14deg)}15%,35%{transform:rotate(-14deg)}}
.module[data-mod="alerts"]:hover .ico svg{transform-origin:50% 12%;animation:bell-ring 1s ease}

/* ---------- Map ---------- */
.map-section{padding:14px 0 56px}
.map-shell{display:grid; grid-template-columns:1fr; gap:18px}
.map-card{background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:18px 18px 10px}
.map-head{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:6px}
.map-head h3{margin:0; font-size:1rem; letter-spacing:.02em}
.legend{display:flex; gap:16px; flex-wrap:wrap; font-size:.74rem; color:var(--text-2)}
.legend span{display:inline-flex; align-items:center; gap:6px}
.swatch{width:13px;height:13px;border-radius:3px;display:inline-block;border:1px solid rgba(255,255,255,.12)}
.sw-clear{background:var(--slate)} .sw-watch{background:var(--amber)} .sw-warn{background:var(--alert-red)}
#us-map{width:100%; height:auto; display:block; max-height:74vh}
#us-map .state{
  fill:var(--slate); stroke:#11151f; stroke-width:1; cursor:pointer;
  transition:fill .18s, filter .18s;
}
#us-map .state:hover{filter:brightness(1.35)}
#us-map .state.lvl-watch{fill:var(--amber)}
#us-map .state.lvl-warn{fill:var(--alert-red)}
#us-map .state.selected{stroke:var(--gold); stroke-width:2.4; filter:brightness(1.2)}
#us-map .dc-marker{stroke:#11151f; stroke-width:1.2}
.map-foot{font-size:.68rem;color:var(--text-2);padding:10px 2px 4px;font-family:var(--mono)}

/* ---------- State drawer ---------- */
.drawer-backdrop{position:fixed; inset:0; background:rgba(8,11,18,.55); opacity:0; visibility:hidden; transition:opacity .25s; z-index:50}
.drawer-backdrop.open{opacity:1; visibility:visible}
.drawer{
  position:fixed; top:0; right:0; height:100%; width:min(460px,92vw);
  background:var(--surface); border-left:1px solid var(--border);
  transform:translateX(100%); transition:transform .28s cubic-bezier(.4,0,.2,1);
  z-index:60; display:flex; flex-direction:column;
}
.drawer.open{transform:translateX(0)}
.drawer-head{padding:20px 22px 14px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:flex-start; gap:12px}
.drawer-head h3{margin:0; font-size:1.35rem}
.drawer-head .code{font-family:var(--mono); color:var(--text-2); font-size:.78rem; letter-spacing:.1em}
.drawer-close{background:none;border:1px solid var(--border);color:var(--text-2);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:1.1rem;line-height:1}
.drawer-close:hover{color:var(--text);border-color:#46527a}
.drawer-body{padding:18px 22px 30px; overflow-y:auto; flex:1}
.drawer-body section{margin-bottom:22px}
.drawer-body h4{font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:var(--text-2); margin:0 0 10px; border-bottom:1px solid var(--border); padding-bottom:6px}
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kpi{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px}
.kpi .n{font-family:var(--mono);font-size:1.4rem;font-weight:700}
.kpi .t{font-size:.66rem;color:var(--text-2);text-transform:uppercase;letter-spacing:.08em}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-size:.72rem;padding:4px 10px;border-radius:999px;background:var(--bg);border:1px solid var(--border);color:var(--text)}
.chip.hz{border-color:#4a3a1e;background:#2a2415;color:#e7c879}
.rows{display:flex;flex-direction:column;gap:8px}
.row{display:flex;justify-content:space-between;gap:10px;font-size:.85rem;padding:9px 11px;background:var(--bg);border:1px solid var(--border);border-radius:8px}
.row .meta{color:var(--text-2);font-size:.74rem}
.badge{font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:5px;font-family:var(--mono)}
.badge.active{background:rgba(220,38,38,.16);color:#f3a3a3;border:1px solid rgba(220,38,38,.4)}
.badge.avail{background:rgba(212,168,67,.14);color:var(--gold);border:1px solid rgba(212,168,67,.4)}
.badge.closed{background:rgba(154,163,184,.12);color:var(--text-2);border:1px solid var(--border)}
.drawer-loading{color:var(--text-2);font-size:.82rem}
.drawer-cta{display:block;margin-top:6px;background:var(--blue);color:#fff;text-align:center;padding:12px;border-radius:8px;font-weight:600}
.drawer-cta:hover{background:#1d4ed8;text-decoration:none}
.drawer-cta.gold{background:transparent;border:1px solid var(--gold);color:var(--gold);margin-top:10px}
.drawer-cta.gold:hover{background:rgba(212,168,67,.1)}
.statepage-link{font-size:.78rem;margin-top:12px;display:inline-block}

/* ---------- Alert signup ---------- */
.alerts-section{padding:46px 0 70px; border-top:1px solid var(--border)}
.alerts-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:start}
.alerts-copy h3{font-size:1.6rem;margin:0 0 10px}
.alerts-copy p{color:var(--text-2);margin:0 0 14px}
.alerts-copy ul{color:var(--text-2);padding-left:18px;margin:0}
.alerts-copy li{margin-bottom:6px}
.alert-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.alert-form label{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);margin:0 0 6px}
.alert-form .field{margin-bottom:16px}
.alert-form input,.alert-form select{
  width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;
  color:var(--text);padding:11px 12px;font-size:.92rem;font-family:var(--sans);
}
.alert-form select[multiple]{height:118px}
.alert-form input:focus,.alert-form select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.25)}
.alert-form .hint{font-size:.68rem;color:var(--text-2);margin-top:5px}
.btn-submit{width:100%;background:var(--gold);color:#1a1f2e;font-weight:700;border:none;border-radius:8px;padding:13px;font-size:.95rem;cursor:pointer;letter-spacing:.02em}
.btn-submit:hover{background:#e3ba54}
.hp{position:absolute;left:-9999px}

/* ---------- Footer ---------- */
.ops-footer{border-top:1px solid var(--border);padding:26px 0;color:var(--text-2);font-size:.8rem}
.ops-footer .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ops-footer a{color:var(--text-2)}
.disclaimer{font-size:.7rem;color:#707a93;max-width:760px;margin-top:8px}

/* ---------- Per-state page extras ---------- */
.sp-hero{padding:40px 0 10px}
.sp-hero .crumb{font-size:.74rem;color:var(--text-2);margin-bottom:10px}
.sp-hero h1{font-size:clamp(1.7rem,3.4vw,2.5rem);margin:0 0 8px;letter-spacing:-.01em}
.sp-hero .lede{color:var(--text-2);max-width:760px}
.sp-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:18px 0}
.sp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.sp-card.full{grid-column:1 / -1}
.sp-card h2{font-size:1.05rem;margin:0 0 14px}
table.sp{width:100%;border-collapse:collapse;font-size:.86rem}
table.sp th,table.sp td{text-align:left;padding:9px 8px;border-bottom:1px solid var(--border)}
table.sp th{color:var(--text-2);font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;font-weight:600}
.sp-cta{background:linear-gradient(120deg,#283357,#242b3d);border:1px solid #3c5bd6}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .modules{grid-template-columns:repeat(2,1fr)}
  .alerts-grid{grid-template-columns:1fr;gap:24px}
  .sp-grid{grid-template-columns:1fr}
}
@media(max-width:560px){
  .modules{grid-template-columns:1fr}
  .ops-clock{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important}
  .drawer,.drawer-backdrop{transition:none}
}
