/* All Forward — Command 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}
.state-brief-picker{margin-left:auto;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.state-brief-picker label{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-2)}
.state-brief-controls{display:flex;align-items:center;gap:8px}
.state-brief-controls select{
  min-width:190px;background:var(--bg);border:1px solid var(--border);border-radius:8px;
  color:var(--text);padding:8px 10px;font-size:.84rem;font-family:var(--sans);
}
.state-brief-controls select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.25)}
.state-brief-button{
  background:var(--blue);border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#fff;
  padding:8px 12px;font-size:.78rem;font-weight:700;cursor:pointer;white-space:nowrap;
}
.state-brief-button:hover{background:#1d4ed8}
.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)}
/* Clickable states are now a Leaflet GeoJSON layer (styled in command-center.js).
   Cursor affordance + smooth color transitions on the rendered paths: */
.leaflet-interactive{cursor:pointer; transition:fill-opacity .18s, stroke .18s}
/* 2-letter state codes centered on the map */
.leaflet-tooltip.state-label{background:transparent;border:none;box-shadow:none;color:#f4f6fa;font-family:var(--mono);font-weight:700;font-size:10px;letter-spacing:.04em;text-shadow:0 1px 3px rgba(0,0,0,.95),0 0 2px rgba(0,0,0,.85);padding:0;white-space:nowrap;pointer-events:none}
.leaflet-tooltip.state-label::before,.leaflet-tooltip.state-label::after{display:none !important}
/* Hide the map's hazard legend while the recovery drawer is open so they don't overlap. */
body.ops-drawer-open .fema-legend{opacity:0; visibility:hidden; transition:opacity .2s}
.map-foot{font-size:.68rem;color:var(--text-2);padding:10px 2px 4px;font-family:var(--mono)}
/* ---------- 31-day hazard outlook (week-block calendar) ---------- */
.forecast31{padding:14px 0 0}
.forecast31 .map-foot a{color:var(--blue)}
.forecast31 .f31-card{max-width:760px;margin-right:auto}
.f31-headrow{align-items:flex-start;gap:12px;flex-wrap:wrap}
.f31-range{display:block;color:var(--text-2);font-size:.72rem;font-family:var(--mono);margin-top:3px}
.f31-controls{display:flex;align-items:center;gap:8px}
.f31-controls label{font-size:.64rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-2)}
.f31-controls select{background:var(--bg);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:6px 9px;font-size:.82rem;font-family:var(--sans);max-width:180px}
/* legend moved above the calendar (between map and calendar) */
.f31-legend{display:flex;flex-wrap:wrap;gap:14px;margin:12px 0 0;padding-bottom:13px;border-bottom:1px solid var(--border)}
.f31-legend .f31-lg{display:flex;align-items:center;gap:6px;font-size:.74rem;color:var(--text-2)}
/* two columns: calendar | "active now" panel (fills the empty space) */
.f31-grid2{display:grid;grid-template-columns:minmax(300px,360px) 1fr;gap:24px;margin-top:14px;align-items:start}
.f31-active h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-2);margin:2px 0 10px}
.f31-active .ai{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--border);font-size:.86rem;color:var(--text)}
.f31-active .ai:last-child{border:none}
.f31-active .ai .pk{margin-left:auto;color:var(--text-2);font-size:.74rem;font-family:var(--mono)}
.f31-active .none{color:var(--text-2);font-size:.85rem}
.wkcal{display:flex;flex-direction:column;gap:5px}
.wkcal-row{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.wkcal-wd{text-align:center;font-size:.6rem;color:var(--text-2);font-weight:700;letter-spacing:.05em}
.wkcal-cell{min-height:46px;border:1px solid var(--border);border-radius:7px;background:var(--bg);padding:5px 6px;display:flex;flex-direction:column;gap:4px}
.wkcal-cell.out{opacity:.3}
.wkcal-cell.today{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.wkcal-dnum{font-size:.72rem;color:var(--text);font-family:var(--mono);line-height:1}
.wkcal-cell.out .wkcal-dnum{color:var(--text-2)}
.wkcal-dots{display:flex;flex-wrap:wrap;gap:3px;margin-top:auto}
.wkcal-dot{width:8px;height:8px;border-radius:50%;flex:none}
/* when the drawer is open, drop the side panel so the drawer never overlaps content */
body.ops-drawer-open .f31-active{display:none}
body.ops-drawer-open .f31-grid2{grid-template-columns:minmax(300px,420px)}
@media(max-width:700px){ .forecast31 .f31-card{max-width:none} .f31-grid2{grid-template-columns:1fr} .wkcal-cell{min-height:40px} }

/* ---------- State drawer ---------- */
.drawer-backdrop{position:fixed; inset:0; background:rgba(8,11,18,.55); opacity:0; visibility:hidden; transition:opacity .25s; z-index:1990}
.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:2000; 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}
  .state-brief-picker,.state-brief-controls{width:100%}
  .state-brief-controls select{min-width:0;flex:1}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important}
  .drawer,.drawer-backdrop{transition:none}
}

/* Language Selector */
.lang-selector-wrapper {
  display: inline-block;
  margin-right: 12px;
  vertical-align: middle;
}
.lang-selector {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-size: 0.8rem;
  font-weight: 600;
  padding: 4px 8px;
  cursor: pointer;
  outline: none;
  transition: all 0.2s ease;
}
.lang-selector:hover {
  border-color: var(--glow-blue, #4fc3f7);
  background: rgba(41, 121, 255, 0.05);
}

/* ==========================================================================
   Calendar & Weather Row Layout
   ========================================================================== */
.f31-weather-row {
  display: flex;
  gap: 24px;
  align-items: stretch;
  margin-top: 24px;
  margin-bottom: 24px;
}
.f31-weather-row .forecast31 {
  flex: 1 1 760px;
  max-width: 760px;
  min-width: 0;
}
.f31-weather-row .weather-outlook-section {
  flex: 1 1 400px;
  max-width: 440px;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
#f31-weather {
  height: 100%;
}

/* ==========================================================================
   Weather Widget Styles
   ========================================================================== */
.weather-widget {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  color: var(--text);
  box-shadow: 0 4px 20px 0 rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  height: 100%;
  box-sizing: border-box;
}
.weather-widget-header h4 {
  margin: 0 0 12px 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: #ffffff;
  border-bottom: 1px solid var(--border);
  padding-bottom: 8px;
}
.weather-widget-body {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  gap: 12px;
}
.weather-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1;
}
.weather-main-icon {
  width: 64px;
  height: 64px;
  filter: drop-shadow(0 0 8px rgba(255,255,255,0.1));
}
.weather-cond-text {
  font-size: 0.82rem;
  color: var(--text-2);
  margin-top: 4px;
  font-weight: 500;
}
.weather-right {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1.3;
  gap: 12px;
}
.weather-temp-large {
  font-size: 2.2rem;
  font-weight: 700;
  color: #ffffff;
  font-family: var(--sans);
  line-height: 1;
}
.weather-details {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: left;
}
.weather-detail-item {
  font-size: 0.78rem;
  color: var(--text-2);
}
.weather-forecast-row {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid var(--border);
  padding-top: 12px;
  margin-top: auto;
  gap: 4px;
}
.weather-forecast-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  text-align: center;
}
.weather-fore-day {
  font-size: 0.72rem;
  color: var(--text-2);
  text-transform: uppercase;
  margin-bottom: 2px;
}
.weather-fore-icon {
  width: 32px;
  height: 32px;
}
.weather-fore-temp {
  font-size: 0.78rem;
  font-weight: 600;
  color: #ffffff;
  margin-top: 2px;
}
.weather-widget-footer {
  font-size: 0.68rem;
  color: #64748b;
  text-align: center;
  margin-top: 12px;
  padding-top: 8px;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

/* ==========================================================================
   Responsive Layout Overrides
   ========================================================================== */
@media (max-width: 1024px) {
  .f31-weather-row {
    flex-direction: column;
    align-items: stretch;
  }
  .f31-weather-row .forecast31,
  .f31-weather-row .weather-outlook-section {
    max-width: 100%;
    width: 100%;
  }
}

/* ==========================================================================
   Unified Navigation Header Styles
   ========================================================================== */
nav#navbar {
  position: sticky;
  top: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 6vw;
  background: rgba(26, 31, 46, 0.95);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  height: 76px;
  box-sizing: border-box;
}
.nav-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}
.nav-logo img {
  height: 48px;
  width: auto;
  border-radius: 8px;
  display: block;
}
.nav-links {
  list-style: none;
  display: flex;
  gap: 28px;
  align-items: center;
  margin: 0;
  padding: 0;
}
.nav-links a {
  color: var(--text);
  text-decoration: none;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.5px;
  transition: color 0.2s;
  text-transform: uppercase;
}
.nav-links a:hover {
  color: var(--teal);
}
.nav-cta {
  background: linear-gradient(135deg, var(--amber), #ff9800);
  color: #fff !important;
  padding: 8px 16px;
  border-radius: 6px;
}
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 6px;
  background: none;
  border: none;
  outline: none;
}
.hamburger span {
  width: 24px;
  height: 2px;
  background: var(--text);
  transition: all 0.3s;
  display: block;
}
.mobile-menu {
  display: none;
  position: fixed;
  top: 76px;
  left: 0;
  right: 0;
  background: rgba(26, 31, 46, 0.98);
  border-bottom: 1px solid var(--border);
  z-index: 999;
  padding: 20px 6vw;
  flex-direction: column;
  gap: 4px;
  box-sizing: border-box;
}
.mobile-menu.open {
  display: flex;
}
.mobile-menu a {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text);
  text-decoration: none;
  padding: 13px 0;
  border-bottom: 1px solid var(--border);
}
.mobile-menu a:last-child {
  border: none;
}
.mobile-menu a:hover {
  color: var(--teal);
}

@media (max-width: 1024px) {
  .nav-links {
    display: none;
  }
  .hamburger {
    display: flex;
  }
}



