/* ============================================================
   Broad Water Innovations 2026 — main stylesheet
   Direction A "Editorial Naturalist".
   Ported from docs/superpowers/design/home-direction-a.html.
   ============================================================ */

/* ---- Tokens ---- */
:root{
  /* brand palette (fixed) */
  --paper:#F7F3EA; --paper2:#EFE9DA;
  --forest:#1E3A2B; --forest2:#2C5239; --moss:#5C7A5E;
  --gold:#C9A24B; --clay:#BC6C49;
  --ink:#23271F; --ink2:#566052;
  /* semantic tokens — LIGHT (default) */
  --bg:var(--paper); --bg-alt:var(--paper2); --surface:#ffffff;
  --text:var(--ink); --text-muted:var(--ink2); --heading:var(--forest);
  --border:#e6dfcd;
  --band-bg:var(--forest); --band-bg-2:var(--forest2); --band-text:#ffffff; --band-muted:#cfe0cf;
  --accent:var(--clay); --accent-gold:var(--gold);
}
html[data-theme="forest"]{
  /* semantic tokens — FOREST (dark) */
  --bg:#15251B; --bg-alt:#1B3326; --surface:#21402E;
  --text:#EAF0E8; --text-muted:#A9C0A9; --heading:#ffffff;
  --border:rgba(255,255,255,.12);
  --band-bg:#1B3326; --band-bg-2:#234634; --band-text:#ffffff; --band-muted:#cfe0cf;
  --accent:#D98A5E; --accent-gold:#D8B05E;
}

/* ---- Reset / base ---- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background-color .25s ease,color .25s ease;
}
.serif{font-family:'Fraunces',serif}
img{max-width:100%;display:block}
a{color:var(--accent)}

/* ---- Layout primitives ---- */
.wrap{max-width:1120px;margin:0 auto;padding:0 28px}
.eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600}

/* ---- Buttons ---- */
.btn{display:inline-block;text-decoration:none;font-weight:600;font-size:14px;padding:13px 26px;border-radius:30px;transition:transform .12s ease,opacity .12s ease}
.btn:hover{transform:translateY(-1px);opacity:.94}
.btn.g{background:var(--clay);color:#fff}
.btn.o{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6)}

/* ---- Small-screen container ---- */
@media(max-width:820px){
  .wrap{padding:0 20px}
}

/* ============================================================
   T4 — Header / nav
   ============================================================ */
header.nav{position:absolute;top:0;left:0;right:0;z-index:20}
header.nav::before{content:'';position:absolute;top:0;left:0;right:0;height:140px;background:linear-gradient(180deg,rgba(8,14,10,.55) 0%,rgba(8,14,10,0) 100%);z-index:-1;pointer-events:none}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:22px;padding-bottom:22px}
.nav-logo{display:inline-block}
.nav-logo img{height:58px;width:auto;filter:drop-shadow(0 1px 3px rgba(0,0,0,.55))}
.nav-menu{display:flex;align-items:center;gap:26px}
.nav-list{display:flex;gap:26px;list-style:none;align-items:center;margin:0;padding:0}
.nav-list a{color:#fff;text-decoration:none;font-size:13.5px;font-weight:500;letter-spacing:.02em;text-shadow:0 1px 6px rgba(0,0,0,.45)}
.nav-list a:hover{opacity:.85}
.nav-menu .donate{background:var(--gold);color:#23271F;padding:9px 18px;border-radius:30px;font-weight:600;text-decoration:none;font-size:13.5px;text-shadow:none}
.theme-toggle{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.42);color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:15px;transition:background .15s ease}
.theme-toggle:hover{background:rgba(255,255,255,.26)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:22px;flex-direction:column;justify-content:space-between;padding:0}
.nav-toggle span{display:block;height:2px;width:100%;background:#fff;border-radius:2px;box-shadow:0 1px 3px rgba(0,0,0,.45)}
@media(max-width:820px){
  .nav-toggle{display:flex}
  .nav-menu{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--forest);padding:8px 28px 22px;display:none;box-shadow:0 16px 30px rgba(0,0,0,.25)}
  .nav-menu.nav-open{display:flex}
  .nav-list{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .nav-list a{display:block;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.12);text-shadow:none}
  .nav-menu .donate{margin-top:16px;text-align:center}
}

/* ============================================================
   T5 — Footer
   ============================================================ */
footer.ft{background:var(--band-bg);color:var(--band-muted);padding:56px 0 30px}
footer.ft .wrap{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
footer.ft img{height:46px;margin-bottom:14px;width:auto}
footer.ft .col{min-width:150px}
footer.ft .col p{max-width:30ch;font-size:13px;color:var(--band-muted)}
footer.ft .col h4{color:var(--band-text);font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px}
footer.ft a{color:var(--band-muted);text-decoration:none;font-size:13.5px;display:block;margin-bottom:7px}
footer.ft a:hover{color:var(--band-text);text-decoration:underline}
footer.ft .fine{margin-top:30px;font-size:12px;color:#8fae90;border-top:1px solid rgba(255,255,255,.12);padding-top:18px}

/* ============================================================
   T7 — Hero
   ============================================================ */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;background-repeat:no-repeat}
.hero .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,30,22,.5) 0%,rgba(18,30,22,.04) 24%,rgba(12,22,16,.34) 56%,rgba(9,16,12,.94) 100%)}
.hero .wrap{position:relative;z-index:2;width:100%;text-align:left;padding-bottom:80px}
.hero .eyebrow{color:#f3ead2;margin-bottom:18px;text-shadow:0 1px 8px rgba(0,0,0,.6)}
.hero h1{font-weight:600;font-size:64px;line-height:1.03;letter-spacing:-.015em;text-shadow:0 2px 6px rgba(0,0,0,.6),0 1px 26px rgba(0,0,0,.5);max-width:15ch}
.hero p.sub{margin-top:22px;font-size:19px;max-width:46ch;color:#f6f3ec;text-shadow:0 1px 8px rgba(0,0,0,.65)}
.hero .scroll{margin-top:36px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#e7dec9;opacity:.9}

/* ============================================================
   T7 — Impact band (theme-aware)
   ============================================================ */
.impact{background:var(--band-bg);color:var(--band-text);padding:46px 0}
.impact .wrap{display:flex;flex-wrap:wrap;gap:22px;align-items:center;justify-content:space-between}
.impact .lead{font-size:14px;color:var(--band-muted);max-width:24ch}
.impact .lead b{color:var(--band-text);font-weight:600}
.impact .nums{display:flex;gap:44px;flex-wrap:wrap}
.impact .n b{font-family:'Fraunces',serif;font-weight:600;font-size:42px;color:var(--accent-gold);display:block;line-height:1}
.impact .n span{font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--band-muted)}

@media(max-width:820px){ .hero h1{font-size:42px} }

/* ============================================================
   T8 — Mission
   ============================================================ */
.mission{padding:92px 0;text-align:center;background:var(--bg)}
.mission .eyebrow{color:var(--accent);margin-bottom:18px}
.mission h2{font-weight:500;font-size:34px;line-height:1.34;max-width:21ch;margin:0 auto;color:var(--heading)}
.mission h2 em{font-style:italic;color:var(--accent)}

/* ============================================================
   T8 — Dual CTA
   ============================================================ */
.dual{display:grid;grid-template-columns:1fr 1fr}
.dual .col{padding:74px 58px}
.dual .support{background:var(--bg-alt)}
.dual .partner{background:var(--band-bg-2);color:var(--band-text)}
.dual .eyebrow{margin-bottom:14px}
.dual .support .eyebrow{color:var(--accent)}
.dual .partner .eyebrow{color:var(--accent-gold)}
.dual h2{font-family:'Fraunces',serif;font-weight:600;font-size:30px;line-height:1.12;margin-bottom:14px}
.dual .support h2{color:var(--heading)}
.dual .partner h2{color:var(--band-text)}
.dual p{font-size:15px;margin-bottom:24px;max-width:34ch}
.dual .support p{color:var(--text-muted)}
.dual .partner p{color:var(--band-muted)}

/* ============================================================
   T8 — Education
   ============================================================ */
.edu{padding:62px 0;text-align:center;background:var(--bg)}
.edu .eyebrow{color:var(--moss);margin-bottom:12px}
.edu h3{font-family:'Fraunces',serif;font-weight:600;font-size:26px;color:var(--heading);margin-bottom:8px}
.edu p{color:var(--text-muted);max-width:52ch;margin:0 auto 18px;font-size:15px}
.edu a{color:var(--accent);font-weight:600;text-decoration:none;font-size:14px}

/* ============================================================
   T8 — Trust seals (theme-aware)
   ============================================================ */
.trust{background:var(--bg-alt);padding:34px 0}
.trust .wrap{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.seal{display:flex;align-items:center;gap:10px;font-family:'Inter',system-ui,sans-serif;font-size:12.5px;color:var(--heading);background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 16px}
.seal b{display:block;font-size:13px}
.seal span{color:var(--text-muted);font-size:11px}
.seal .ic{font-size:17px;color:var(--accent-gold);width:22px;text-align:center;flex-shrink:0}

@media(max-width:820px){ .dual{grid-template-columns:1fr} }

/* ============================================================
   T9 (homepage) — A Living Look teaser
   ============================================================ */
.living-teaser{background:var(--band-bg);color:var(--band-text);padding:80px 0}
.living-teaser .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center}
.living-teaser .lt-media{position:relative;border-radius:16px;overflow:hidden;min-height:380px;background-size:cover;background-position:center}
.living-teaser .lt-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,14,10,.25) 0%,rgba(8,14,10,0) 45%,rgba(8,14,10,.55) 100%)}
.lt-badge{position:absolute;top:18px;left:18px;z-index:2;display:flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:rgba(0,0,0,.42);padding:6px 12px;border-radius:30px;color:#fff;backdrop-filter:blur(3px)}
.lt-badge .dot{width:8px;height:8px;border-radius:50%;background:#ff5a4d;display:inline-block}
.lt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:rgba(255,255,255,.16);border:2px solid rgba(255,255,255,.75);display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;z-index:2}
.living-teaser .eyebrow{color:var(--accent-gold);margin-bottom:14px}
.living-teaser h2{font-family:'Fraunces',serif;font-weight:600;font-size:34px;line-height:1.1;color:var(--band-text);margin-bottom:14px}
.living-teaser p{color:var(--band-muted);font-size:16px;margin-bottom:24px;max-width:42ch}

/* ============================================================
   T10 (homepage) — Our Lands (map placeholder + place cards)
   ============================================================ */
.lands{padding:92px 0;background:var(--bg)}
.lands-head{text-align:center;margin-bottom:42px}
.lands-head .eyebrow{color:var(--accent);margin-bottom:14px}
.lands-head h2{font-family:'Fraunces',serif;font-weight:600;font-size:40px;color:var(--heading)}
.lands-head p{color:var(--text-muted);margin:10px auto 0;font-size:16px;max-width:62ch}
.mapph{position:relative;height:340px;border-radius:16px;overflow:hidden;background:radial-gradient(120% 120% at 30% 20%,#dfe9d8 0%,#cdddc4 45%,#bccfb1 100%);border:1px solid var(--border);margin-bottom:34px;display:flex;align-items:center;justify-content:center}
.mapph-note{font-size:13px;color:var(--forest);background:rgba(255,255,255,.86);padding:8px 16px;border-radius:30px}
.places{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.place{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.place .pic{height:150px;background-size:cover;background-position:center}
.place .b{padding:16px 18px 20px}
.place .st{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--moss);font-weight:600}
.place h3{font-family:'Fraunces',serif;font-weight:600;font-size:21px;color:var(--heading);margin:3px 0 8px}
.place p{font-size:13.5px;color:var(--text-muted)}
.place .ac{margin-top:12px;font-size:12px;color:var(--accent);font-weight:600}

@media(max-width:820px){
  .living-teaser .wrap{grid-template-columns:1fr}
  .living-teaser .lt-media{min-height:260px}
  .places{grid-template-columns:1fr}
}

/* ============================================================
   T11 — Interior pages (masthead + body)
   ============================================================ */
.page-hero{position:relative;min-height:44vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,28,20,.45) 0%,rgba(16,28,20,.12) 45%,rgba(12,22,16,.8) 100%)}
.page-hero .wrap{position:relative;z-index:2;padding-top:130px;padding-bottom:46px}
.page-hero h1{font-family:'Fraunces',serif;font-weight:600;font-size:48px;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.5)}

.page-body{padding:64px 0 88px;background:var(--bg)}
.page-body .wrap{max-width:740px}
.page-body > .wrap > *:first-child{margin-top:0}
.page-body p{color:var(--text);margin-bottom:1.1em;font-size:17px;line-height:1.75}
.page-body > .wrap > p:first-of-type{font-size:21px;line-height:1.6;color:var(--heading);font-weight:400}
.page-body h2{font-family:'Fraunces',serif;color:var(--heading);font-size:30px;margin:1.6em 0 .5em;line-height:1.18}
.page-body h3{font-family:'Fraunces',serif;color:var(--heading);font-size:22px;margin:1.4em 0 .4em}
.page-body ul,.page-body ol{margin:0 0 1.3em 0;padding:0}
.page-body ul{list-style:none}
.page-body ul li{position:relative;padding-left:1.7em;margin-bottom:.65em;color:var(--text);font-size:16.5px;line-height:1.6}
.page-body ul li::before{content:'';position:absolute;left:0;top:.6em;width:8px;height:8px;border-radius:50%;background:var(--accent-gold)}
.page-body ol{padding-left:1.3em}
.page-body ol li{margin-bottom:.65em;font-size:16.5px;line-height:1.6}
.page-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.page-body strong{color:var(--heading)}
.page-body blockquote{border-left:3px solid var(--accent-gold);padding-left:1.15em;margin:1.5em 0;font-family:'Fraunces',serif;font-size:20px;line-height:1.4;color:var(--heading);font-style:italic}
.page-body img{border-radius:12px;margin:1.4em 0;height:auto;max-width:100%}
.page-body hr{border:0;border-top:1px solid var(--border);margin:2.2em 0}

/* Steward-partner (B2B) page */
.partner-page .wrap{max-width:1040px}
.partner-page .partner-intro{max-width:680px;font-size:17px}
.partner-page .reassure{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin:38px 0}
.reassure .card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px}
.reassure .card i{font-size:22px;color:var(--accent-gold);margin-bottom:10px;display:block}
.reassure .card h3{font-family:'Fraunces',serif;color:var(--heading);font-size:18px;margin:0 0 6px}
.reassure .card p{color:var(--text-muted);font-size:14px;margin:0}
.partner-cta{text-align:center;background:var(--band-bg-2);color:var(--band-text);padding:54px 30px;border-radius:18px;margin-top:24px}
.partner-cta h2{font-family:'Fraunces',serif;font-size:30px;margin-bottom:20px;color:var(--band-text)}

@media(max-width:820px){ .page-hero h1{font-size:34px} }

/* ============================================================
   T9 — Wildlife showcase page (/wildlife/) — map promoted to property header
   ============================================================ */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.wildlife .wl-wrap{max-width:1100px}
.wl-intro{max-width:720px;font-size:17px;color:var(--text-muted);margin-bottom:18px}
.wl-sample{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text-muted);background:var(--bg-alt);border:1px solid var(--border);border-radius:10px;padding:11px 15px;margin-bottom:26px}
.wl-sample i{color:var(--accent-gold)}
.wtabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.wtab{cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:12px;padding:11px 16px;text-align:left;font-family:inherit}
.wtab:hover{border-color:var(--moss)}
.wtab.active{background:var(--forest);border-color:var(--forest);color:#fff}
.wtab.active span{color:#cfe0cf}
.wtab b{display:block;font-size:14px;font-weight:600}
.wtab span{display:block;font-size:11px;color:var(--text-muted);margin-top:1px}
.wpanel{display:none}
.wpanel.active{display:block}

.wprop-head{display:grid;grid-template-columns:1fr 1.1fr;gap:26px;align-items:center;margin-bottom:24px}
.wph-info h2{font-family:'Fraunces',serif;font-weight:600;font-size:30px;color:var(--heading);margin-bottom:4px}
.wph-loc{color:var(--text-muted);font-size:14px;margin-bottom:18px}
.wph-stats{display:flex;gap:30px}
.wph-stats b{font-family:'Fraunces',serif;font-weight:600;font-size:30px;color:var(--accent);display:block;line-height:1}
.wph-stats span{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}
.wph-map{position:relative;height:184px;border-radius:14px;overflow:hidden;background:radial-gradient(130% 130% at 28% 18%,#e9efe0 0%,#c3d2b4 100%);border:1px solid var(--border)}
.wph-map .propmap-svg{position:absolute;inset:0;width:100%;height:100%}
.parcel{fill:rgba(30,58,43,.26);stroke:var(--gold);stroke-width:2.5;stroke-dasharray:7 5;stroke-linejoin:round}
.water{fill:none;stroke:#7fa9c4;stroke-width:5;stroke-linecap:round;opacity:.6}
.grid{stroke:rgba(46,82,57,.10);stroke-width:1}
.pin{fill:#ff5a4d;stroke:#fff;stroke-width:2.5}
.propmap-cap{position:absolute;left:12px;bottom:11px;font-size:11px;color:var(--forest);background:rgba(255,255,255,.88);padding:4px 10px;border-radius:30px;display:flex;align-items:center;gap:6px}
.propmap-cap i{color:var(--clay)}

.wbody{display:grid;grid-template-columns:.95fr 1.25fr;gap:24px;align-items:start}
.wcam{position:relative;border-radius:16px;overflow:hidden;min-height:300px;background-size:cover;background-position:center}
.wcam::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,14,10,.3) 0%,rgba(8,14,10,0) 40%,rgba(8,14,10,.7) 100%)}
.wcam .badge{position:absolute;top:14px;left:14px;z-index:2;display:flex;align-items:center;gap:7px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;background:rgba(0,0,0,.45);padding:6px 12px;border-radius:30px;color:#fff}
.wcam .badge i{width:8px;height:8px;border-radius:50%;background:#ff5a4d;display:inline-block;animation:pulse 1.6s infinite}
.wcam .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.16);border:2px solid rgba(255,255,255,.75);display:flex;align-items:center;justify-content:center;color:#fff;font-size:19px;z-index:2}
.wcam-cap{position:absolute;left:16px;bottom:14px;z-index:2;color:#fff;font-size:12px;text-shadow:0 1px 4px rgba(0,0,0,.6)}
.wspecies h3{font-family:'Fraunces',serif;font-weight:600;font-size:20px;color:var(--heading);margin-bottom:14px}
.sgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sp{display:flex;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:11px 13px;align-items:center}
.sp-thumb{width:50px;height:50px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--forest2);font-size:20px}
.sp-info{min-width:0;flex:1}
.sp-name{font-size:14px;font-weight:600;color:var(--heading);line-height:1.15}
.sp-sci{font-style:italic;font-size:11.5px;color:var(--text-muted);margin-bottom:5px}
.sp-meta{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:6px}
.sp-count{background:#ece3cf;color:#7a5a12;font-weight:600;border-radius:20px;padding:1px 7px;font-size:10.5px}
.sp-conf{height:3px;border-radius:3px;background:#e2dac6;margin-top:6px;overflow:hidden}
.sp-conf i{display:block;height:100%;background:var(--gold)}
.wspecies .all-link{display:inline-block;margin-top:16px;color:var(--accent);font-weight:600;font-size:13.5px;background:none;border:0;cursor:pointer;font-family:inherit;padding:0}
.wspecies .all-link:hover{text-decoration:underline}
.species-all{margin-top:14px}
.species-all-grid{column-count:2;column-gap:26px;font-size:12.5px}
.al{display:flex;justify-content:space-between;gap:10px;padding:4px 0;break-inside:avoid;border-bottom:1px solid var(--border)}
.al span{color:var(--text)}
.al b{color:var(--accent);font-weight:600;white-space:nowrap}
.wl-foot{margin-top:34px;font-size:12.5px;color:var(--text-muted);border-top:1px solid var(--border);padding-top:18px}
@media(max-width:820px){
  .wprop-head{grid-template-columns:1fr}
  .wbody{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr}
  .species-all-grid{column-count:1}
}

/* ============================================================
   T10 — Our Lands interactive map (MapLibre)
   ============================================================ */
.mapph{position:relative}
.bw2-pin{width:18px;height:18px;border-radius:50% 50% 50% 0;background:var(--clay);border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.3);transform:rotate(-45deg);cursor:pointer}
.maplibregl-popup-content{font-family:'Inter',system-ui,sans-serif;border-radius:10px;padding:12px 15px;box-shadow:0 6px 20px rgba(0,0,0,.18)}
.maplibregl-popup-content b{font-family:'Fraunces',serif;color:var(--forest);font-size:15px}
.maplibregl-popup-content span{font-size:12px;color:var(--ink2)}
.maplibregl-popup-content a{color:var(--clay);font-weight:600;text-decoration:none;font-size:12.5px}

/* ============================================================
   INTERIOR SECTION LIBRARY (Purpose / What We Do / Education /
   At a Glance / Team / Technology) — vision-preview redesign
   ============================================================ */

/* Background helpers */
.bg-bg{background:var(--bg)}
.bg-alt{background:var(--bg-alt)}
.bg-band{background:var(--band-bg);color:var(--band-text)}

/* Interior masthead additions (eyebrow + subhead over photo) */
.page-hero .wrap{max-width:1120px;width:100%}
.page-hero .eyebrow{color:#f3ead2;margin-bottom:14px;text-shadow:0 1px 8px rgba(0,0,0,.6)}
.page-hero h1{max-width:18ch;line-height:1.05}
.page-hero p.sub{margin-top:18px;font-size:18px;max-width:48ch;color:#f6f3ec;text-shadow:0 1px 8px rgba(0,0,0,.6)}

/* Shared section header */
.sec-head{margin-bottom:38px;max-width:62ch}
.sec-head.al-center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head .eyebrow{color:var(--accent);margin-bottom:12px}
.sec-head h2{font-family:'Fraunces',serif;font-weight:600;font-size:34px;line-height:1.12;color:var(--heading)}
.sec-head .sec-intro{margin-top:12px;font-size:17px;color:var(--text-muted)}

/* Short accent rule under section eyebrows — gives each section a clear
   "break point" so consecutive sections sharing a background don't blend. */
.sec-head .eyebrow::after,
.lede .eyebrow::after,
.fp-text .eyebrow::after,
.team-intro .eyebrow::after{
  content:'';display:block;width:48px;height:3px;border-radius:3px;
  background:var(--accent-gold);margin-top:13px;
}
.sec-head.al-center .eyebrow::after{margin-left:auto;margin-right:auto}

/* Lede / intro prose */
.lede{padding:78px 0}
.lede .wrap{max-width:820px}
.lede.al-center{text-align:center}
.lede.al-center .wrap{margin:0 auto}
.lede .eyebrow{color:var(--accent);margin-bottom:14px}
.lede h2{font-family:'Fraunces',serif;font-weight:600;font-size:34px;line-height:1.12;color:var(--heading);margin-bottom:22px;max-width:20ch}
.lede.al-center h2{margin-left:auto;margin-right:auto}
.lede-body p{font-size:17px;line-height:1.75;color:var(--text);margin-bottom:1.05em}
.lede-body p.big{font-size:22px;line-height:1.55;color:var(--heading);font-weight:400}
.lede-body p:last-child{margin-bottom:0}

/* Card grid */
.cardsec{padding:72px 0;background:var(--bg)}
.cardsec.on-band{background:var(--band-bg);color:var(--band-text)}
.cardgrid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}
.cardgrid .card{flex:0 1 280px}
.cardgrid.cols-2 .card{flex:0 1 calc((100% - 20px)/2)}
.cardgrid.cols-3 .card{flex:0 1 calc((100% - 40px)/3)}
.cardgrid.cols-4 .card{flex:0 1 calc((100% - 60px)/4)}
.cardgrid .card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 26px;transition:transform .14s ease,box-shadow .14s ease}
.cardgrid .card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(20,30,20,.09)}
.cardgrid .card i{font-size:26px;color:var(--accent-gold);margin-bottom:14px;display:block}
.cardgrid .card h3{font-family:'Fraunces',serif;font-weight:600;font-size:20px;color:var(--heading);margin-bottom:8px;line-height:1.18}
.cardgrid .card p{font-size:14.5px;color:var(--text-muted);line-height:1.6}
.card-link{display:inline-flex;align-items:center;gap:7px;margin-top:14px;color:var(--accent);font-weight:600;font-size:13.5px;text-decoration:none}
.card-link:hover{gap:11px}
.on-band .sec-head h2,.on-band .sec-head .eyebrow{color:var(--band-text)}
.on-band .sec-head .eyebrow{color:var(--accent-gold)}
.on-band .sec-head .sec-intro{color:var(--band-muted)}
.on-band .card{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14)}
.on-band .card:hover{box-shadow:0 14px 30px rgba(0,0,0,.25)}
.on-band .card h3{color:#fff}
.on-band .card p{color:var(--band-muted)}

/* Image + text split */
.split{padding:78px 0}
.split.bg-band .eyebrow{color:var(--accent-gold)}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split.rev .split-media{order:2}
.split-media{min-height:420px;border-radius:18px;background-size:cover;background-position:center;box-shadow:0 18px 40px rgba(20,30,20,.14)}
.split-text .eyebrow{color:var(--accent);margin-bottom:12px}
.split-text h2{font-family:'Fraunces',serif;font-weight:600;font-size:32px;line-height:1.14;color:var(--heading);margin-bottom:16px}
.split.bg-band h2{color:var(--band-text)}
.split-text .rt p{font-size:16px;color:var(--text-muted);line-height:1.7;margin-bottom:1em}
.split.bg-band .rt p{color:var(--band-muted)}
.checklist{list-style:none;margin:18px 0 24px;padding:0}
.checklist li{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px;font-size:15.5px;color:var(--text)}
.split.bg-band .checklist li{color:var(--band-text)}
.checklist li i{color:var(--accent-gold);margin-top:4px;flex-shrink:0}

/* Steps / timeline */
.stepsec{padding:78px 0}
.steps{display:grid;gap:22px}
.stepsec.v-steps .steps{grid-template-columns:repeat(2,1fr)}
.stepsec.v-timeline .steps{grid-template-columns:repeat(3,1fr);gap:10px}
.step{display:flex;gap:18px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 24px}
/* Connected timeline (year markers on a line) */
.v-timeline .step{display:block;background:none;border:0;border-radius:0;padding:48px 22px 0;text-align:center;position:relative}
.v-timeline .step::before{content:'';position:absolute;top:11px;left:0;right:0;height:2px;background:var(--border)}
.v-timeline .step:first-child::before{left:50%}
.v-timeline .step:last-child::before{right:50%}
.v-timeline .step::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:16px;height:16px;border-radius:50%;background:var(--accent);border:4px solid var(--bg-alt);box-sizing:content-box;z-index:2}
.v-timeline .step-num{min-width:0;font-size:30px;text-align:center;margin-bottom:8px}
.v-timeline .step-b h3{margin-bottom:6px}
.stepsec.bg-band .step{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14)}
.step-num{font-family:'Fraunces',serif;font-weight:600;font-size:26px;color:var(--accent);line-height:1;flex-shrink:0;min-width:1.6em}
.step-b h3{font-family:'Fraunces',serif;font-weight:600;font-size:19px;color:var(--heading);margin-bottom:6px}
.step-b p{font-size:14.5px;color:var(--text-muted);line-height:1.6}
.stepsec.bg-band .step-b h3{color:#fff}
.stepsec.bg-band .step-b p{color:var(--band-muted)}

/* Featured pull-quote band */
.quoteband{position:relative;padding:92px 0;background:var(--band-bg);color:#fff;overflow:hidden;text-align:center}
.quoteband.has-img .bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.quoteband.has-img .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,24,18,.82),rgba(14,24,18,.88))}
.quoteband .wrap{position:relative;z-index:2;max-width:880px}
.quoteband .qmark{font-size:30px;color:var(--accent-gold);margin-bottom:22px;display:block}
.quoteband blockquote{font-family:'Fraunces',serif;font-weight:500;font-style:italic;font-size:29px;line-height:1.4;color:#fff;border:0;padding:0;margin:0}
.quoteband .qcite{margin-top:26px}
.quoteband .qcite b{font-family:'Inter',sans-serif;font-style:normal;font-size:15px;color:#fff;display:block}
.quoteband .qcite span{font-size:13px;color:var(--band-muted)}

/* Stat tiles (dashboard) */
.statgrid-sec{padding:72px 0;background:var(--bg)}
.statgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.stile{position:relative;overflow:hidden;border-radius:16px;border:1px solid var(--border);background:var(--surface);min-height:215px;display:flex;align-items:flex-end}
.stile-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .55s ease}
.stile:hover .stile-bg{transform:scale(1.07)}
.stile.has-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,33,24,.12) 0%,rgba(18,33,24,.5) 52%,rgba(12,24,17,.9) 100%)}
.stile-in{position:relative;z-index:2;padding:24px 22px;width:100%}
.stile i{font-size:18px;color:var(--moss);margin-bottom:10px;display:block}
.stile b{font-family:'Fraunces',serif;font-weight:600;font-size:46px;line-height:1;color:var(--accent);display:block}
.stile span{display:block;margin-top:7px;font-size:11.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--text-muted)}
.stile.has-img i{color:#f2d089}
.stile.has-img b{color:#fff}
.stile.has-img span{color:rgba(255,255,255,.88)}

/* CTA band */
.ctaband{padding:74px 0;text-align:center;color:var(--band-text)}
.ctaband.bg-band{background:var(--band-bg)}
.ctaband.bg-band2{background:var(--band-bg-2)}
.ctaband.bg-clay{background:var(--clay)}
.ctaband .eyebrow{color:var(--accent-gold);margin-bottom:14px}
.ctaband h2{font-family:'Fraunces',serif;font-weight:600;font-size:34px;color:var(--band-text);margin-bottom:14px}
.ctaband p{font-size:16px;color:var(--band-muted);max-width:50ch;margin:0 auto 26px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Related cross-links */
.related{padding:64px 0 84px;background:var(--bg)}
.related .eyebrow{color:var(--accent);text-align:center;margin-bottom:24px}
.rel-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}
.rel-card{display:block;flex:0 1 calc((100% - 40px)/3);background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 26px;text-decoration:none;transition:transform .14s ease,box-shadow .14s ease}
.rel-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(20,30,20,.09)}
.rel-card i{font-size:26px;color:var(--accent-gold);display:block;margin-bottom:14px}
.rel-label{display:block;font-size:20px;color:var(--heading);margin-bottom:8px;line-height:1.18;transition:color .14s ease}
.rel-desc{display:block;font-size:14.5px;color:var(--text-muted);line-height:1.6}
.rel-card:hover .rel-label{color:var(--accent)}

/* Newsletter / email capture (sitewide pre-footer) */
.signup{background:var(--bg-alt);padding:56px 0;border-top:1px solid var(--border)}
.signup .wrap{display:flex;align-items:center;justify-content:space-between;gap:34px;flex-wrap:wrap}
.signup-copy{flex:1;min-width:280px}
.signup-copy .eyebrow{color:var(--accent);margin-bottom:10px}
.signup-copy h2{font-family:'Fraunces',serif;font-weight:600;font-size:28px;color:var(--heading);margin-bottom:8px}
.signup-copy p{font-size:14.5px;color:var(--text-muted);max-width:46ch}
.signup-form{display:flex;gap:10px;flex-wrap:wrap}
.signup-form input{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:30px;padding:13px 20px;font-family:inherit;font-size:14.5px;min-width:240px}
.signup-form input:focus{outline:2px solid var(--accent);outline-offset:1px}

/* WHAT WE DO — the Broad Water advantage */
.advantage{padding:78px 0;background:var(--bg-alt)}
.adv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.adv-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:36px 32px}
.adv-big{font-family:'Fraunces',serif;font-weight:600;font-size:58px;line-height:1;color:var(--accent);margin-bottom:14px}
.adv-card h3{font-family:'Fraunces',serif;font-weight:600;font-size:23px;color:var(--heading);margin-bottom:12px}
.adv-card p{font-size:15px;color:var(--text-muted);line-height:1.65}

/* EDUCATION — scholarship callout */
.scholarship{padding:24px 0 78px;background:var(--bg)}
.sch-card{display:flex;align-items:center;gap:28px;background:var(--band-bg-2);color:var(--band-text);border-radius:20px;padding:40px 40px;flex-wrap:wrap}
.sch-icon{font-size:42px;color:var(--accent-gold);flex-shrink:0}
.sch-body{flex:1;min-width:260px}
.sch-body .eyebrow{color:var(--accent-gold);margin-bottom:10px}
.sch-body h2{font-family:'Fraunces',serif;font-weight:600;font-size:28px;color:#fff;margin-bottom:8px}
.sch-body p{font-size:15.5px;color:var(--band-muted);margin-bottom:14px}
.sch-meta{display:flex;gap:22px;flex-wrap:wrap;font-size:13.5px;color:var(--band-text)}
.sch-meta i{color:var(--accent-gold);margin-right:6px}
.sch-cta{flex-shrink:0}

/* AT A GLANCE — nine-state footprint */
.footprint{padding:24px 0 78px;background:var(--bg)}
.footprint-grid{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.fp-text .eyebrow{color:var(--accent);margin-bottom:12px}
.fp-text h2{font-family:'Fraunces',serif;font-weight:600;font-size:32px;color:var(--heading);margin-bottom:14px}
.fp-text p{font-size:16px;color:var(--text-muted);line-height:1.7;margin-bottom:18px}
.fp-map{position:relative;height:340px;border-radius:18px;background:radial-gradient(120% 120% at 30% 20%,#dfe9d8 0%,#cdddc4 45%,#bccfb1 100%);border:1px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center}
html[data-theme="forest"] .fp-map{background:radial-gradient(120% 120% at 30% 20%,#21402e 0%,#1b3326 100%)}
.fp-map-inner{text-align:center;color:var(--forest)}
html[data-theme="forest"] .fp-map-inner{color:var(--band-muted)}
.fp-map-inner i{font-size:40px;color:var(--clay);display:block;margin-bottom:14px}
.fp-map-inner b{font-family:'Fraunces',serif;font-size:20px;display:block}
.fp-map-inner span{font-size:12.5px;opacity:.8}

/* TEAM */
.team{padding:78px 0}
.team-intro{margin-bottom:32px}
.team-intro .eyebrow{color:var(--accent);margin-bottom:10px}
.team-intro h2{font-family:'Fraunces',serif;font-weight:600;font-size:32px;color:var(--heading)}
.tm-feature{display:grid;grid-template-columns:300px 1fr;gap:36px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:34px;margin-bottom:26px}
.tm-feature-photo{width:100%;aspect-ratio:1;border-radius:16px;background-size:cover;background-position:center}
.tm-feature-body h3{font-family:'Fraunces',serif;font-weight:600;font-size:28px;color:var(--heading)}
.tm-role{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600;margin:6px 0 16px}
.tm-feature-body p{font-size:15.5px;color:var(--text-muted);line-height:1.7;margin-bottom:18px}
.tm-contact{display:flex;gap:22px;flex-wrap:wrap}
.tm-contact a{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--accent);text-decoration:none;font-weight:500}
.tm-contact a:hover{text-decoration:underline}
.tm-contact i{color:var(--moss)}
.tm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.tm-card{display:flex;gap:22px;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:26px;align-items:flex-start}
.tm-photo{width:96px;height:96px;border-radius:14px;background-size:cover;background-position:center;flex-shrink:0}
.tm-mono{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--forest2),var(--moss))}
.tm-mono span{font-family:'Fraunces',serif;font-weight:600;font-size:30px;color:#fff}
.tm-card-b h3{font-family:'Fraunces',serif;font-weight:600;font-size:21px;color:var(--heading)}
.tm-card-b p{font-size:14px;color:var(--text-muted);line-height:1.6;margin:0 0 14px}
.team-affil{margin-top:28px;font-size:13.5px;color:var(--text-muted);display:flex;align-items:center;gap:10px;border-top:1px solid var(--border);padding-top:20px}
.team-affil i{color:var(--accent-gold)}

/* CONTACT */
.contact-sec{padding:78px 0}
.contact-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:44px;align-items:start}
.contact-main > .eyebrow{color:var(--accent);margin-bottom:12px}
.contact-main > .eyebrow::after{content:'';display:block;width:48px;height:3px;border-radius:3px;background:var(--accent-gold);margin-top:13px}
.contact-main > h2{font-family:'Fraunces',serif;font-weight:600;font-size:30px;color:var(--heading);margin-bottom:24px}
.cf-msg{display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:12px;margin-bottom:22px;font-size:14.5px}
.cf-msg.ok{background:#e7f0e3;color:#2c5239;border:1px solid #bcd3b3}
.cf-msg.err{background:#f6e7df;color:#9a3b22;border:1px solid #e4c3b0}
html[data-theme="forest"] .cf-msg.ok{background:rgba(92,122,94,.22);color:#cfe0cf;border-color:rgba(255,255,255,.18)}
.contact-form .cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form label{display:block;font-size:13px;font-weight:600;color:var(--heading);margin-bottom:16px}
.contact-form label span{color:var(--accent)}
.contact-form input,.contact-form textarea{display:block;width:100%;margin-top:7px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:10px;padding:12px 14px;font-family:inherit;font-size:15px}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.contact-form textarea{resize:vertical}
.contact-form .hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.contact-form button{margin-top:4px;border:0;cursor:pointer;font-size:14px}
.contact-aside{background:var(--bg-alt);border:1px solid var(--border);border-radius:18px;padding:32px}
.contact-aside .ca-intro{font-size:15px;color:var(--text-muted);line-height:1.65;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.ca-person{margin-bottom:22px}
.ca-person .ca-name{font-family:'Fraunces',serif;font-weight:600;font-size:19px;color:var(--heading)}
.ca-person .ca-role{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:600;margin:3px 0 12px}
.ca-person a,.ca-person .ca-loc{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--text);text-decoration:none;margin-bottom:8px}
.ca-person a:hover{color:var(--accent)}
.ca-person i{color:var(--moss);width:16px;text-align:center}
@media(max-width:820px){
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .contact-form .cf-row{grid-template-columns:1fr}
}

/* TECHNOLOGY — live feed */
.livecam-sec{padding:24px 0 78px;background:var(--bg)}
.livecam-sec .wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:stretch}
.livecam{position:relative;border-radius:18px;overflow:hidden;min-height:380px;background-size:cover;background-position:center}
.livecam::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,14,10,.25) 0%,rgba(8,14,10,0) 45%,rgba(8,14,10,.7) 100%)}
.livecam .badge{position:absolute;top:16px;left:16px;z-index:2;display:flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:rgba(0,0,0,.5);padding:7px 13px;border-radius:30px;color:#fff}
.livecam .badge i{width:8px;height:8px;border-radius:50%;background:#ff5a4d;display:inline-block;animation:pulse 1.6s infinite}
.livecam .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:rgba(255,255,255,.16);border:2px solid rgba(255,255,255,.78);display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;z-index:2;text-decoration:none}
.livecam .play:hover{background:rgba(255,255,255,.28)}
.livecam-cap{position:absolute;left:18px;bottom:16px;z-index:2;color:#fff;text-shadow:0 1px 5px rgba(0,0,0,.6)}
.livecam-cap b{font-family:'Fraunces',serif;font-size:17px;display:block}
.livecam-cap span{font-size:12.5px;opacity:.9}
.livecam-side{display:flex;flex-direction:column;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:30px}
.livecam-side .eyebrow{color:var(--accent);margin-bottom:14px}
.species-strip{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:22px}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--heading);background:var(--bg-alt);border:1px solid var(--border);border-radius:30px;padding:7px 13px}
.chip i{color:var(--accent-gold);font-size:11px}
.livecam-side .btn{align-self:flex-start}
.livecam-note{margin-top:14px;font-size:11.5px;color:var(--text-muted)}

/* ---- Responsive ---- */
@media(max-width:900px){
  .cardgrid.cols-4 .card{flex-basis:calc((100% - 20px)/2)}
  .stepsec.v-timeline .steps{grid-template-columns:1fr;gap:0}
  .v-timeline .step{padding:20px 0;text-align:left;border-top:1px solid var(--border)}
  .v-timeline .step::before,.v-timeline .step::after{display:none}
  .v-timeline .step-num{text-align:left}
}
@media(max-width:820px){
  .cardgrid.cols-2 .card,.cardgrid.cols-3 .card,.cardgrid.cols-4 .card,.rel-card{flex-basis:100%}
  .split-grid{grid-template-columns:1fr;gap:28px}
  .split.rev .split-media{order:0}
  .split-media{min-height:260px}
  .stepsec.v-steps .steps{grid-template-columns:1fr}
  .statgrid{grid-template-columns:repeat(2,1fr)}
  .quoteband blockquote{font-size:23px}
  .adv-grid{grid-template-columns:1fr}
  .footprint-grid{grid-template-columns:1fr;gap:24px}
  .tm-feature{grid-template-columns:1fr;text-align:center}
  .tm-feature-photo{max-width:220px;margin:0 auto}
  .tm-feature .tm-contact{justify-content:center}
  .tm-grid{grid-template-columns:1fr}
  .livecam-sec .wrap{grid-template-columns:1fr}
  .sch-card{flex-direction:column;text-align:center}
  .sch-meta{justify-content:center}
  .signup .wrap{flex-direction:column;align-items:flex-start}
  .lede-body p.big{font-size:19px}
}
@media(max-width:600px){
  .lede,.cardsec,.stepsec,.split,.statgrid-sec,.advantage,.footprint,.scholarship,.team,.contact-sec,.related{padding-top:54px;padding-bottom:54px}
  .quoteband,.ctaband{padding-top:62px;padding-bottom:62px}
  .sec-head{margin-bottom:26px}
  .sec-head h2,.lede h2,.split-text h2,.fp-text h2,.ctaband h2,.team-intro h2,.contact-main > h2{font-size:26px}
  .stile b{font-size:40px}
  .impact .nums{gap:18px 34px}
  .wrap{padding:0 18px}
}
