/* ---------- PFARS Design System ---------- */
/* Pulled from real PFARS livery: navy + safety orange + steel grey + white */

:root{
  --navy:#1B3A6B;
  --navy-deep:#0F2244;
  --navy-2:#22468C;
  --orange:#E87722;
  --orange-deep:#C8631A;
  --steel:#2A2F36;
  --steel-2:#3B424B;
  --line-grey:#AEB4BD;
  --paper:#F4F4F2;
  --paper-2:#E9E9E6;
  --paper-3:#DCDCD7;
  --rule:rgba(15,34,68,0.14);
  --rule-strong:rgba(15,34,68,0.28);
  --ink:#0E1320;
  --ink-soft:#1A2238;
  --muted:rgba(15,34,68,0.62);
  --muted-2:rgba(15,34,68,0.42);
  --green:#2E7D4F;
  --amber:#E8A838;
  --red:#D5212C;

  --f-display:"Barlow Condensed", "Oswald", "Archivo Narrow", ui-sans-serif, system-ui, sans-serif;
  --f-body:"Barlow", "Inter", ui-sans-serif, system-ui, sans-serif;
  --f-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --maxw:1360px;
  --gut:clamp(20px, 3vw, 40px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

body[data-theme="dark"]{
  background:var(--steel);
  color:#F4F4F2;
  --paper:#1A1F28;
  --paper-2:#22272F;
  --paper-3:#2A2F38;
  --ink:#F4F4F2;
  --rule:rgba(244,244,242,0.14);
  --rule-strong:rgba(244,244,242,0.32);
  --muted:rgba(244,244,242,0.62);
  --muted-2:rgba(244,244,242,0.42);
  --navy:#3A6BC0;
  --navy-deep:#1B3A6B;
}

a{color:inherit}
img{max-width:100%;display:block}
button{font-family:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.rule{height:1px;background:var(--rule);width:100%}
.rule-strong{height:1px;background:var(--rule-strong);width:100%}
.mono{font-family:var(--f-mono);letter-spacing:.02em}

/* signature livery stripe — pulled from the real apparatus */
.livery-stripe{
  height:14px;
  background:
    linear-gradient(180deg, transparent 0 3px, var(--orange) 3px 8px, transparent 8px 11px),
    linear-gradient(180deg, var(--paper-3) 0 3px, var(--paper-3) 11px 14px, transparent 14px);
  background-size:100% 100%;
  background-repeat:no-repeat;
}
.livery-band{
  display:flex;align-items:center;gap:0;
  background:var(--paper-3);
  border-block:1px solid var(--rule);
  height:32px; overflow:hidden;
}
.livery-band .o{flex:1;height:6px;background:var(--orange)}
.livery-band .g{flex:0 0 8px;height:100%;background:var(--paper-3)}

.eyebrow{
  font-family:var(--f-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.16em;
  color:var(--muted);
  font-weight:500;
}
.eyebrow .dot{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--orange);margin-right:8px;vertical-align:1px;
  animation:blink 1.6s infinite;
}
@keyframes blink{
  0%,70%,100%{opacity:1;box-shadow:0 0 0 0 rgba(232,119,34,.6)}
  35%{opacity:.35;box-shadow:0 0 0 6px rgba(232,119,34,0)}
}

/* ---------- Top status bar ---------- */
.statbar{
  background:var(--navy-deep);
  color:#F4F4F2;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:0.08em;
  border-bottom:4px solid var(--orange);
}
.statbar .inner{
  display:flex;align-items:center;justify-content:space-between;
  height:32px; gap:16px; overflow:hidden; white-space:nowrap;
}
.statbar .left{display:flex;align-items:center;gap:14px}
.statbar .right{display:flex;align-items:center;gap:14px;color:rgba(244,244,242,.7)}
.statbar .sep{width:1px;height:10px;background:rgba(244,244,242,.25)}
.statbar .pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:2px 8px;border:1px solid rgba(244,244,242,.25);border-radius:0;
  color:#F4F4F2;
}
.statbar .pill .d{width:6px;height:6px;border-radius:50%;background:#4ADE80;animation:blink 1.6s infinite}
@media (max-width: 720px){
  .statbar .hide-sm{display:none}
}

/* ---------- Masthead ---------- */
.mast{
  position:sticky; top:0; z-index:50;
  background:var(--paper);
  border-bottom:1px solid var(--rule-strong);
}
body[data-theme="dark"] .mast{background:var(--steel)}
.mast .inner{
  display:flex;align-items:center;justify-content:space-between;
  min-height:78px; gap:24px;
}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand-mark{
  width:54px;height:54px;border-radius:50%;
  background:var(--navy);color:#fff;
  display:grid;place-items:center;
  position:relative; overflow:hidden;
  box-shadow:inset 0 0 0 3px rgba(255,255,255,.95), inset 0 0 0 4px var(--navy);
}
.brand-mark svg{width:30px;height:30px;color:#fff}
.brand-name{line-height:1.1;display:flex;flex-direction:column;gap:3px}
.brand-name b{
  font-family:var(--f-display);font-weight:700;
  font-size:20px;letter-spacing:.02em;
  color:var(--navy);text-transform:uppercase;
  display:block;line-height:1.05;
}
body[data-theme="dark"] .brand-name b{color:#F4F4F2}
.brand-name > span{
  font-family:var(--f-display);font-weight:500;
  font-size:13px;color:var(--ink);
  letter-spacing:.06em; text-transform:uppercase;
  display:block;line-height:1.1;
}
.brand-name .station{
  font-family:var(--f-mono);font-size:10px;
  color:var(--orange);font-weight:600;letter-spacing:.12em;
  display:block;line-height:1.1;
}

.navlinks{display:flex;align-items:center;gap:2px}
.navlinks a{
  text-decoration:none;color:var(--ink);
  font-family:var(--f-display);
  font-size:14px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;
  padding:10px 14px;border-radius:0;
  position:relative;
}
.navlinks a:hover{color:var(--navy)}
.navlinks a:hover::after,
.navlinks a.active::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:var(--orange)}
.navlinks a.active{color:var(--navy)}
body[data-theme="dark"] .navlinks a:hover,
body[data-theme="dark"] .navlinks a.active{color:var(--orange)}
@media (max-width: 1080px){ .navlinks{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:4px;flex-wrap:nowrap;padding-bottom:2px} .navlinks a{white-space:nowrap;font-size:.72rem;padding:4px 8px} .cta-row .btn{font-size:.65rem;padding:4px 10px} }

.cta-row{display:flex;align-items:center;gap:8px}
.btn{
  appearance:none;border:2px solid var(--navy);
  background:var(--navy);color:#fff;
  font-family:var(--f-display);font-size:14px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  padding:10px 18px;border-radius:0;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;
  transition:transform .15s ease, background .15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn.orange{background:var(--orange);border-color:var(--orange);color:#fff}
.btn.orange:hover{background:var(--orange-deep);border-color:var(--orange-deep)}
.btn.ghost{background:transparent;color:var(--navy)}
body[data-theme="dark"] .btn.ghost{color:#F4F4F2;border-color:#F4F4F2}
.btn.sm{padding:8px 14px;font-size:12px;white-space:nowrap}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translate(2px,-2px)}

/* ---------- Section scaffolding ---------- */
section{ scroll-margin-top:96px; }
.sect{ padding:clamp(40px, 4.5vw, 64px) 0; position:relative }
.sect-hd{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);
  gap:32px; align-items:end; margin-bottom:28px;
}
@media(max-width:820px){ .sect-hd{grid-template-columns:1fr; gap:16px} }
.sect-hd .tag{display:flex;flex-direction:column;gap:10px}
.sect-hd h2{
  font-family:var(--f-display);font-weight:600;
  font-size:clamp(32px, 4vw, 52px);
  letter-spacing:0;line-height:.95;margin:0;
  text-wrap:balance;text-transform:uppercase;
  color:var(--ink);
}
.sect-hd h2 em{font-style:normal;color:var(--orange)}
.sect-hd .lede{
  font-size:clamp(16px,1.4vw,19px);
  color:var(--muted);max-width:56ch;text-wrap:pretty;
}
.sect-num{
  font-family:var(--f-mono);font-size:11px;color:var(--muted);
  display:flex;align-items:center;gap:12px;font-weight:500;
}
.sect-num::before{content:"";width:28px;height:1px;background:var(--rule-strong)}

/* ---------- Image styling ---------- */
.img-frame{
  position:relative; overflow:hidden;
  background:var(--paper-3);
  border:1px solid var(--rule);
}
.img-frame img{width:100%;height:100%;object-fit:cover;display:block}
.img-frame .tag{
  position:absolute;left:0;bottom:0;
  font-family:var(--f-mono);font-size:10.5px;text-transform:uppercase;
  letter-spacing:.14em; padding:7px 12px;
  background:var(--navy-deep); color:#fff;
}
.img-frame .corner{
  position:absolute;top:0;right:0;
  background:var(--orange);color:#fff;
  font-family:var(--f-mono);font-size:10px;font-weight:600;
  padding:5px 10px;letter-spacing:.12em;text-transform:uppercase;
}

/* utility */
.num-tab{
  font-family:var(--f-mono);font-size:11px;color:var(--muted);
  border:1px solid var(--rule);padding:2px 7px;
  display:inline-block;letter-spacing:.08em;text-transform:uppercase;
}

/* -------- Hero -------- */
.hero{
  position:relative; overflow:hidden;
  padding:0;
}
.hero-image-wrap{
  position:relative;min-height:clamp(420px, 58vh, 560px);
  overflow:hidden; background:var(--steel);
  display:flex; align-items:flex-end;
}
.hero-image-wrap img{
  position:absolute; inset:0;
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.55) saturate(.85);
  z-index:0;
}
.hero-image-wrap::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(15,34,68,.4) 0%, rgba(15,34,68,.0) 30%, rgba(15,34,68,.85) 100%);
  z-index:1;
}
.hero-overlay{
  position:relative;
  width:100%;
  padding:clamp(28px,3vw,48px) 0;
  z-index:2;
  color:#fff;
}
.hero-grid{
  display:grid; grid-template-columns: minmax(0,1.2fr) minmax(0,1fr);
  gap:48px; align-items:end;
}
@media(max-width:960px){ .hero-grid{grid-template-columns:1fr; gap:24px} }
.hero .eyebrow{color:rgba(255,255,255,.85)}
.hero h1{
  font-family:var(--f-display); font-weight:600;
  font-size:clamp(40px, 5.6vw, 84px);
  line-height:.92; letter-spacing:0; margin:12px 0 0;
  text-wrap:balance; text-transform:uppercase;
  color:#fff;
}
.hero h1 em{
  font-style:normal; color:var(--orange);
  font-family:var(--f-display); font-weight:600;
}
.hero-meta{
  display:flex; flex-wrap:wrap; gap:10px 24px; margin-top:22px;
  font-family:var(--f-mono); font-size:11px; color:rgba(255,255,255,.7);
  text-transform:uppercase; letter-spacing:.1em;
}
.hero-meta b{color:#fff; font-weight:600}
.hero-side{
  display:flex;flex-direction:column;gap:16px;
  background:rgba(15,34,68,.85);
  backdrop-filter:blur(8px);
  border-left:4px solid var(--orange);
  padding:24px 28px;
}
.hero-cta{ display:flex; gap:8px; flex-wrap:wrap }
.hero-quote{
  font-family:var(--f-display);font-weight:500;
  font-size:clamp(17px,1.5vw,21px);
  line-height:1.35; letter-spacing:0;
  color:#fff; text-wrap:pretty;
}
.hero-quote .cite{
  display:block; margin-top:10px;
  font-family:var(--f-mono);font-size:10.5px;
  text-transform:uppercase;letter-spacing:.12em;
  color:rgba(255,255,255,.65); font-weight:400;
}

/* Stats board */
.stats-board{
  background:var(--ink);
  color:#F4F4F2;
  margin-top:0;
  border-bottom:4px solid var(--orange);
}
.stats-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--gut); border-bottom:1px solid rgba(244,244,242,.12);
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(244,244,242,.7);
}
.stats-head .units{display:flex;gap:18px;flex-wrap:wrap}
.stats-head .units span{display:inline-flex;align-items:center;gap:6px}
.stats-head .units .d{width:7px;height:7px;border-radius:50%;background:#4ADE80;animation:blink 1.6s infinite}
.stats-head .units .d.busy{background:var(--orange);animation-duration:1s}
.stats-head .units .d.scene{background:var(--red)}
.stats-grid{
  display:grid; grid-template-columns:repeat(4, minmax(0,1fr));
  gap:1px; background:rgba(244,244,242,.1);
}
@media(max-width:720px){ .stats-grid{grid-template-columns:repeat(2,1fr)} }
.stats-cell{
  padding:22px var(--gut) 20px; background:var(--ink);
  display:flex; flex-direction:column; gap:4px;
}
.stats-cell .k{
  font-family:var(--f-mono); font-size:11px;
  color:rgba(244,244,242,.55); text-transform:uppercase; letter-spacing:.14em;
}
.stats-cell .v{
  font-family:var(--f-display); font-weight:600;
  font-size:clamp(32px, 3.6vw, 48px); letter-spacing:0;
  line-height:1; color:#F4F4F2;
  font-variant-numeric:tabular-nums;
}
.stats-cell .v .unit{
  font-size:0.42em; color:rgba(244,244,242,.5);
  margin-left:6px;
}
.stats-cell .delta{
  font-family:var(--f-mono); font-size:11px; margin-top:4px;
  color:#4ADE80; letter-spacing:.06em;
}
.stats-cell .delta.flat{color:rgba(244,244,242,.55)}

/* -------- Mission -------- */
.mission-grid{
  display:grid; grid-template-columns: minmax(0,1fr) minmax(0,1.6fr);
  gap:48px; align-items:start;
}
@media(max-width:900px){ .mission-grid{grid-template-columns:1fr; gap:24px} }
.mission p.lead{ font-family:var(--f-display); font-weight:500; font-size:clamp(20px,1.7vw,26px); line-height:1.3; color:var(--ink); text-wrap:pretty; max-width:22ch; letter-spacing:0; margin:0 }
.mission .pillars{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:0; border-top:1px solid var(--rule); border-left:1px solid var(--rule)}
@media(max-width:640px){ .mission .pillars{grid-template-columns:1fr} }
.pillar{
  display:flex; flex-direction:column; gap:6px;
  padding:18px 22px; border-right:1px solid var(--rule); border-bottom:1px solid var(--rule);
}
.pillar .n{font-family:var(--f-mono);font-size:10.5px;color:var(--orange);letter-spacing:.12em;font-weight:600}
.pillar h4{font-family:var(--f-display);font-size:18px;font-weight:600;margin:0;letter-spacing:.02em;text-transform:uppercase;color:var(--navy)}
body[data-theme="dark"] .pillar h4{color:#F4F4F2}
.pillar p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.5}

/* -------- Services -------- */
.svc-grid{
  display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:0;
  border-top:2px solid var(--navy); border-bottom:2px solid var(--navy);
}
@media(max-width:760px){ .svc-grid{grid-template-columns:1fr}}
.svc{
  padding:36px; border-right:1px solid var(--rule);
  border-top:1px solid var(--rule);
  display:flex; flex-direction:column; gap:14px;
  min-height:340px;
  position:relative;
}
.svc:nth-child(1),.svc:nth-child(2){border-top:none}
.svc:nth-child(2n){border-right:none}
@media(max-width:760px){
  .svc{border-right:none}
  .svc:nth-child(2){border-top:1px solid var(--rule)}
}
.svc .num{
  font-family:var(--f-mono);font-size:11px;color:var(--orange);
  letter-spacing:.12em;font-weight:600;
}
.svc h3{
  font-family:var(--f-display);font-size:30px;font-weight:600;
  letter-spacing:.02em;margin:0;text-transform:uppercase;color:var(--navy);
}
body[data-theme="dark"] .svc h3{color:#F4F4F2}
.svc p{color:var(--muted);margin:0;font-size:15px;line-height:1.55}
.svc ul{
  list-style:none;padding:0;margin:auto 0 0;
  font-family:var(--f-mono);font-size:11.5px;color:var(--ink);
  text-transform:uppercase;letter-spacing:.06em;
}
.svc ul li{padding:8px 0;border-top:1px dashed var(--rule);display:flex;justify-content:space-between;gap:10px}
.svc ul li:first-child{border-top:none}
.svc ul li span{color:var(--muted)}

/* -------- Classes -------- */
.classes-grid{
  display:grid; grid-template-columns: minmax(0,1.8fr) minmax(0,1fr);
  gap:32px;
}
@media(max-width:900px){ .classes-grid{grid-template-columns:1fr} }
.cal-list{border-top:2px solid var(--navy)}
.cal-row{
  display:grid;
  grid-template-columns: 84px 110px 1fr auto auto;
  gap:18px; align-items:center;
  padding:14px 0; border-bottom:1px solid var(--rule);
  transition:background .15s;
}
@media(max-width:640px){ .cal-row{grid-template-columns:72px 1fr; gap:12px} }
.cal-row:hover{background:var(--paper-2)}
.cal-date{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.cal-date b{
  display:block;font-family:var(--f-display);font-size:26px;
  letter-spacing:0;color:var(--orange);font-weight:700;
  line-height:1;margin-bottom:2px;
}
.cal-kind{
  font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;font-weight:700;
  padding:4px 8px; border:1px solid var(--rule); display:inline-block;
  color:var(--navy); white-space:nowrap;
}
body[data-theme="dark"] .cal-kind{color:#F4F4F2; border-color:var(--rule-strong)}
.cal-kind.class{color:#2E7D4F; border-color:rgba(46,125,79,.4)}
.cal-kind.fund{color:var(--orange); border-color:rgba(232,119,34,.5)}
.cal-kind.event{color:var(--navy); border-color:rgba(27,58,107,.4)}
body[data-theme="dark"] .cal-kind.event{color:#7DA8E0; border-color:rgba(125,168,224,.5)}
.cal-title{
  font-family:var(--f-display);font-size:17px;font-weight:600;
  letter-spacing:.01em;text-transform:uppercase;color:var(--navy);
}
body[data-theme="dark"] .cal-title{color:#F4F4F2}
.cal-title small{
  display:block;font-family:var(--f-body);font-weight:400;
  color:var(--muted);font-size:12.5px;margin-top:2px;
  letter-spacing:0;text-transform:none;
}
.cal-meta{font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:right}
.cal-seats{
  font-family:var(--f-mono);font-size:11px;padding:5px 11px;
  border:1px solid var(--rule);text-transform:uppercase;letter-spacing:.08em;
  color:var(--green);font-weight:600;
}
.cal-seats.low{color:var(--orange);border-color:var(--orange)}
.cal-seats.full{color:var(--red);border-color:var(--red)}
.cal-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.filter-chip{
  appearance:none;border:1px solid var(--rule);background:transparent;color:inherit;
  padding:8px 14px;border-radius:0;font-family:var(--f-mono);font-size:11px;
  text-transform:uppercase;letter-spacing:.08em;cursor:pointer;font-weight:600;
}
.filter-chip[aria-selected="true"]{background:var(--navy);color:#fff;border-color:var(--navy)}

.cal-side .img-frame{height:200px}
.cal-side-note{
  margin-top:14px;font-size:13.5px;color:var(--muted);line-height:1.5;
  padding:16px;background:var(--paper-2);border-left:3px solid var(--orange);
}
body[data-theme="dark"] .cal-side-note{background:var(--paper-2)}

@media(max-width:640px){
  .cal-kind,.cal-meta,.cal-seats{grid-column:2;text-align:left;justify-self:start}
}

/* -------- Volunteer -------- */
.vol-hero{
  background:var(--navy-deep);color:#F4F4F2;
  position:relative;overflow:hidden;
}
.vol-hero::before{
  content:"";position:absolute;top:0;left:0;right:0;height:6px;
  background:linear-gradient(90deg, var(--orange) 0 50%, transparent 50%);
  background-size:24px 100%;
}
.vol-grid{
  display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
}
@media(max-width:900px){ .vol-grid{grid-template-columns:1fr}}
.vol-copy{padding:clamp(40px,5vw,72px)}
.vol-copy h3{
  font-family:var(--f-display);font-size:clamp(40px,5vw,72px);
  font-weight:600;letter-spacing:0;line-height:.95;margin:0 0 24px;
  color:#fff;text-transform:uppercase;text-wrap:balance;
}
.vol-copy p{font-size:16px;line-height:1.6;color:rgba(244,244,242,.78);max-width:48ch}
.vol-steps{
  padding:clamp(40px,5vw,64px);
  background:var(--ink);
  display:flex;flex-direction:column;gap:0;
  border-left:1px solid rgba(244,244,242,.1);
}
@media(max-width:900px){ .vol-steps{border-left:none;border-top:1px solid rgba(244,244,242,.1)} }
.vol-step{
  padding:14px 0;display:grid;grid-template-columns:36px 1fr;gap:14px;
  border-top:1px solid rgba(244,244,242,.1);
}
.vol-step:first-child{border-top:none;padding-top:0}
.vol-step .n{font-family:var(--f-mono);color:var(--orange);font-size:12px;padding-top:4px;font-weight:600;letter-spacing:.1em}
.vol-step b{
  font-family:var(--f-display);font-size:18px;font-weight:600;
  display:block;margin-bottom:5px;color:#fff;
  letter-spacing:.02em;text-transform:uppercase;
}
.vol-step p{margin:0;color:rgba(244,244,242,.65);font-size:14px;line-height:1.5}
.vol-reqs{
  margin-top:24px;padding:0;
  display:grid; grid-template-columns:repeat(2,1fr); gap:0;
  list-style:none;
  font-family:var(--f-mono);font-size:11.5px;color:rgba(244,244,242,.78);
  text-transform:uppercase; letter-spacing:.06em;font-weight:500;
}
.vol-reqs li{padding:11px 0;border-top:1px solid rgba(244,244,242,.1);display:flex;gap:10px;align-items:center}
.vol-reqs li::before{content:"✓";color:var(--orange);font-weight:700}

/* -------- Fleet -------- */
.fleet-intro{
  margin-bottom:24px;
  display:grid; grid-template-columns: minmax(0,1fr) auto; gap:24px; align-items:end;
  padding-bottom:16px; border-bottom:1px solid var(--rule);
}
@media(max-width:760px){ .fleet-intro{grid-template-columns:1fr; gap:12px} }
.fleet-intro p{
  margin:0; font-family:var(--f-display); font-weight:500;
  font-size:clamp(17px,1.4vw,21px); line-height:1.35; color:var(--ink);
  max-width:60ch; text-wrap:pretty;
}
.fleet-intro p em{font-style:normal; color:var(--orange)}
.fleet-intro .fleet-tags{
  display:flex; flex-wrap:wrap; gap:6px;
  font-family:var(--f-mono); font-size:10.5px;
  text-transform:uppercase; letter-spacing:.1em; color:var(--muted);
}
.fleet-intro .fleet-tags span{
  padding:4px 10px; border:1px solid var(--rule);
}
.fleet-grid{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:16px;
}
@media(max-width:900px){ .fleet-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .fleet-grid{grid-template-columns:1fr} }
.rig{
  border:1px solid var(--rule); background:var(--paper);
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition:border-color .2s;
}
body[data-theme="dark"] .rig{background:var(--paper-2)}
.rig:hover{border-color:var(--navy)}
.rig .img-wrap{height:160px;position:relative;overflow:hidden;background:var(--paper-3)}
.rig .img-wrap img{width:100%;height:100%;object-fit:cover}
.rig .img-wrap.placeholder{
  background:
    repeating-linear-gradient(135deg, var(--paper-2) 0 14px, var(--paper-3) 14px 28px);
  display:flex;align-items:flex-end;padding:0;
}
.rig .img-wrap.placeholder .ph-tag{
  font-family:var(--f-mono);font-size:10px;text-transform:uppercase;
  letter-spacing:.12em; padding:8px 12px; background:var(--navy-deep); color:#fff;
}
.rig .body{padding:16px 18px 18px}
.rig .row{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.rig h4{
  font-family:var(--f-display);font-size:20px;font-weight:700;margin:0 0 2px;
  letter-spacing:.02em;text-transform:uppercase;color:var(--navy);
}
body[data-theme="dark"] .rig h4{color:#F4F4F2}
.rig .sub{font-family:var(--f-mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.rig p{color:var(--muted);font-size:13px;margin:10px 0 0;line-height:1.5}
.rig .stats{
  display:flex;gap:14px;margin-top:14px;padding-top:12px;border-top:1px dashed var(--rule);
  font-family:var(--f-mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;
}
.rig .stats b{
  display:block;font-family:var(--f-display);font-size:20px;
  color:var(--ink);letter-spacing:0;font-weight:700;margin-bottom:2px;
}
.rig .status{
  position:absolute;top:12px;right:12px; z-index:2;
  font-family:var(--f-mono);font-size:10px;font-weight:600;
  padding:5px 10px;background:rgba(15,34,68,.92);color:#4ADE80;
  text-transform:uppercase;letter-spacing:.1em;
  display:flex;align-items:center;gap:6px;
}
.rig .status::before{content:"";width:6px;height:6px;border-radius:50%;background:#4ADE80;animation:blink 1.6s infinite}
.rig .status.busy{color:var(--orange)}
.rig .status.busy::before{background:var(--orange)}
.rig .unit-badge{
  position:absolute;top:12px;left:12px; z-index:2;
  font-family:var(--f-display);font-size:14px;font-weight:700;
  padding:5px 10px;background:var(--orange);color:#fff;
  letter-spacing:.04em;
}

/* -------- History -------- */
.history{
  background:var(--navy-deep);color:#F4F4F2;
  position:relative;
}
.history::before{
  content:"";position:absolute;top:0;left:0;right:0;height:6px;
  background:linear-gradient(90deg, var(--orange) 0 50%, transparent 50%);
  background-size:24px 100%;
}
.history .sect-hd h2{color:#fff}
.history .sect-hd .lede{color:rgba(244,244,242,.7)}
.history .sect-num{color:rgba(244,244,242,.55)}
.history .sect-num::before{background:rgba(244,244,242,.3)}
.history .eyebrow{color:rgba(244,244,242,.6)}
.timeline{
  position:relative;
  border-top:1px solid rgba(244,244,242,.18);
  margin-top:24px;
}
.tl-row{
  display:grid;
  grid-template-columns:140px 1fr 1.3fr;
  gap:24px; align-items:start;
  padding:18px 0; border-bottom:1px solid rgba(244,244,242,.13);
}
@media(max-width:820px){ .tl-row{grid-template-columns:1fr; gap:12px} }
.tl-year{
  font-family:var(--f-display);font-weight:700;
  font-size:clamp(34px,3.5vw,48px);letter-spacing:0;
  color:var(--orange);line-height:1;
}
.tl-title{
  font-family:var(--f-display);font-size:17px;font-weight:600;
  letter-spacing:.02em;text-transform:uppercase;color:#fff;
}
.tl-body{color:rgba(244,244,242,.72);font-size:14px;line-height:1.55;text-wrap:pretty}

/* memorial */
.memorial{
  margin-top:28px;padding:24px 28px;
  background:rgba(255,255,255,.04);
  border-left:4px solid var(--orange);
  display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;
}
@media(max-width:760px){ .memorial{grid-template-columns:1fr;padding:32px} }
.memorial .seal{
  width:80px;height:80px;border-radius:50%;
  border:2px solid var(--orange);color:var(--orange);
  display:grid;place-items:center;font-family:var(--f-display);font-size:11px;
  text-transform:uppercase;letter-spacing:.12em;text-align:center;
  font-weight:600;line-height:1.1;
}
.memorial h4{
  font-family:var(--f-display);font-size:22px;font-weight:600;
  margin:0 0 6px;letter-spacing:.02em;text-transform:uppercase;color:#fff;
}
.memorial .dates{
  font-family:var(--f-mono);font-size:11px;color:var(--orange);
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;
}
.memorial p{color:rgba(244,244,242,.78);font-size:14.5px;line-height:1.6;margin:0;max-width:62ch}

/* -------- People -------- */
.people-intro{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-bottom:28px;
  border-top:2px solid var(--navy); border-bottom:1px solid var(--rule);
}
@media(max-width:760px){ .people-intro{grid-template-columns:repeat(3,1fr)} }
.peoplecount{padding:14px 18px;border-right:1px solid var(--rule)}
.peoplecount:last-child{border-right:none}
.peoplecount b{
  display:block;font-family:var(--f-display);font-size:clamp(28px,3vw,40px);
  font-weight:700;color:var(--navy);line-height:1;letter-spacing:0;
}
body[data-theme="dark"] .peoplecount b{color:#F4F4F2}
.peoplecount span{
  font-family:var(--f-mono);font-size:10.5px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.12em;display:block;margin-top:4px;font-weight:500;
}

.people-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;
}
@media(max-width:900px){ .people-grid{grid-template-columns:repeat(2,1fr)} }

/* compact 2-photo leadership + roster list */
.leaders{
  display:grid; grid-template-columns: minmax(0,220px) minmax(0,220px) minmax(0,1fr);
  gap:24px; align-items:start;
}
@media(max-width:760px){
  .leaders{grid-template-columns:1fr 1fr; gap:20px}
  .leader-roster{grid-column:1 / -1}
}
.leader .img-frame{aspect-ratio:4/5;margin-bottom:10px}
.leader .img-frame.placeholder{
  background:
    repeating-linear-gradient(135deg, var(--paper-2) 0 14px, var(--paper-3) 14px 28px);
  display:flex;align-items:flex-end;
}
.leader .img-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.leader .img-frame .ph-tag{
  font-family:var(--f-mono);font-size:10px;text-transform:uppercase;
  letter-spacing:.12em; padding:7px 11px; background:var(--navy-deep); color:#fff;
  position:relative; z-index:1;
}
.leader-meta b{
  font-family:var(--f-display);font-size:18px;font-weight:700;
  display:block;letter-spacing:.02em;text-transform:uppercase;color:var(--navy);
}
body[data-theme="dark"] .leader-meta b{color:#F4F4F2}
.leader-meta .role{
  font-family:var(--f-mono);font-size:10.5px;color:var(--orange);
  text-transform:uppercase;letter-spacing:.1em;margin-top:3px;font-weight:600;
}
.leader-roster{
  list-style:none;margin:0;padding:0;
  border-top:1px solid var(--rule);
  font-family:var(--f-mono);
}
.leader-roster li{
  padding:10px 0;border-bottom:1px solid var(--rule);
  display:grid; grid-template-columns: minmax(0,200px) minmax(0,1fr); gap:16px;
  align-items:baseline;
  font-size:11.5px; letter-spacing:.04em;
}
.leader-roster li .k{
  font-family:var(--f-display); font-weight:700; font-size:13px;
  text-transform:uppercase; letter-spacing:.04em; color:var(--navy);
}
body[data-theme="dark"] .leader-roster li .k{color:#F4F4F2}
.leader-roster li .v{ color:var(--muted); letter-spacing:.02em; }
.leader-roster li.roster-link{display:block;padding:14px 0 0;border:none}
.leader-roster li.roster-link a{
  color:var(--orange); font-weight:700; text-decoration:underline;
  letter-spacing:.08em; text-transform:uppercase; font-size:11px;
}
.person{position:relative}
.person .img-frame{aspect-ratio:4/5;margin-bottom:14px}
.person .img-frame.placeholder{
  background:
    repeating-linear-gradient(135deg, var(--paper-2) 0 14px, var(--paper-3) 14px 28px);
  display:flex;align-items:flex-end;
}
.person .img-frame.placeholder .ph-tag{
  font-family:var(--f-mono);font-size:10px;text-transform:uppercase;
  letter-spacing:.12em; padding:8px 12px; background:var(--navy-deep); color:#fff;
}
.person b{
  font-family:var(--f-display);font-size:18px;font-weight:700;
  display:block;letter-spacing:.02em;text-transform:uppercase;color:var(--navy);
}
body[data-theme="dark"] .person b{color:#F4F4F2}
.person .role{
  font-family:var(--f-mono);font-size:10.5px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em;margin-top:3px;font-weight:500;
}
.person .tenure{
  font-family:var(--f-mono);font-size:10.5px;color:var(--orange);
  margin-top:8px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
}

/* -------- Donate -------- */
.donate{
  background:var(--paper-2);
  border-top:2px solid var(--navy); border-bottom:2px solid var(--navy);
}
body[data-theme="dark"] .donate{background:var(--paper-2)}
.donate-grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:36px;align-items:start;
}
@media(max-width:900px){ .donate-grid{grid-template-columns:1fr} }
.donate-box{
  background:var(--paper); border:1px solid var(--rule);
  padding:clamp(28px,3vw,40px);
  border-top:6px solid var(--orange);
}
body[data-theme="dark"] .donate-box{background:var(--paper-3)}
.amt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
@media(max-width:560px){ .amt-grid{grid-template-columns:repeat(2,1fr)} }
.amt{
  appearance:none;cursor:pointer;background:transparent;
  border:1px solid var(--rule);padding:18px 8px;
  font-family:var(--f-display);font-size:24px;font-weight:700;color:inherit;letter-spacing:0;
  transition:all .15s;
}
.amt:hover{border-color:var(--navy)}
.amt[aria-selected="true"]{background:var(--orange);border-color:var(--orange);color:#fff}
.custom{
  width:100%;border:1px solid var(--rule);background:transparent;color:inherit;
  padding:14px 16px;font-family:var(--f-display);font-size:22px;font-weight:600;letter-spacing:0;
  margin-bottom:10px;
}
.custom::placeholder{color:var(--muted-2)}
.freq{display:flex;gap:0;margin-bottom:18px;border:1px solid var(--rule)}
.freq button{
  flex:1;appearance:none;border:0;background:transparent;color:inherit;
  padding:10px 8px;
  font-family:var(--f-display);font-size:13px;font-weight:600;cursor:pointer;
  letter-spacing:.05em;text-transform:uppercase;
  border-right:1px solid var(--rule);
}
.freq button:last-child{border-right:none}
.freq button[aria-selected="true"]{background:var(--navy);color:#fff}
.impact-line{
  margin-top:18px;padding:14px 0;
  border-top:1px dashed var(--rule);
  font-family:var(--f-mono);font-size:12px;color:var(--muted);letter-spacing:.04em;
  line-height:1.6;
}
.impact-line b{color:var(--orange);font-weight:700}

.donate-copy h3{
  font-family:var(--f-display);font-size:clamp(26px,3vw,38px);
  font-weight:600;letter-spacing:0;line-height:1;margin:0 0 14px;
  color:var(--navy);text-transform:uppercase;text-wrap:balance;
}
body[data-theme="dark"] .donate-copy h3{color:#F4F4F2}
.donate-copy p{font-size:15px;color:var(--muted);line-height:1.55;max-width:52ch}
.donate-lines{
  margin-top:18px;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:0;
  font-family:var(--f-mono);font-size:11px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;font-weight:500;
}
.donate-lines li{
  padding:10px 0;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:baseline;
}
.donate-lines li:last-child{border-bottom:1px solid var(--rule)}
.donate-lines li b{
  color:var(--navy);font-weight:700;font-family:var(--f-display);
  font-size:18px;letter-spacing:0;text-transform:none;
}
body[data-theme="dark"] .donate-lines li b{color:#F4F4F2}

.donate-other{
  margin-top:18px;padding:14px 16px;background:var(--paper);border:1px solid var(--rule);
}
body[data-theme="dark"] .donate-other{background:var(--paper-3)}
.donate-other h5{
  font-family:var(--f-display);font-size:14px;text-transform:uppercase;
  letter-spacing:.06em;margin:0 0 10px;color:var(--navy);font-weight:700;
}
body[data-theme="dark"] .donate-other h5{color:#F4F4F2}
.donate-other p{font-size:13.5px;color:var(--muted);line-height:1.55;margin:0}

/* -------- Contact -------- */
.contact-grid{
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:40px;
}
@media(max-width:900px){ .contact-grid{grid-template-columns:1fr} }
.contact-img{height:280px}
.contact-lines{display:flex;flex-direction:column;gap:0;border-top:2px solid var(--navy)}
.contact-line{
  padding:14px 0;border-bottom:1px solid var(--rule);
  display:grid;grid-template-columns:128px 1fr;gap:18px;align-items:baseline;
}
.contact-line .k{
  font-family:var(--f-mono);font-size:11px;text-transform:uppercase;
  letter-spacing:.12em;color:var(--muted);font-weight:600;
}
.contact-line .v{font-family:var(--f-display);font-size:17px;font-weight:600;letter-spacing:.01em;text-transform:uppercase;color:var(--navy)}
body[data-theme="dark"] .contact-line .v{color:#F4F4F2}
.contact-line .v small{
  display:block;font-family:var(--f-body);font-weight:400;font-size:14px;
  color:var(--muted);letter-spacing:0;margin-top:4px;text-transform:none;
}
.contact-line .v a{text-decoration:none}
.emergency-callout{
  margin-top:20px;padding:18px 20px;
  background:var(--navy-deep);color:#fff;
  border-left:6px solid var(--orange);
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
}
.emergency-callout .big{
  font-family:var(--f-display);font-size:26px;font-weight:700;
  color:#fff;letter-spacing:.02em;line-height:1;text-transform:uppercase;
}
.emergency-callout small{
  font-family:var(--f-mono);font-size:11px;text-transform:uppercase;
  letter-spacing:.12em;color:var(--orange);display:block;margin-bottom:4px;font-weight:600;
}
.emergency-callout .col{display:flex;flex-direction:column}
.emergency-callout .sep{width:1px;height:48px;background:rgba(255,255,255,.15)}
.emergency-callout .ph{
  font-family:var(--f-mono);font-size:18px;font-weight:600;color:#fff;
  letter-spacing:.05em;
}

/* -------- FAQ -------- */
.faq{border-top:2px solid var(--navy);margin-top:12px}
.faq details{border-bottom:1px solid var(--rule);padding:14px 0}
.faq summary{
  list-style:none;cursor:pointer;
  display:grid;grid-template-columns:44px 1fr 28px;gap:16px;align-items:baseline;
  font-family:var(--f-display);font-size:clamp(16px,1.5vw,19px);font-weight:600;
  letter-spacing:.01em;text-transform:uppercase;color:var(--navy);
}
body[data-theme="dark"] .faq summary{color:#F4F4F2}
.faq summary::-webkit-details-marker{display:none}
.faq summary .n{font-family:var(--f-mono);font-size:12px;color:var(--orange);font-weight:600;letter-spacing:.08em;text-transform:none}
.faq summary .ico{
  width:28px;height:28px;border:1px solid var(--rule);
  display:grid;place-items:center;transition:transform .2s;font-size:14px;color:inherit;
}
.faq details[open] summary .ico{transform:rotate(45deg);background:var(--orange);color:#fff;border-color:var(--orange)}
.faq .ans{
  padding:10px 0 0 60px;color:var(--muted);font-size:14px;line-height:1.6;
  max-width:74ch;text-wrap:pretty;
}
@media(max-width:560px){ .faq .ans{padding-left:0} }

/* -------- Footer -------- */
footer{
  background:var(--navy-deep);color:#F4F4F2;padding:48px 0 24px;
  border-top:6px solid var(--orange);
}
.footer-top{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;
}
@media(max-width:900px){ .footer-top{grid-template-columns:1fr 1fr;gap:40px} }
@media(max-width:560px){ .footer-top{grid-template-columns:1fr} }
.footer-top h5{
  font-family:var(--f-mono);font-size:11px;text-transform:uppercase;
  letter-spacing:.16em;color:var(--orange);margin:0 0 18px;font-weight:600;
}
.footer-top a{display:block;color:rgba(244,244,242,.85);text-decoration:none;padding:5px 0;font-size:14px}
.footer-top a:hover{color:var(--orange)}
.footer-brand .big{
  font-family:var(--f-display);font-size:32px;font-weight:700;
  letter-spacing:.02em;line-height:1;margin-bottom:14px;
  color:#fff;text-transform:uppercase;
}
.footer-brand p{color:rgba(244,244,242,.65);font-size:14px;line-height:1.6;max-width:34ch}
.footer-bot{
  margin-top:32px;padding-top:18px;border-top:1px solid rgba(244,244,242,.15);
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--f-mono);font-size:11px;color:rgba(244,244,242,.55);
  letter-spacing:.08em;flex-wrap:wrap;
}
.footer-bot .badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border:1px solid rgba(244,244,242,.18);
  color:#F4F4F2;font-weight:600;
}

/* ── Dispatch Ticker (hero side) ── */
.ticker{
  background:rgba(8,18,40,.92);
  border:1px solid rgba(232,119,34,.4);
  border-left:4px solid var(--orange);
  font-family:var(--f-mono);
  color:#E5F0FF;
  box-shadow:0 18px 40px rgba(0,0,0,.45);
  position:relative;
  overflow:hidden;
}
.ticker::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.03) 0 1px, transparent 1px 3px);
  mix-blend-mode:overlay;
}
.ticker-hd{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 14px;border-bottom:1px solid rgba(232,119,34,.3);
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(229,240,255,.75);font-weight:600;
}
.ticker-hd .rec{
  color:var(--orange);display:inline-flex;align-items:center;gap:6px;
}
.ticker-hd .rec::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--orange);animation:blink 1.1s infinite}
.ticker-body{padding:8px 14px 12px;display:flex;flex-direction:column;gap:6px;min-height:160px}
.tk-row{
  display:grid;grid-template-columns:64px 50px 1fr;gap:10px;
  font-size:11px;letter-spacing:.04em;
  color:rgba(229,240,255,.65);padding:3px 0;
  opacity:.7;
}
.tk-row.fresh{
  color:#fff;opacity:1;
  animation:tk-in .35s ease both;
}
@keyframes tk-in{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}
.tk-time{color:rgba(229,240,255,.55)}
.tk-code{color:var(--orange);font-weight:600}
.tk-row.tones .tk-code{background:var(--orange);color:#000;padding:0 4px}
.tk-row.tones .tk-txt{color:#FFD7A3}
.tk-txt{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Scroll Readout (top of masthead) ── */
.scroll-readout{
  display:flex;align-items:center;gap:14px;
  padding:6px var(--gut);
  background:var(--ink);color:rgba(244,244,242,.85);
  font-family:var(--f-mono);font-size:10.5px;
  letter-spacing:.14em;text-transform:uppercase;
  border-bottom:1px solid rgba(244,244,242,.1);
}
.scroll-readout .sr-cur{color:var(--orange);font-weight:600;flex-shrink:0}
.scroll-readout .sr-bar{
  flex:1;height:2px;background:rgba(244,244,242,.15);position:relative;
}
.scroll-readout .sr-fill{
  position:absolute;top:0;left:0;bottom:0;background:var(--orange);
  transition:width .15s linear;
}
.scroll-readout .sr-pct{font-variant-numeric:tabular-nums;color:rgba(244,244,242,.65);flex-shrink:0;min-width:34px;text-align:right}
@media(max-width:720px){ .scroll-readout .sr-bar{display:none} }

/* ── Fleet feature with hotspots ── */
.rig-feature{
  display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:0;
  margin-bottom:24px;
  border:1px solid var(--rule);
  background:var(--paper);
}
body[data-theme="dark"] .rig-feature{background:var(--paper-2)}
@media(max-width:900px){ .rig-feature{grid-template-columns:1fr} }
.rig-feature-img{
  position:relative;overflow:hidden;background:var(--ink);
  min-height:320px;
}
.rig-feature-img img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0}
.rig-feature-img .unit-badge.big{
  font-size:18px;padding:8px 14px;letter-spacing:.05em;
}
.rig-feature-img .status.big{
  font-size:11px;padding:7px 12px;letter-spacing:.12em;
}
.hotspot{
  position:absolute;width:28px;height:28px;border:0;background:transparent;
  transform:translate(-50%,-50%);cursor:pointer;padding:0;
  display:grid;place-items:center;
}
.hotspot .dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 0 4px rgba(232,119,34,.25),0 0 0 8px rgba(232,119,34,.12);
  position:relative;
}
.hotspot .dot::after{
  content:"";position:absolute;inset:-2px;border-radius:50%;
  border:2px solid var(--orange);
  animation:hs-pulse 1.8s infinite;
}
@keyframes hs-pulse{
  0%{transform:scale(1);opacity:.9}
  100%{transform:scale(2.4);opacity:0}
}
.hotspot-card{
  position:absolute;left:50%;top:calc(100% + 10px);transform:translateX(-50%);
  background:var(--ink);color:#fff;
  padding:10px 14px;min-width:160px;
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.06em;
  text-transform:uppercase;line-height:1.35;
  opacity:0;pointer-events:none;transition:opacity .15s;
  z-index:5;
  border-left:3px solid var(--orange);
  box-shadow:0 12px 28px rgba(0,0,0,.4);
  white-space:nowrap;
}
.hotspot-card b{display:block;color:var(--orange);font-weight:700;margin-bottom:3px;font-size:11px;letter-spacing:.08em}
.hotspot-card span{display:block;color:rgba(244,244,242,.85);text-transform:none;letter-spacing:.02em;font-size:11px}
.hotspot.active .hotspot-card{opacity:1}

.rig-feature-meta{
  padding:22px 24px;border-left:1px solid var(--rule);
  display:flex;flex-direction:column;
}
@media(max-width:900px){ .rig-feature-meta{border-left:none;border-top:1px solid var(--rule)} }
.rig-feature-meta h3{
  font-family:var(--f-display);font-size:30px;font-weight:700;
  margin:8px 0 4px;letter-spacing:.02em;text-transform:uppercase;color:var(--navy);
  line-height:.95;
}
body[data-theme="dark"] .rig-feature-meta h3{color:#F4F4F2}
.rig-feature-meta h3 small{
  display:block;font-family:var(--f-mono);font-size:11px;
  color:var(--orange);font-weight:600;letter-spacing:.12em;margin-top:8px;
}
.rig-feature-meta p{color:var(--muted);font-size:13.5px;line-height:1.55;margin:10px 0 16px}
.rig-feature-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
.rig-feature-stats > div{
  padding:14px 0;border-right:1px solid var(--rule);
  font-family:var(--f-mono);font-size:10.5px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.08em;
}
.rig-feature-stats > div:last-child{border-right:none;padding-left:14px}
.rig-feature-stats > div:not(:first-child):not(:last-child){padding-left:14px}
.rig-feature-stats b{display:block;font-family:var(--f-display);font-size:22px;color:var(--ink);letter-spacing:0;font-weight:700;margin-bottom:3px}
.rig-tabs{
  display:flex;gap:0;margin-top:auto;padding-top:16px;flex-wrap:wrap;
}
.rig-tab{
  appearance:none;border:1px solid var(--rule);background:transparent;color:inherit;
  padding:10px 14px;font-family:var(--f-mono);font-size:11px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;cursor:pointer;
  margin-right:-1px;
}
.rig-tab.active{background:var(--navy);color:#fff;border-color:var(--navy);position:relative;z-index:2}

/* ── Awards strip ── */
.awards{
  background:var(--paper);
  padding:clamp(36px,4vw,56px) 0;
  border-top:1px solid var(--rule-strong);border-bottom:1px solid var(--rule-strong);
}
body[data-theme="dark"] .awards{background:var(--paper-2)}
.awards-hd{margin-bottom:24px;display:flex;flex-direction:column;gap:10px}
.awards-hd h3{
  font-family:var(--f-display);font-size:clamp(24px,2.6vw,36px);font-weight:700;
  letter-spacing:.01em;line-height:.95;margin:0;text-transform:uppercase;color:var(--navy);
  text-wrap:balance;
}
body[data-theme="dark"] .awards-hd h3{color:#F4F4F2}
.awards-grid{
  display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:0;
  border-top:2px solid var(--navy);border-bottom:2px solid var(--navy);
}
@media(max-width:960px){ .awards-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .awards-grid{grid-template-columns:1fr} }
.award{
  padding:18px;border-right:1px solid var(--rule);
  display:flex;flex-direction:column;gap:6px;min-height:120px;
}
.award:last-child{border-right:none}
@media(max-width:960px){
  .award{border-bottom:1px solid var(--rule)}
  .award:nth-child(2n){border-right:none}
}
.award-y{
  font-family:var(--f-display);font-size:28px;font-weight:700;
  color:var(--orange);line-height:1;letter-spacing:0;
}
.award-t{
  font-family:var(--f-display);font-size:14px;font-weight:700;
  color:var(--navy);text-transform:uppercase;letter-spacing:.02em;line-height:1.2;
}
body[data-theme="dark"] .award-t{color:#F4F4F2}
.award-w{
  font-family:var(--f-mono);font-size:10.5px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.08em;margin-top:auto;
}
.partners{
  margin-top:20px;padding-top:16px;
  display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;
  border-top:1px dashed var(--rule);
  font-family:var(--f-mono);font-size:10.5px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.08em;font-weight:500;
}
.partners-lbl{color:var(--orange);font-weight:600;margin-right:8px}

/* ── Multi-page: page hero + home highlights ── */
.page-hero{
  padding:clamp(56px,7vw,96px) 0 clamp(40px,5vw,72px);
  background:var(--paper);
  border-bottom:1px solid var(--rule-strong);
}
.page-hero-grid{
  display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);
  gap:48px;align-items:end;
}
@media(max-width:900px){ .page-hero-grid{grid-template-columns:1fr;gap:24px} }
.page-hero .eyebrow{margin-bottom:18px;display:inline-flex;align-items:center}
.page-h1{
  font-family:var(--f-display);font-weight:700;
  font-size:clamp(48px,7vw,108px);
  line-height:.92;letter-spacing:0;margin:0;
  text-transform:uppercase;text-wrap:balance;color:var(--ink);
}
.page-h1 em{font-style:normal;color:var(--orange)}
.page-lede{
  font-size:clamp(16px,1.4vw,19px);color:var(--muted);
  max-width:42ch;text-wrap:pretty;margin:0;
  padding-bottom:6px;
}

.home-highlights{padding-top:clamp(48px,6vw,80px)}
.hh-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;
  border-top:2px solid var(--navy);border-bottom:2px solid var(--navy);
}
@media(max-width:900px){ .hh-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .hh-grid{grid-template-columns:1fr} }
.hh-card{
  display:grid;grid-template-columns:64px 1fr;gap:16px;
  padding:28px;text-decoration:none;color:inherit;
  border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  transition:background .15s;
  min-height:200px;
}
.hh-card:hover{background:var(--paper-2)}
.hh-k{
  font-family:var(--f-mono);font-size:12px;color:var(--orange);
  font-weight:700;letter-spacing:.1em;
}
.hh-card h3{
  font-family:var(--f-display);font-size:26px;font-weight:700;
  margin:0 0 8px;letter-spacing:.02em;text-transform:uppercase;color:var(--navy);line-height:1;
}
body[data-theme="dark"] .hh-card h3{color:#F4F4F2}
.hh-card p{color:var(--muted);font-size:14px;line-height:1.55;margin:0 0 14px}
.hh-arr{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--orange);font-weight:600;
}
.hh-card:hover .hh-arr{color:var(--navy)}
body[data-theme="dark"] .hh-card:hover .hh-arr{color:#F4F4F2}

/* ── Announcement Ticker (top-of-page marquee) ── */
.ann-tick{
  display:flex;align-items:stretch;
  background:var(--navy-deep);color:#F4F4F2;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;
  border-bottom:3px solid var(--orange);
  position:relative; overflow:hidden;
  height:44px;
}
.ann-tick-lead{
  flex-shrink:0;display:flex;align-items:center;gap:8px;
  padding:0 16px;background:var(--orange);color:#fff;
  font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:11px;
  position:relative;z-index:2;
}
.ann-tick-lead::after{
  content:"";position:absolute;right:-12px;top:0;bottom:0;width:12px;
  background:linear-gradient(90deg, var(--orange), transparent);
}
.ann-pulse{
  width:8px;height:8px;border-radius:50%;background:#fff;
  box-shadow:0 0 0 0 rgba(255,255,255,.6);
  animation:annpulse 1.4s infinite;
}
@keyframes annpulse{
  0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}
  100%{box-shadow:0 0 0 10px rgba(255,255,255,0)}
}
.ann-tick-track{
  flex:1;overflow:hidden;display:flex;align-items:center;position:relative;
  mask-image:linear-gradient(90deg, transparent 0, #000 30px, #000 calc(100% - 80px), transparent 100%);
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 30px, #000 calc(100% - 80px), transparent 100%);
}
.ann-tick-run{
  display:flex;align-items:center;gap:0;
  animation:annscroll 80s linear infinite;
  white-space:nowrap;flex-shrink:0;
  padding-left:30px;
}
.ann-tick:hover .ann-tick-run{animation-play-state:paused}
@keyframes annscroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.ann-item{
  display:inline-flex;align-items:center;gap:10px;
  color:rgba(244,244,242,.92);text-decoration:none;
  padding:0 6px;flex-shrink:0;
}
.ann-item:hover{color:#fff}
.ann-kind{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  font-size:10.5px;
  padding:3px 8px;
  border:1px solid rgba(244,244,242,.25);
}
.ann-event   .ann-kind{color:var(--orange);border-color:rgba(232,119,34,.45)}
.ann-social  .ann-kind{color:#7DD3FC;border-color:rgba(125,211,252,.45)}
.ann-news    .ann-kind{color:#FCD34D;border-color:rgba(252,211,77,.4)}
.ann-txt{font-weight:500;color:rgba(244,244,242,.95);letter-spacing:.02em}
.ann-sep{color:var(--orange);margin:0 18px;font-size:10px;opacity:.5}
.ann-tick-cta{
  flex-shrink:0;display:flex;align-items:center;gap:6px;
  padding:0 16px;background:rgba(244,244,242,.06);
  color:#fff;text-decoration:none;
  font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:11px;
  border-left:1px solid rgba(244,244,242,.1);
}
.ann-tick-cta:hover{background:rgba(232,119,34,.2);color:var(--orange)}
@media(max-width:720px){
  .ann-tick{font-size:11px}
  .ann-tick-lead{padding:0 10px;font-size:10px}
  .ann-tick-cta{display:none}
}

/* ── Roster styles ── */
.roster-group { margin-bottom: 3rem; }
.roster-head { display: flex; align-items: baseline; gap: 1rem; margin-bottom: 1rem; border-bottom: 2px solid var(--navy); padding-bottom: .5rem; }
.roster-head h3 { font-family: 'Barlow Condensed', sans-serif; font-size: 1.3rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; margin: 0; }
.roster-note { font-size: .8rem; color: var(--text-mid); text-transform: uppercase; letter-spacing: .08em; }
.roster-list { columns: 2; gap: 2rem; padding-left: 1.25rem; line-height: 2; color: var(--text-mid); }
@media (max-width: 600px) { .roster-list { columns: 1; } }


/* ─── Mobile nav drawer ─── */

body[data-theme="dark"] 
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}


body[data-theme="dark"] 
body[data-theme="dark"] 


/* ─── Mobile: hide desktop CTAs in header at small screen ─── */
@media(max-width:1080px){
  .cta-row .btn.ghost,
  .cta-row .btn.orange:not(:last-of-type) { display:none }
}
@media(max-width:480px){
  .cta-row .btn { display:none }
}

/* ─── General mobile overflow safety ─── */
img,video,iframe,embed,object{ max-width:100%; }
.wrap{ overflow-x:hidden; }

/* ─── Ticker fix on very small screens ─── */
@media(max-width:480px){
  .statbar .right{ display:none }
  .brand-name > span:first-of-type{ display:none }
}

/* ─── Hero headline size on tiny screens ─── */
@media(max-width:420px){
  .hero-hl{ font-size:clamp(28px,9vw,44px) !important; }
}

/* ── Donation picker ── */
.donate-amounts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
  margin-bottom: 1rem;
}
.amt-btn {
  background: var(--paper-2);
  border: 2px solid var(--rule);
  border-radius: 8px;
  padding: .65rem .5rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--navy);
  cursor: pointer;
  transition: all .15s;
}
.amt-btn:hover { border-color: var(--orange); color: var(--orange); }
.amt-btn.active { background: var(--navy); border-color: var(--navy); color: #fff; }
.amt-custom {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: .4rem;
  border: 2px solid var(--rule);
  border-radius: 8px;
  padding: .5rem .75rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--navy);
  background: var(--paper-2);
}
.amt-custom span { opacity: .5; }
.amt-custom input {
  flex: 1;
  border: none;
  background: transparent;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  outline: none;
  width: 100%;
}
.freq-row {
  display: flex;
  gap: .5rem;
  margin-bottom: 1.25rem;
}
.freq-btn {
  flex: 1;
  background: var(--paper-2);
  border: 2px solid var(--rule);
  border-radius: 8px;
  padding: .6rem;
  font-family: 'Barlow', sans-serif;
  font-size: .85rem;
  font-weight: 600;
  color: var(--ink-2);
  cursor: pointer;
  transition: all .15s;
}
.freq-btn:hover { border-color: var(--orange); }
.freq-btn.active { background: var(--navy); border-color: var(--navy); color: #fff; }
.impact-line {
  background: var(--paper-2);
  border-left: 3px solid var(--orange);
  border-radius: 0 8px 8px 0;
  padding: .75rem 1rem;
  font-size: .9rem;
  color: var(--ink-2);
  margin-bottom: .5rem;
  line-height: 1.5;
}
.impact-amt {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--navy);
}

/* ── Calendar register button ── */
.cal-row {
  display: grid;
  align-items: center;
}
.cal-reg-btn {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--orange);
  text-decoration: none;
  white-space: nowrap;
  padding: .3rem .6rem;
  border: 1px solid rgba(232,119,34,.4);
  border-radius: 4px;
  transition: all .15s;
}
.cal-reg-btn:hover {
  background: var(--orange);
  color: #fff;
  border-color: var(--orange);
}

/* ── Ticker: prevent page-level scrollbar ── */
.ann-tick {
  overflow: hidden !important;
}
.ann-tick-track {
  overflow: hidden !important;
  max-width: 100%;
}
/* kind labels for class/fund in ticker */
.ann-class .ann-kind { color: #86EFAC; border-color: rgba(134,239,172,.4); }
.ann-fund  .ann-kind { color: #FCD34D; border-color: rgba(252,211,77,.4); }

/* ── v13: Scroll trap fix for sub-page heroes ── */
.page-hero, .page-hero * {
  touch-action: pan-y;
}
.page-hero-grid {
  pointer-events: auto;
}
/* Ensure page-hero doesn't create scroll isolation */
.page-hero {
  overscroll-behavior: auto;
}
/* Banner carousel transitions */
.banner-carousel img {
  transition: opacity 0.4s ease;
}
