@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;1,9..144,300;1,9..144,400&family=Hanken+Grotesk:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

/* =================================================================
   A SAY IN OUR SKIES — unified stylesheet (one palette, whole site)
   Spirit: calm landscape-architecture editorial (after OKRA).
   ================================================================= */
:root{
  --bone:#f1ece1; --bone-2:#e8e1d2; --bone-3:#ddd4c2;
  --ink:#23292b; --ink-soft:#5e6663; --ink-faint:#676b62;
  --sky:#6f8ba0; --sky-pale:#a9bcc6;
  --leaf:#6f8a63; --leaf-deep:#4d6044; --leaf-dark:#384b32;
  --sand:#c9b896; --rule:#d8d1c2; --white:#fbf9f4;
  --accent:#4d6044;            /* single accent = leaf-deep */
  --display:"Fraunces",Georgia,serif;
  --sans:"Hanken Grotesk","Carlito","Segoe UI","Helvetica Neue",Arial,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --maxw:1180px; --radius:3px;
  --shadow:0 1px 0 rgba(0,0,0,.03), 0 22px 48px -30px rgba(40,40,25,.4);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{background:var(--bone);color:var(--ink);font-family:var(--sans);font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased;padding-bottom:0}
img{max-width:100%;display:block}
a{color:inherit}
.container,.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,64px)}
.text-center{text-align:center}
.mt-2{margin-top:2rem}
.label{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint)}
.lead{font-family:var(--display);font-weight:300;font-size:clamp(20px,2.6vw,28px);line-height:1.4;color:var(--ink)}
.fine-print{font-size:13.5px;color:var(--ink-faint);line-height:1.5}

/* ---------- header / nav ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(241,236,225,.9);backdrop-filter:saturate(1.1) blur(8px);border-bottom:1px solid var(--rule)}
.site-header .nav{max-width:var(--maxw);margin:0 auto;padding:16px clamp(20px,5vw,64px);display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{font-family:var(--display);font-weight:500;font-size:21px;line-height:1.05;letter-spacing:.005em;text-decoration:none;color:var(--ink)}
.brand span{display:block;font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-top:3px}
.nav-links{display:flex;gap:clamp(15px,1.7vw,26px);align-items:center}
.nav-links a{font-size:14px;letter-spacing:.01em;color:var(--ink-soft);text-decoration:none;padding:4px 0;white-space:nowrap}
.nav-links a:hover{color:var(--ink)}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);width:42px;height:42px;cursor:pointer}
.nav-toggle .icon-close{display:none}
.nav-toggle svg{width:24px;height:24px}
@media(max-width:1024px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .nav-links{position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;background:var(--bone);border-bottom:1px solid var(--rule);padding:8px 0;transform:translateY(-12px);opacity:0;pointer-events:none;transition:.2s}
  .nav-links a{padding:15px clamp(20px,5vw,64px);width:100%;border-top:1px solid var(--rule);font-size:16px}
  .site-header.open .nav-links{transform:none;opacity:1;pointer-events:auto}
  .site-header.open .nav-toggle .icon-hamburger{display:none}
  .site-header.open .nav-toggle .icon-close{display:block}
}

/* ---------- notice / urgent strip ---------- */
.notice-strip,.urgent-strip{background:var(--leaf-dark);color:var(--bone);text-align:center;font-size:14.5px;padding:.7rem 0}
.notice-strip .container,.urgent-strip .container{display:block}
.notice-strip a,.urgent-strip a{color:#cfe0c5;font-weight:600;text-underline-offset:3px}

/* ---------- hero (light, masthead style) ---------- */
.hero{background:var(--bone);padding:clamp(40px,7vw,86px) 0 clamp(28px,4vw,44px)}
.hero .container,.hero-text{max-width:980px}
.hero-tag,.loc-tag{display:inline-block;font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--leaf-deep);margin-bottom:18px}
.hero h1{font-family:var(--display);font-weight:300;font-size:clamp(38px,7vw,82px);line-height:1.03;letter-spacing:-.015em;color:var(--ink);text-transform:none;text-wrap:balance}
.hero h1 em{font-style:italic;color:var(--leaf-deep)}
.hero-lead{font-family:var(--display);font-weight:300;font-size:clamp(19px,2.4vw,27px);line-height:1.42;color:var(--ink-soft);margin-top:22px;max-width:42em}
.hero-text{text-align:left}

/* ---------- buttons + CTAs (clear hierarchy) ---------- */
.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.btn-row--center,.btn-row.center{justify-content:flex-start}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 30px;border-radius:var(--radius);
  font-family:var(--sans);font-size:15px;font-weight:700;letter-spacing:.01em;text-transform:none;text-decoration:none;
  background:var(--ink);color:var(--bone);border:1px solid var(--ink);transition:.15s;cursor:pointer}
.btn:hover{background:var(--leaf-deep);border-color:var(--leaf-deep)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--rule)}
.btn-outline:hover{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-navy{background:var(--leaf-deep);border-color:var(--leaf-deep);color:var(--bone)}
.btn-navy:hover{background:var(--leaf-dark);border-color:var(--leaf-dark)}
.section-navy .btn-outline,.section-green .btn-outline{color:var(--bone);border-color:rgba(255,255,255,.55)}
.section-navy .btn-outline:hover,.section-green .btn-outline:hover{border-color:#fff;color:#fff;background:transparent}

.btn-primary{box-shadow:0 8px 22px -10px rgba(45,55,40,.6)}
.link{display:inline-block;margin-top:22px;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--leaf);padding-bottom:5px}
.link:hover{border-color:var(--ink)}

/* ---------- sections ---------- */
section{scroll-margin-top:80px}
.section-cream{background:var(--bone);padding:clamp(48px,7vw,104px) 0}
.section-navy{background:var(--ink);color:var(--bone);padding:clamp(48px,7vw,104px) 0}
.section-green{background:var(--leaf-deep);color:var(--bone);padding:clamp(48px,7vw,104px) 0}
.section-navy a:not(.btn),.section-green a:not(.btn){color:var(--sky-pale)}
.section-navy .lead,.section-green .lead{color:var(--bone)}
.section-green a:not(.btn){color:#cfe0e8}
.section-title{font-family:var(--display);font-weight:300;font-size:clamp(27px,4.2vw,46px);line-height:1.1;letter-spacing:-.015em;text-transform:none;text-align:center;margin-bottom:34px}
.section-title em{font-style:italic;color:var(--leaf-deep)}
.section-navy .section-title em,.section-green .section-title em{color:var(--sky-pale)}

/* ---------- cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden}
.cards-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.cards-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cards-3{grid-template-columns:1fr}}
.card{background:var(--bone);padding:26px 24px 30px}
.section-navy .cards,.section-green .cards{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.16)}
.section-navy .card{background:var(--ink)}
.section-green .card{background:var(--leaf-deep)}
.card h3{font-family:var(--display);font-weight:500;font-size:20px;letter-spacing:-.01em;margin-bottom:9px;text-transform:none}
.card p{font-size:15.5px;line-height:1.6;color:var(--ink-soft)}
.section-navy .card p,.section-green .card p{color:#d7ddd2}
.card-icon{display:none}

/* ---------- callout ---------- */
.callout{background:var(--white);border:1px solid var(--rule);border-left:3px solid var(--leaf);border-radius:var(--radius);padding:clamp(22px,3vw,34px);max-width:880px;margin:0 auto;box-shadow:var(--shadow)}
.callout h3{font-family:var(--display);font-weight:500;font-size:clamp(20px,2.4vw,26px);margin-bottom:12px}
.callout p{color:var(--ink-soft)}

/* ---------- stamp (flat, calm) ---------- */
.stamp{display:inline-block;font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(16px,2vw,20px);color:var(--ink);
  border:1px solid var(--rule);border-radius:var(--radius);padding:12px 22px;transform:none;text-transform:none;letter-spacing:0;background:var(--white)}

/* ---------- exposure / cumulative visual ---------- */
.exposure{display:flex;align-items:stretch;justify-content:center;gap:.75rem;flex-wrap:wrap;max-width:840px;margin:0 auto}
.exposure-step{background:var(--white);border-top:3px solid var(--leaf);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.4rem 1.2rem;min-width:170px;flex:1 1 170px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.exposure-num{font-family:var(--display);font-weight:300;font-size:2.6rem;line-height:1;color:var(--ink)}
.exposure-lab{font-size:.95rem;color:var(--ink-soft);margin-top:.4rem}
.exposure-arrow{display:flex;align-items:center;font-size:1.7rem;color:var(--leaf);font-weight:400}
@media(max-width:620px){.exposure{flex-direction:column}.exposure-arrow{transform:rotate(90deg);justify-content:center}.exposure-step{width:100%}}

/* ---------- stats band (OKRA) ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,4vw,46px);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:clamp(34px,5vw,54px) 0}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr;gap:32px 22px}}
.stat .n{font-family:var(--display);font-weight:300;font-size:clamp(38px,5.2vw,62px);line-height:.95;letter-spacing:-.02em;color:var(--ink)}
.stat .n small{font-size:.5em;font-weight:400}
.stat .k{margin-top:11px;font-size:13.5px;line-height:1.5;color:var(--ink-soft);max-width:18em}

/* ---------- narrative sec (image/text) ---------- */
.sec{display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(28px,6vw,76px);align-items:center;padding:clamp(54px,8vw,116px) 0}
@media(max-width:820px){.sec{grid-template-columns:1fr;gap:28px}}
.sec.reverse .text{order:2}
@media(max-width:820px){.sec.reverse .text{order:0}}
.sec h2{font-family:var(--display);font-weight:300;font-size:clamp(27px,4.2vw,46px);line-height:1.08;letter-spacing:-.015em;margin:13px 0 20px}
.sec h2 em{font-style:italic;color:var(--leaf-deep)}
.sec p{font-size:17px;line-height:1.7;color:var(--ink-soft);max-width:34em}
.sec p+p{margin-top:1em}
.sec .art{border-radius:var(--radius);overflow:hidden}
.sec .art svg{display:block;width:100%;height:auto}

/* ---------- asks grid ---------- */
.askgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden}
@media(max-width:760px){.askgrid{grid-template-columns:1fr}}
.ask{background:var(--bone);padding:26px 24px 30px}
.ask .i{font-family:var(--display);font-style:italic;color:var(--leaf);font-size:22px}
.ask h3{font-family:var(--display);font-weight:500;font-size:19px;margin:6px 0 8px;color:var(--ink)}
.ask p{font-size:15px;line-height:1.6;color:var(--ink-soft)}

/* ---------- CTA block ---------- */
.cta{text-align:center;padding:clamp(60px,10vw,140px) 0}
.cta .big{font-family:var(--display);font-weight:300;font-style:italic;font-size:clamp(25px,4.4vw,50px);line-height:1.2;letter-spacing:-.01em;max-width:16em;margin:0 auto 34px}

/* ---------- image placeholder + art-direction RIDER ---------- */
.ph{position:relative;background:var(--bone-2);border:1px dashed #c6bca6;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;min-height:clamp(220px,38vw,440px);overflow:hidden}
.ph.tall{min-height:clamp(300px,52vw,560px)}
.ph::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent 0 20px,rgba(70,60,40,.018) 20px 40px)}
.ph .rider{position:relative;max-width:38em;padding:clamp(18px,3vw,30px);text-align:center}
.ph .rider .tag{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:var(--leaf-deep);padding:4px 9px;border-radius:2px;margin-bottom:14px}
.ph .rider .desc{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(16px,2vw,21px);line-height:1.4;color:var(--ink)}
.ph .rider .spec{margin-top:10px;font-family:var(--mono);font-size:11px;line-height:1.6;color:var(--ink-soft);letter-spacing:.01em}
.scene-cap{margin-top:12px;font-size:12.5px;color:var(--ink-faint)}
.hero-media{display:block;width:100%;height:auto;border-radius:var(--radius);max-height:78vh;object-fit:cover}
.sec .art img{display:block;width:100%;height:auto;border-radius:var(--radius)}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#cdd2cb;padding:clamp(44px,6vw,72px) 0 96px}
.site-footer .tagline{font-family:var(--display);font-weight:300;font-size:clamp(20px,2.6vw,30px);color:var(--bone);text-transform:none;letter-spacing:-.01em;margin-bottom:6px;max-width:20em}
.site-footer p{font-size:14px;line-height:1.7;color:#aab0a8}
.site-footer a{color:#cfe0c5;text-decoration:underline;text-underline-offset:3px}

/* ---------- sticky mobile CTA (prioritised primary) ---------- */
.mobile-cta{display:none}
@media(max-width:820px){
  body{padding-bottom:78px}
  .mobile-cta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;gap:0;background:var(--bone);border-top:1px solid var(--rule);padding:10px 14px;box-shadow:0 -8px 24px -16px rgba(0,0,0,.5)}
  .mobile-cta a{flex:1;display:flex;align-items:center;justify-content:center;min-height:52px;background:var(--ink);color:var(--bone);
    text-decoration:none;font-weight:700;font-size:16px;letter-spacing:.01em;border-radius:var(--radius);text-transform:none}
  .mobile-cta a:active{background:var(--leaf-deep)}
}

/* ---------- legacy template helpers (kept consistent) ---------- */
.letter-box{background:var(--white);border:1px solid var(--rule);border-radius:var(--radius);padding:clamp(18px,2.5vw,28px);font-family:var(--mono);font-size:13.5px;line-height:1.7;color:var(--ink);white-space:pre-wrap;max-width:820px;margin:0 auto}
.action-step{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;padding:18px 0;border-top:1px solid var(--rule)}
.action-step .num{font-family:var(--display);font-style:italic;font-size:26px;color:var(--leaf)}
.copy-feedback{display:inline-block;margin-left:10px;font-size:13px;color:var(--leaf-deep);font-weight:600}

/* =================================================================
   EDITORIAL EXPLAINERS (noise / visibility / wildlife) — same palette
   Scoped under .sheet so they don't clash with site headings.
   ================================================================= */
.sheet{max-width:940px;margin:clamp(20px,4vw,48px) auto;background:var(--white);padding:clamp(28px,5vw,64px);border:1px solid var(--rule);border-radius:var(--radius);box-shadow:var(--shadow)}
.sheet .mono{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.sheet .runhead{display:flex;justify-content:space-between;gap:16px;align-items:center;color:var(--ink-soft);flex-wrap:wrap}
.sheet .runhead .dot{width:7px;height:7px;border-radius:50%;background:var(--leaf-deep);display:inline-block;margin-right:9px;vertical-align:middle}
.sheet .hr{height:1px;background:var(--rule);border:0;margin:16px 0 34px}
.sheet .hr.tight{margin:30px 0}
.sheet h1{font-family:var(--display);font-weight:300;font-size:clamp(34px,6.4vw,60px);line-height:1.03;letter-spacing:-.015em;margin-bottom:22px;text-transform:none;text-wrap:balance}
.sheet h1 em{font-style:italic;color:var(--leaf-deep)}
.sheet .standfirst{font-size:clamp(17px,2.1vw,21px);line-height:1.5;color:var(--ink-soft);max-width:48em;font-style:italic;font-family:var(--display);font-weight:300}
.sheet .standfirst em{color:var(--leaf-deep);font-style:normal;font-weight:500}
.sheet .secmark{display:flex;align-items:baseline;gap:16px;margin:38px 0 14px}
.sheet .secmark .n{font-family:var(--display);font-style:italic;color:var(--leaf);font-size:30px;line-height:1}
.sheet .secmark h2{font-family:var(--display);font-weight:400;font-size:clamp(21px,3.3vw,29px);letter-spacing:-.01em;text-transform:none}
.sheet .secmark h2 em{font-style:italic;color:var(--leaf-deep)}
.sheet p.body{max-width:50em;margin-left:46px;font-size:17.5px;color:var(--ink-soft);line-height:1.7}
.sheet p.body em{color:var(--leaf-deep);font-style:italic}
.sheet p.body+p.body{margin-top:12px}
@media(max-width:560px){.sheet p.body{margin-left:0}}
.sheet .figlabel{display:flex;align-items:center;gap:12px;color:var(--leaf-deep);margin:38px 0 14px}
.sheet .figlabel::before{content:"";height:1px;background:var(--rule);flex:0 0 22px}
.sheet .figlabel::after{content:"";height:1px;background:var(--rule);flex:1}
.sheet figure{margin:0}
.sheet figcaption{font-size:13.5px;color:var(--ink-faint);line-height:1.45;margin-top:12px;max-width:54em}
.sheet figcaption b{color:var(--ink-soft);font-weight:600}
.sheet .panel{background:var(--ink);border-radius:var(--radius);padding:clamp(22px,4vw,32px);color:#cdd2cb}
.sheet .panel .note{font-size:14px;line-height:1.5;color:#b3bab2;margin-top:6px}
.sheet .panel .note em{color:var(--sky-pale);font-style:normal;font-weight:500}
.moonfig{display:grid;grid-template-columns:340px 1fr;gap:clamp(18px,4vw,38px);align-items:center}
.moonfig svg{width:100%;height:auto;display:block}
@media(max-width:720px){.moonfig{grid-template-columns:1fr}}
.mtable{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:12px;color:#cdd2cb}
.mtable caption{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:#9aa39a;text-align:left;padding-bottom:10px}
.mtable th{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:#9aa39a;font-weight:400;text-align:right;padding:0 0 8px}
.mtable th:first-child{text-align:left}
.mtable td{padding:5.5px 0;border-top:1px solid rgba(255,255,255,.09);text-align:right}
.mtable td:first-child{text-align:left;color:#e7e0cf}
.mtable tr.moonrow td{color:var(--sky-pale);border-top:1px dashed rgba(169,188,198,.5)}
.mtable tr.band td{color:#dbe7c9}
.barrow{display:grid;grid-template-columns:120px 1fr;gap:16px;align-items:center;margin:0 0 16px}
.barrow .bk{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#cdd2cb;text-align:right;line-height:1.4}
.bar{height:30px;border-radius:var(--radius);display:flex;align-items:center;padding-left:12px;font-family:var(--mono);font-size:11px;color:#fff}
.bar.lo{background:var(--leaf);width:88%}
.bar.hi{background:#37432f;width:24%;color:#cdd2cb}
.lawlist{list-style:none;margin:0 0 0 46px;max-width:52em}
@media(max-width:560px){.lawlist{margin-left:0}}
.lawlist li{border-top:1px solid var(--rule);padding:13px 0;display:grid;grid-template-columns:26px 1fr;gap:12px}
.lawlist li:first-child{border-top:0}
.lawlist .mk{font-family:var(--display);font-style:italic;color:var(--leaf);font-size:20px;line-height:1.2}
.lawlist .lt{font-weight:600}
.lawlist .ld{color:var(--ink-soft);font-size:15px;line-height:1.5}
.sheet .sources{margin:8px 0 0 46px;font-family:var(--mono);font-size:11px;line-height:1.7;color:var(--ink-faint);max-width:50em}
@media(max-width:560px){.sheet .sources{margin-left:0}}
.sheet .sources b{color:var(--ink-soft);font-weight:600}
.sheet .pull{font-family:var(--display);font-size:clamp(20px,3vw,26px);font-style:italic;font-weight:300;line-height:1.35;color:var(--ink);max-width:30em;margin:30px auto;text-align:center}
.sheet .foot{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:8px}
@media(max-width:640px){.sheet .foot{grid-template-columns:1fr}}
.sheet .foot .col .h{color:var(--leaf-deep);margin-bottom:9px}
.sheet .foot .col p{font-family:var(--mono);font-size:11px;line-height:1.7;color:var(--ink-soft)}
.reveal{opacity:0;transform:translateY(14px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){.reveal{animation:none;opacity:1;transform:none}}


/* ---- Video module (homepage "See it. Hear it.") ---- */
.vid-section .vid-lead{max-width:760px;color:var(--ink-soft);font-size:1.05rem;line-height:1.6;margin:.4rem 0 1.7rem}
.vid-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media(max-width:760px){.vid-grid{grid-template-columns:1fr}}
.vid{margin:0}
.vid-frame{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;border:1px solid var(--rule);background-color:var(--ink);background-size:cover;background-position:center}
.vid-frame video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#000;display:block}
.vid-soon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:1.1rem;color:#f1ece1;font-size:.92rem;line-height:1.5;background:linear-gradient(0deg,rgba(20,26,28,.62),rgba(20,26,28,.42))}
.vid-soon code{background:rgba(255,255,255,.18);padding:.12em .45em;border-radius:4px;font-size:.86em;font-family:var(--mono)}
.vid figcaption{margin-top:.55rem;color:var(--ink-soft);font-size:.95rem}
.vid-credit{margin-top:1.4rem;color:var(--ink-faint);font-size:.85rem;line-height:1.55;max-width:780px}
.vid-credit a{color:var(--leaf-deep)}


/* ---- Further reading list ---- */
.reading{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:1040px;margin:0 auto}
@media(max-width:820px){.reading{grid-template-columns:1fr;gap:26px}}
.rgroup .label{display:block;margin-bottom:6px}
.rlink{display:block;padding:12px 0;border-top:1px solid var(--rule);text-decoration:none;color:var(--ink)}
.rlink:first-of-type{border-top:none}
.rlink b{display:block;font-weight:500;font-size:15px;line-height:1.4}
.rlink span{display:block;font-family:var(--mono);font-size:11px;color:var(--ink-faint);margin-top:3px;letter-spacing:.04em}
.rlink:hover b{text-decoration:underline;text-underline-offset:3px}


/* =================================================================
   REGION CHOOSER — first-touch geography (self-selected, remembered)
   ================================================================= */
.region-choose{padding:clamp(40px,6vw,80px) 0}
.region-intro{max-width:760px;margin:0 auto 34px;text-align:center}
.region-intro .label{display:block;margin-bottom:14px;color:var(--leaf-deep)}
.region-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden;max-width:1040px;margin:0 auto}
@media(max-width:760px){.region-grid{grid-template-columns:1fr}}
.region-card{background:var(--white);padding:30px 26px 28px;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;gap:8px;transition:background .15s,box-shadow .15s;position:relative;cursor:pointer}
.region-card:hover{background:var(--bone)}
.region-card:hover,.region-card:focus-visible{box-shadow:inset 0 0 0 2px var(--leaf-deep);z-index:1}
.region-card:focus-visible{outline:none}
.region-card .rc-place{font-family:var(--display);font-weight:500;font-size:24px;letter-spacing:-.01em;line-height:1.1}
.region-card .rc-sub{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--leaf-deep)}
.region-card .rc-desc{font-size:15px;line-height:1.55;color:var(--ink-soft);margin-top:2px}
.region-card .rc-go{margin-top:auto;padding-top:14px;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:7px}
.region-card .rc-go::after{content:"\2192";transition:transform .15s}
.region-card:hover .rc-go::after{transform:translateX(4px)}
.region-card[data-current="true"]::before{content:"Your area";position:absolute;top:14px;right:14px;font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--leaf-deep);padding:3px 8px;border-radius:2px}

/* Return-visit shortcut strip */
.region-resume{display:none;background:var(--white);border:1px solid var(--rule);border-left:3px solid var(--leaf);border-radius:var(--radius);padding:16px 22px;max-width:760px;margin:0 auto 28px;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;box-shadow:var(--shadow)}
.region-resume.show{display:flex}
.region-resume .rr-text{font-size:15.5px;color:var(--ink-soft)}
.region-resume .rr-text b{color:var(--ink);font-weight:600}
.region-resume .rr-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.region-resume .rr-change{font-size:14px}

/* Region indicator pill in header */
.region-pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);font-size:12.5px;font-weight:600;letter-spacing:.02em;color:var(--ink-soft);text-decoration:none;border:1px solid var(--rule);border-radius:999px;padding:5px 12px;transition:.15s;white-space:nowrap}
.region-pill:hover{border-color:var(--ink);color:var(--ink)}
.region-pill svg{width:13px;height:13px}
.region-pill[hidden]{display:none}

/* "What's happening now" timeline on region pages */
.timeline{max-width:760px;margin:0 auto;border-left:2px solid var(--rule);padding-left:0}
.tl-item{position:relative;padding:0 0 30px 30px}
.tl-item::before{content:"";position:absolute;left:-7px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--leaf-deep);border:2px solid var(--bone)}
.tl-item:last-child{padding-bottom:0}
.tl-date{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--leaf-deep)}
.tl-item h3{font-family:var(--display);font-weight:500;font-size:20px;letter-spacing:-.01em;margin:5px 0 7px}
.tl-item p{font-size:15.5px;line-height:1.6;color:var(--ink-soft);max-width:40em}
.tl-item.live .tl-date{color:#a4442f}
.tl-item.live::before{background:#a4442f}

/* Priority-action banner on region pages */
.priority{background:var(--leaf-deep);color:var(--bone);border-radius:var(--radius);padding:clamp(24px,4vw,40px);max-width:880px;margin:0 auto;box-shadow:var(--shadow)}
.priority .label{color:#cfe0c5}
.priority h3{font-family:var(--display);font-weight:400;font-size:clamp(22px,3vw,30px);line-height:1.15;margin:10px 0 10px;color:#fff}
.priority p{color:#dbe7d4;font-size:16px;line-height:1.6;max-width:46em;margin-bottom:20px}
.hero-pick + .btn-row{margin-top:12px}


/* =================================================================
   MOBILE HARDENING — high-priority fixes for the 99%-mobile audience
   ================================================================= */

/* Global safety net: nothing should ever force horizontal scroll */
html,body{overflow-x:hidden}
.letter-box,.sheet,.card,.region-card,.callout{overflow-wrap:anywhere;word-break:break-word}

/* (3) Letter / objection templates: guarantee long tokens (URLs, emails,
   reference lines) wrap instead of pushing the page sideways. */
.letter-box{overflow-wrap:anywhere;word-break:break-word;-webkit-hyphens:none;hyphens:none}
@media(max-width:560px){
  .letter-box{font-size:12.5px;line-height:1.65;padding:16px 14px}
}

/* (8) iOS safe-area: keep the sticky CTA clear of the home indicator. */
@media(max-width:820px){
  .mobile-cta{padding-bottom:calc(10px + env(safe-area-inset-bottom,0px))}
  body{padding-bottom:calc(78px + env(safe-area-inset-bottom,0px))}
}

/* Narrow-phone layer: everything below applies at <=520px */
@media(max-width:520px){

  /* (1) Header crowding — give the brand room, shrink the tagline,
     and let the region pill compress to just the icon. */
  .site-header .nav{gap:10px;padding-left:16px;padding-right:16px}
  .brand{font-size:18px}
  .brand span{font-size:9.5px;letter-spacing:.14em}
  .region-pill{padding:5px 9px}
  .region-pill span{max-width:84px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  /* (2) Hero region selectors stack full-width as equal thumb targets. */
  .hero .btn-row{flex-direction:column;align-items:stretch;gap:10px}
  .hero .btn-row .btn{width:100%}

  /* (5) Stats read better as a single column on the narrowest phones. */
  .stats{grid-template-columns:1fr;gap:26px}
  .stat .k{max-width:none}

  /* (6) Inline action links get a larger, separated tap target. */
  .link{padding-top:8px;padding-bottom:8px;display:inline-block}
}

/* (1b) Smallest screens — if a region is chosen, drop the pill's text label
   entirely so the header never overflows. Icon still links to the chooser. */
@media(max-width:380px){
  .region-pill span{display:none}
}

/* (4) Homepage flight-corridor SVG: enlarge the baked-in labels on small
   screens so they stay legible when the 640-wide canvas is squeezed. */
@media(max-width:560px){
  .sec .art svg text{font-size:16px}
}
