/* ============================================================
   Durham 2031 — "Human & Hopeful" shared design system
   City of Durham Community Safety brand: navy / red / gold
   ============================================================ */
:root{
  /* ── Durham "Rare & Brief" brand palette — exact values from the
     Brand Guidelines. 60 cream / 30 navy / 10 warm-accent. ────────── */
  --ink: #2B2C31;            /* body text — warm charcoal, never pure black */
  --ink-soft: #4B4A4E;       /* softened ink for secondary copy */
  --muted: #847B68;          /* captions, footers, metadata */
  --faint: #A89E8B;          /* quietest labels */
  /* Durham navy = the anchor: headings, spine, rules, structure */
  --terra: #00467F;          /* logo navy (primary structural accent) */
  --terra-deep: #0A3A66;     /* deep navy — large fields, back panel */
  --terra-soft: #E9EEF3;     /* cool tint — quiet cards, navy pills */
  /* clay = the calmer label red (eyebrows & labels) */
  --clay: #8E443F;
  --clay-soft: #F3E7E2;
  /* Durham red = action accent (primary CTAs, sparing emphasis) */
  --red: #D23B40;
  --red-deep: #B22E33;
  --red-soft: #F7E5E4;
  /* Durham gold = motif, section rules, bullets, timeline nodes,
     and achievement / functional-zero */
  --gold: #E3A12A;           /* the workhorse gold */
  --gold-bright: #FFD24F;    /* pops on navy ONLY */
  --gold-deep: #A9761B;      /* legible gold for text on cream */
  --gold-soft: #F6E9CC;
  /* functional-zero semantic = gold */
  --green: #A9761B;
  --green-soft: #F6E9CC;
  --navy: #00467F;
  --navy-deep: #0A3A66;
  --sand: #F7F1E6;           /* cream paper — the default page background */
  --sand-deep: #EFE7D6;      /* sand tint — callout backgrounds */
  --paper: #FCF9F1;          /* card surface — cream, gently lifted */
  --line: #DBD3C2;           /* rule — hairlines, borders, dividers */
  --ink-bg: #0A3A66;         /* large navy bands / back panels */
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:72px;}
body{font-family:"Libre Franklin",system-ui,sans-serif;color:var(--ink);background:var(--sand);line-height:1.65;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{font-family:"Newsreader",serif;font-weight:400;line-height:1.08;letter-spacing:-0.01em;}
.wrap{max-width:1140px;margin:0 auto;padding:0 clamp(22px,5vw,60px);}
.narrow{max-width:760px;margin:0 auto;padding:0 clamp(22px,5vw,60px);}
.eyebrow{font-size:12.5px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--clay);}
a{color:inherit;}

/* nav */
header.nav{position:sticky;top:0;z-index:50;background:oklch(0.97 0.008 82 / 0.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:66px;}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink);}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--red);}
.brand-logo{height:33px;width:auto;display:block;}
.navlinks{display:flex;gap:17px;font-size:13px;font-weight:600;align-items:center;margin-left:18px;}
.navlinks a{color:var(--ink-soft);text-decoration:none;transition:color .2s;white-space:nowrap;}
.navlinks a:hover,.navlinks a.active{color:var(--terra-deep);}
.nav-cta{background:var(--red);color:#fff;font-size:13.5px;font-weight:700;padding:9px 18px;border-radius:999px;text-decoration:none;transition:background .2s,transform .2s;white-space:nowrap;}
.nav-cta:hover{background:var(--red-deep);transform:translateY(-1px);}
@media(max-width:880px){.navlinks{display:none;}}

/* reveal — additive; content visible by default */
.rv{opacity:1;transform:none;}
.anim-on .rv{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1);}
.anim-on .rv.in{opacity:1;transform:none;}
@media(prefers-reduced-motion: reduce){.anim-on .rv{opacity:1!important;transform:none!important;transition:none;}}

/* hero (home) */
.hero{padding:clamp(50px,8vw,96px) 0 clamp(40px,6vw,72px);}
.hero .eyebrow{display:block;margin-bottom:24px;}
.hero h1{font-size:clamp(40px,7vw,86px);font-weight:300;max-width:16ch;letter-spacing:-0.02em;}
.hero h1 em{font-style:italic;color:var(--terra);font-weight:400;}
.hero-foot{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:end;margin-top:42px;}
@media(max-width:820px){.hero-foot{grid-template-columns:1fr;gap:28px;}}
.hero-foot p{font-size:clamp(17px,2vw,21px);color:var(--ink-soft);max-width:46ch;font-weight:400;}
.hero-foot .actions{display:flex;gap:14px;flex-wrap:wrap;}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:14.5px;padding:13px 24px;border-radius:999px;text-decoration:none;transition:transform .18s,background .2s,border-color .2s;cursor:pointer;border:none;font-family:inherit;}
.btn-fill{background:var(--ink);color:var(--sand);}
.btn-fill:hover{transform:translateY(-2px);background:var(--ink-bg);}
.btn-out{border:1.5px solid var(--ink);color:var(--ink);background:transparent;}
.btn-out:hover{background:var(--ink);color:var(--sand);}
.btn-terra{background:var(--red);color:#fff;}
.btn-terra:hover{background:var(--red-deep);transform:translateY(-2px);}
.hero-img{margin-top:48px;height:clamp(280px,40vw,460px);border-radius:18px;overflow:hidden;}

/* image-slot framing */
image-slot{display:block;border-radius:18px;overflow:hidden;}

/* placeholder (legacy / fallback) */
.ph{border:1px solid var(--line);background:
   repeating-linear-gradient(135deg, var(--sand-deep), var(--sand-deep) 13px, oklch(0.9 0.025 65) 13px, oklch(0.9 0.025 65) 26px);
   display:grid;place-items:center;color:var(--terra-deep);font-size:12.5px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;text-align:center;padding:20px;}
.ph.dark{background:repeating-linear-gradient(135deg, oklch(0.3 0.03 45), oklch(0.3 0.03 45) 13px, oklch(0.34 0.03 45) 13px, oklch(0.34 0.03 45) 26px);color:var(--terra-soft);border-color:transparent;}

/* sections */
section{padding:clamp(56px,9vw,108px) 0;}
.band-ink{background:var(--ink-bg);color:var(--sand);}
.band-terra{background:var(--terra-soft);}
.band-paper{background:var(--paper);}

/* story / proof */
.story-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(36px,5vw,72px);align-items:center;}
@media(max-width:860px){.story-grid{grid-template-columns:1fr;gap:34px;}}
.story-num{font-family:"Newsreader",serif;font-size:clamp(120px,18vw,230px);font-weight:300;line-height:0.8;color:var(--gold-bright);letter-spacing:-0.04em;}
.story-num small{display:block;font-family:"Libre Franklin";font-size:16px;font-weight:600;color:var(--sand);letter-spacing:0;margin-top:18px;line-height:1.5;max-width:24ch;}
.band-ink .eyebrow{color:var(--gold-bright);}
.story-grid h2{font-size:clamp(28px,3.8vw,46px);font-weight:300;color:var(--sand);margin:16px 0 20px;}
.story-grid h2 em{font-style:italic;color:var(--gold);}
.story-grid p{font-size:16.5px;color:oklch(0.86 0.02 250);margin-bottom:16px;max-width:54ch;}
.story-grid p.first::first-letter{font-family:"Newsreader",serif;font-size:3.4em;float:left;line-height:0.78;padding:6px 12px 0 0;color:var(--gold);font-weight:400;}

/* section head */
.sh{margin-bottom:48px;max-width:62ch;}
.sh .eyebrow{display:block;margin-bottom:16px;}
.sh h2{font-size:clamp(30px,4.4vw,54px);font-weight:300;letter-spacing:-0.015em;}
.sh h2 em{font-style:italic;color:var(--terra);}
.sh p{font-size:18px;color:var(--muted);margin-top:18px;max-width:54ch;}

/* definition editorial */
.def{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
@media(max-width:860px){.def{grid-template-columns:1fr;gap:34px;}}
.def-word{margin-bottom:34px;}
.def-word:last-child{margin-bottom:0;}
.def-word h3{font-size:clamp(30px,4vw,44px);font-weight:400;font-style:italic;color:var(--terra);margin-bottom:8px;}
.def-word p{font-size:16.5px;color:var(--ink-soft);max-width:42ch;}
.fz-quote{background:var(--ink-bg);color:var(--sand);border-radius:18px;padding:clamp(30px,4vw,48px);}
.fz-quote .mk{font-family:"Newsreader",serif;font-size:60px;line-height:0.5;color:var(--gold);}
.fz-quote p{font-family:"Newsreader",serif;font-size:clamp(20px,2.4vw,28px);font-weight:300;line-height:1.4;margin:14px 0 20px;}
.fz-quote .formula{font-size:14px;color:oklch(0.82 0.02 250);border-top:1px solid oklch(0.45 0.05 252);padding-top:18px;}
.fz-quote .formula b{color:var(--gold);}

/* journey / targets */
.journey-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:36px;}
.pop-tabs{display:flex;flex-wrap:wrap;gap:9px;}
.pop-tab{font-size:13.5px;font-weight:600;padding:9px 16px;border-radius:999px;border:1.5px solid var(--line);background:transparent;color:var(--ink-soft);cursor:pointer;transition:all .2s;font-family:inherit;}
.pop-tab:hover{border-color:var(--terra);color:var(--terra-deep);}
.pop-tab.active{background:var(--ink);color:var(--sand);border-color:var(--ink);}
.journey{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:clamp(28px,4vw,48px);}
.journey-top{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:14px;margin-bottom:30px;}
.journey-top h3{font-size:clamp(24px,3vw,34px);font-weight:400;}
.journey-top h3 span{color:var(--terra);font-style:italic;}
.journey-top .approx{font-size:14px;color:var(--faint);font-weight:600;}
.track-years{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
@media(max-width:680px){.track-years{grid-template-columns:repeat(5,1fr);gap:7px;}}
.yr{text-align:center;}
.yr .bar-wrap{height:170px;display:flex;align-items:flex-end;justify-content:center;margin-bottom:12px;}
.yr .bar{width:100%;max-width:54px;border-radius:9px 9px 4px 4px;background:linear-gradient(180deg,var(--terra),var(--terra-deep));transition:height .8s cubic-bezier(.2,.8,.2,1);position:relative;}
.yr .bar.fz{background:linear-gradient(180deg,var(--gold),var(--gold-deep));}
.yr .bar.sustain{background:repeating-linear-gradient(135deg,var(--gold),var(--gold) 7px,var(--gold-deep) 7px,var(--gold-deep) 14px);}
.yr .val{font-family:"Newsreader",serif;font-size:21px;font-weight:500;margin-bottom:4px;}
.yr .val.fz{color:var(--green);}
.yr .ylab{font-size:12px;color:var(--faint);font-weight:600;}
.yr .ydate{font-size:11px;color:var(--faint);}
.journey-note{margin-top:24px;font-size:13.5px;color:var(--muted);display:flex;gap:24px;flex-wrap:wrap;}
.journey-note span{display:flex;align-items:center;gap:8px;}
.dotk{width:12px;height:12px;border-radius:3px;}

/* commitments (lanes) */
.commit{border-top:1px solid var(--line);}
.crow{display:grid;grid-template-columns:0.5fr 1fr 1.2fr auto;gap:34px;padding:30px 0;border-bottom:1px solid var(--line);align-items:center;text-decoration:none;color:inherit;transition:padding-left .25s,background .2s;}
.crow:hover{padding-left:10px;}
@media(max-width:820px){.crow{grid-template-columns:1fr auto;gap:10px 16px;}.crow p{grid-column:1/-1;}}
.crow .ci{font-family:"Newsreader",serif;font-size:18px;font-style:italic;color:var(--terra);}
.crow h3{font-size:clamp(22px,2.6vw,30px);font-weight:400;}
.crow p{font-size:15.5px;color:var(--muted);}
.crow .go{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;color:var(--terra-deep);transition:all .2s;flex-shrink:0;}
.crow:hover .go{background:var(--terra);border-color:var(--terra);color:#fff;transform:translateX(4px);}

/* functions accordion */
.fn-list{display:flex;flex-direction:column;border-top:1px solid var(--line);}
.fn-item{border-bottom:1px solid var(--line);}
.fn-head{display:grid;grid-template-columns:auto 1fr auto auto;gap:24px;padding:26px 0;align-items:center;cursor:pointer;transition:padding-left .25s;background:none;border:none;width:100%;text-align:left;font-family:inherit;color:inherit;}
.fn-head:hover{padding-left:10px;}
@media(max-width:760px){.fn-head{grid-template-columns:auto 1fr auto;gap:14px;}.fn-head .fn-stat{display:none;}}
.fn-head .fn-i{font-family:"Newsreader",serif;font-size:clamp(30px,5vw,52px);font-weight:300;color:var(--line);min-width:58px;transition:color .25s;}
.fn-item.open .fn-head .fn-i,.fn-head:hover .fn-i{color:var(--terra);}
.fn-head h3{font-size:clamp(19px,2.4vw,26px);font-weight:400;}
.fn-stat{font-size:13px;font-weight:700;color:var(--terra-deep);background:var(--terra-soft);padding:7px 14px;border-radius:999px;white-space:nowrap;}
.fn-chev{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;color:var(--ink-soft);transition:all .3s;flex-shrink:0;}
.fn-item.open .fn-chev{background:var(--terra);border-color:var(--terra);color:#fff;transform:rotate(180deg);}
.fn-panel{overflow:hidden;max-height:0;transition:max-height .45s cubic-bezier(.4,0,.2,1);}
.fn-panel-inner{padding:6px 0 36px;display:grid;grid-template-columns:1fr 1.3fr;gap:40px;}
@media(max-width:760px){.fn-panel-inner{grid-template-columns:1fr;gap:22px;}}
.fn-lead{font-size:16.5px;color:var(--ink-soft);line-height:1.6;}
.fn-lead .why{display:block;margin-top:18px;font-style:italic;font-family:"Newsreader",serif;font-size:18px;color:var(--terra-deep);line-height:1.45;}
.fn-key{list-style:none;}
.fn-key li{position:relative;padding:0 0 14px 26px;font-size:14.5px;color:var(--muted);}
.fn-key li::before{content:"";position:absolute;left:2px;top:9px;width:8px;height:8px;border-radius:50%;background:var(--terra);}
.fn-key li b{color:var(--ink);font-weight:600;}
.fn-deep{margin-top:14px;font-size:13.5px;font-weight:700;color:var(--terra-deep);display:inline-flex;gap:7px;align-items:center;text-decoration:none;}

/* voices pull quote */
.voices{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(34px,5vw,64px);align-items:center;}
@media(max-width:820px){.voices{grid-template-columns:1fr;gap:30px;}}
.voices-img{height:clamp(280px,36vw,420px);}
.voices blockquote{font-family:"Newsreader",serif;font-size:clamp(24px,3.2vw,40px);font-weight:300;line-height:1.28;letter-spacing:-0.01em;}
.voices blockquote em{font-style:italic;color:var(--gold);}
.voices .attr{margin-top:24px;font-size:14px;color:var(--muted);font-weight:600;letter-spacing:0.02em;}

/* cities */
.cities{display:flex;flex-wrap:wrap;gap:10px;}
.city{font-size:14px;font-weight:600;border:1px solid var(--line);border-radius:999px;padding:8px 16px;color:var(--ink-soft);background:var(--sand);transition:all .2s;}
.city:hover{border-color:var(--terra);color:var(--terra-deep);}

/* future vignettes */
.future-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:820px){.future-grid{grid-template-columns:1fr;}}
.vign{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:30px;display:flex;flex-direction:column;gap:14px;transition:transform .25s,box-shadow .25s;}
.vign:hover{transform:translateY(-4px);box-shadow:0 20px 42px -26px oklch(0.4 0.05 50/.55);}
.vign .who{font-family:"Newsreader",serif;font-style:italic;color:var(--terra);font-size:17px;}
.vign .num{font-family:"Newsreader",serif;font-size:34px;font-weight:300;color:var(--green);line-height:1;}
.vign p{font-size:15.5px;color:var(--ink-soft);line-height:1.55;}
.vign p em{font-style:normal;color:var(--ink);font-weight:600;}

/* engage / get involved */
.role-pick{display:flex;flex-wrap:wrap;gap:9px;align-items:center;margin-bottom:34px;}
.role-pick .lab{font-family:"Newsreader",serif;font-style:italic;font-size:18px;color:var(--ink-soft);margin-right:4px;}
.role-chip{font-family:inherit;font-size:13.5px;font-weight:600;padding:9px 16px;border-radius:999px;border:1.5px solid var(--line);background:transparent;color:var(--ink-soft);cursor:pointer;transition:all .2s;}
.role-chip:hover{border-color:var(--terra);color:var(--terra-deep);}
.role-chip.active{background:var(--terra);color:#fff;border-color:var(--terra);}
.eng-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:860px){.eng-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.eng-grid{grid-template-columns:1fr;}}
.eng{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:28px;transition:transform .2s,box-shadow .2s,border-color .25s,background .25s;display:flex;flex-direction:column;scroll-margin-top:90px;text-decoration:none;color:inherit;}
.eng:hover{transform:translateY(-4px);box-shadow:0 18px 36px -24px oklch(0.4 0.05 50/.6);}
.eng.hot{border-color:var(--terra);background:oklch(0.94 0.03 248);box-shadow:0 22px 46px -24px oklch(0.43 0.10 250/.5), inset 0 3px 0 0 var(--red);transform:translateY(-4px);}
.eng .ei{font-family:"Newsreader",serif;font-style:italic;color:var(--terra);font-size:18px;margin-bottom:12px;}
.eng h4{font-size:22px;font-weight:400;margin-bottom:9px;}
.eng p{font-size:14.5px;color:var(--muted);flex:1;}
.eng .act{margin-top:16px;font-size:13.5px;font-weight:700;color:var(--terra-deep);display:inline-flex;align-items:center;gap:8px;}
.eng .act svg{transition:transform .2s;}
.eng:hover .act svg,.eng.hot .act svg{transform:translateX(4px);}

/* CTA band */
.cta-band{margin-top:42px;background:var(--ink-bg);color:var(--sand);border-radius:24px;padding:clamp(32px,5vw,58px);display:grid;grid-template-columns:1.4fr auto;gap:34px;align-items:center;}
@media(max-width:780px){.cta-band{grid-template-columns:1fr;gap:24px;}}
.cta-band h3{font-family:"Newsreader",serif;font-weight:300;font-size:clamp(26px,3.6vw,40px);color:var(--sand);letter-spacing:-0.015em;line-height:1.12;}
.cta-band h3 em{font-style:italic;color:var(--gold);}
.cta-band p{font-size:15px;color:oklch(0.82 0.02 250);margin-top:14px;max-width:48ch;}
.cta-band .acts{display:flex;gap:12px;flex-wrap:wrap;}

/* newsletter inline */
.news{margin-top:42px;background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:clamp(26px,4vw,40px);display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;}
@media(max-width:720px){.news{grid-template-columns:1fr;gap:18px;}}
.news h3{font-size:clamp(22px,2.8vw,30px);font-weight:400;}
.news h3 em{font-style:italic;color:var(--terra);}
.news p{font-size:14.5px;color:var(--muted);margin-top:8px;max-width:46ch;}
.news-form{display:flex;gap:10px;flex-wrap:wrap;}
.news-form input{font-family:inherit;font-size:15px;padding:13px 18px;border-radius:999px;border:1.5px solid var(--line);background:var(--sand);min-width:240px;color:var(--ink);}
.news-form input:focus{outline:none;border-color:var(--terra);}
.news.done .news-form{display:none;}
.news-thanks{display:none;font-family:"Newsreader",serif;font-style:italic;font-size:19px;color:var(--green);}
.news.done .news-thanks{display:block;}

/* ============================================================
   SUBPAGE LAYOUT (lanes + flows)
   ============================================================ */
.crumbs{font-size:13px;font-weight:600;color:var(--muted);padding:22px 0 0;display:flex;gap:9px;align-items:center;flex-wrap:wrap;}
.crumbs a{text-decoration:none;color:var(--terra-deep);}
.crumbs a:hover{text-decoration:underline;}
.crumbs span{color:var(--faint);}

.sub-hero{padding:clamp(30px,5vw,56px) 0 clamp(34px,5vw,60px);border-bottom:1px solid var(--line);}
.sub-hero .kick{display:flex;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap;}
.sub-hero .lane-no{font-family:"Newsreader",serif;font-size:clamp(40px,7vw,76px);font-weight:300;color:var(--terra);line-height:0.8;}
.sub-hero h1{font-size:clamp(34px,5.2vw,62px);font-weight:300;max-width:20ch;letter-spacing:-0.02em;}
.sub-hero h1 em{font-style:italic;color:var(--terra);}
.sub-hero .aim{margin-top:26px;font-size:clamp(17px,2vw,21px);color:var(--ink-soft);max-width:60ch;}
.sub-hero .aim b{color:var(--ink);font-weight:600;}
.sub-hero .pills{display:flex;flex-wrap:wrap;gap:9px;margin-top:26px;}
.pill{font-size:12.5px;font-weight:700;color:var(--terra-deep);background:var(--terra-soft);border-radius:999px;padding:7px 14px;}

.prose{max-width:none;}
.col-2{display:grid;grid-template-columns:1.1fr 0.9fr;gap:clamp(34px,5vw,64px);align-items:start;}
@media(max-width:860px){.col-2{grid-template-columns:1fr;gap:30px;}}
.lead{font-size:clamp(18px,2.1vw,22px);font-weight:300;font-family:"Newsreader",serif;color:var(--ink-soft);line-height:1.45;}
.body-copy p{font-size:16px;color:var(--muted);margin-bottom:16px;}
.body-copy p b{color:var(--ink);font-weight:600;}

/* secondary-strategy list */
.sec-list{list-style:none;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line);}
.sec-list li{position:relative;padding:20px 0 20px 38px;border-bottom:1px solid var(--line);font-size:16px;color:var(--ink-soft);}
.sec-list li .n{position:absolute;left:0;top:20px;font-family:"Libre Franklin",monospace;}
.sec-list li::before{content:"";position:absolute;left:3px;top:27px;width:9px;height:9px;border-radius:50%;background:var(--terra);}

/* side card */
.aside-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:28px;position:sticky;top:84px;}
.aside-card h4{font-size:18px;font-weight:400;margin-bottom:14px;}
.aside-card .row{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px;}
.aside-card .row:last-child{border:none;}
.aside-card .row .k{color:var(--muted);}
.aside-card .row .v{font-weight:700;color:var(--ink);text-align:right;}

/* milestones timeline */
.miles{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
@media(max-width:760px){.miles{grid-template-columns:1fr;}}
.mile{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:10px;}
.mile .yr-tag{font-family:"Libre Franklin",monospace;font-size:12px;color:var(--terra-deep);font-weight:600;}
.mile .yr-date{font-size:11px;color:var(--faint);}
.mile p{font-size:13.5px;color:var(--ink-soft);line-height:1.5;}
.mile.fz{background:var(--gold-soft);border-color:var(--gold);}

/* pull / crosswalk */
.crosswalk{background:var(--ink-bg);color:var(--sand);border-radius:18px;padding:clamp(28px,4vw,44px);}
.crosswalk h3{color:var(--sand);font-weight:300;font-size:clamp(22px,2.8vw,30px);margin-bottom:18px;}
.crosswalk h3 em{font-style:italic;color:var(--gold);}
.crosswalk ul{list-style:none;}
.crosswalk li{padding:13px 0;border-bottom:1px solid oklch(0.45 0.05 252);font-size:15px;color:oklch(0.84 0.02 250);}
.crosswalk li:last-child{border:none;}
.crosswalk li b{color:var(--sand);font-weight:600;}

/* lane prev/next */
.lane-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px;}
@media(max-width:600px){.lane-nav{grid-template-columns:1fr;}}
.lane-nav a{display:flex;flex-direction:column;gap:5px;padding:24px;border:1px solid var(--line);border-radius:16px;background:var(--paper);text-decoration:none;transition:border-color .2s,transform .2s;}
.lane-nav a:hover{border-color:var(--terra);transform:translateY(-3px);}
.lane-nav .dir{font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--terra-deep);}
.lane-nav a.next{text-align:right;}
.lane-nav h4{font-size:20px;font-weight:400;}

/* ============================================================
   FORMS (flows)
   ============================================================ */
.flow-grid{display:grid;grid-template-columns:1fr 0.85fr;gap:clamp(34px,5vw,60px);align-items:start;}
@media(max-width:880px){.flow-grid{grid-template-columns:1fr;gap:30px;}}
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:clamp(26px,4vw,40px);}
.form-card h2{font-size:clamp(24px,3vw,34px);font-weight:400;margin-bottom:8px;}
.form-card h2 em{font-style:italic;color:var(--terra);}
.form-card .sub{font-size:15px;color:var(--muted);margin-bottom:26px;}
.field{margin-bottom:20px;}
.field label{display:block;font-size:13px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px;}
.field .hint{font-weight:400;text-transform:none;letter-spacing:0;color:var(--faint);font-size:12.5px;}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:15.5px;padding:13px 16px;border-radius:12px;border:1.5px solid var(--line);background:var(--sand);color:var(--ink);transition:border-color .2s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--terra);background:var(--paper);}
.field textarea{min-height:104px;resize:vertical;}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--red);background:var(--red-soft);}
.field .err{display:none;color:var(--red-deep);font-size:12.5px;margin-top:6px;font-weight:600;}
.field.invalid .err{display:block;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:520px){.row2{grid-template-columns:1fr;}}

/* donation amounts */
.amount-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:8px;}
@media(max-width:520px){.amount-grid{grid-template-columns:repeat(2,1fr);}}
.amt{font-family:inherit;font-size:18px;font-weight:700;padding:16px 8px;border-radius:12px;border:1.5px solid var(--line);background:var(--sand);color:var(--ink);cursor:pointer;transition:all .18s;}
.amt:hover{border-color:var(--terra);}
.amt.active{background:var(--terra);color:#fff;border-color:var(--terra);}
.amt small{display:block;font-size:10.5px;font-weight:600;opacity:.8;margin-top:3px;letter-spacing:0.02em;}
.freq{display:flex;gap:8px;margin-bottom:22px;}
.freq button{flex:1;font-family:inherit;font-size:14px;font-weight:700;padding:11px;border-radius:999px;border:1.5px solid var(--line);background:transparent;color:var(--ink-soft);cursor:pointer;transition:all .18s;}
.freq button.active{background:var(--ink);color:var(--sand);border-color:var(--ink);}
.impact-note{background:var(--terra-soft);border-radius:12px;padding:14px 16px;font-size:13.5px;color:var(--terra-deep);font-weight:600;margin-bottom:22px;}

/* choice cards (get-help paths, landlord toggles) */
.choices{display:flex;flex-direction:column;gap:12px;margin-bottom:22px;}
.choice{display:flex;gap:14px;align-items:flex-start;padding:18px;border:1.5px solid var(--line);border-radius:14px;background:var(--sand);cursor:pointer;transition:all .18s;}
.choice:hover{border-color:var(--terra);}
.choice.active{border-color:var(--terra);background:oklch(0.94 0.03 248);}
.choice .ck{width:22px;height:22px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;margin-top:2px;display:grid;place-items:center;transition:all .2s;}
.choice.active .ck{border-color:var(--terra);background:var(--terra);}
.choice.active .ck::after{content:"";width:8px;height:8px;border-radius:50%;background:#fff;}
.choice .ct{font-weight:700;font-size:15.5px;color:var(--ink);}
.choice .cd{font-size:13.5px;color:var(--muted);margin-top:3px;}

/* form success */
.form-success{display:none;text-align:center;padding:20px 0;}
.form-success.show{display:block;animation:pop .4s ease;}
@keyframes pop{from{opacity:0;transform:scale(.96);}to{opacity:1;transform:none;}}
.form-success .check{width:64px;height:64px;border-radius:50%;background:var(--terra);display:grid;place-items:center;margin:0 auto 20px;}
.form-success h2{font-size:clamp(26px,3.4vw,38px);font-weight:400;margin-bottom:12px;}
.form-success h2 em{font-style:italic;color:var(--terra);}
.form-success p{font-size:16px;color:var(--muted);max-width:44ch;margin:0 auto 22px;}

/* emergency banner (get-help) */
.emergency{background:var(--ink-bg);color:var(--sand);border-radius:16px;padding:22px 26px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-bottom:30px;}
.emergency .dot{width:11px;height:11px;border-radius:50%;background:var(--red);flex-shrink:0;box-shadow:0 0 0 0 var(--red);animation:epulse 2s infinite;}
@keyframes epulse{0%{box-shadow:0 0 0 0 oklch(0.585 0.195 26/.5);}70%{box-shadow:0 0 0 9px oklch(0.585 0.195 26/0);}100%{box-shadow:0 0 0 0 oklch(0.585 0.195 26/0);}}
.emergency b{color:var(--sand);}
.emergency span{font-size:14.5px;color:oklch(0.84 0.02 250);}
.emergency a{color:var(--gold);font-weight:700;text-decoration:none;}

/* step list (what happens next) */
.steps{list-style:none;counter-reset:s;}
.steps li{position:relative;padding:0 0 22px 50px;}
.steps li::before{counter-increment:s;content:counter(s);position:absolute;left:0;top:-2px;width:34px;height:34px;border-radius:50%;background:var(--terra-soft);color:var(--terra-deep);font-weight:800;display:grid;place-items:center;font-size:15px;}
.steps li::after{content:"";position:absolute;left:16px;top:34px;bottom:0;width:1.5px;background:var(--line);}
.steps li:last-child{padding-bottom:0;}
.steps li:last-child::after{display:none;}
.steps li b{display:block;font-size:16px;color:var(--ink);font-weight:600;margin-bottom:3px;}
.steps li p{font-size:14px;color:var(--muted);}

/* footer */
footer{background:var(--ink-bg);color:oklch(0.82 0.02 250);padding:clamp(56px,8vw,96px) 0 44px;}
footer h2{font-family:"Newsreader",serif;font-size:clamp(30px,5vw,58px);font-weight:300;color:var(--sand);max-width:18ch;letter-spacing:-0.02em;}
footer h2 em{font-style:italic;color:var(--gold);}
.foot-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px;}
.btn-sand{background:var(--red);color:#fff;}
.btn-sand:hover{background:var(--red-deep);}
.btn-line{border:1.5px solid oklch(0.55 0.04 252);color:var(--sand);}
.btn-line:hover{border-color:var(--gold);color:var(--gold);}
.foot-cols{display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px;margin-top:48px;}
.foot-cols .fcol h5{font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;}
.foot-cols .fcol a{display:block;font-size:14px;color:oklch(0.82 0.02 250);text-decoration:none;margin-bottom:9px;transition:color .2s;}
.foot-cols .fcol a:hover{color:#fff;}
.foot-logo{margin-top:46px;background:#fff;border-radius:12px;padding:14px 18px;display:inline-block;}
.foot-logo img{height:34px;width:auto;display:block;}
.foot-meta{margin-top:24px;border-top:1px solid oklch(0.45 0.05 252);padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px;line-height:1.7;color:oklch(0.68 0.02 250);}
.backlink{position:fixed;left:16px;bottom:16px;z-index:60;background:var(--ink);color:var(--sand);font-size:12px;font-weight:600;padding:9px 14px;border-radius:999px;text-decoration:none;box-shadow:0 8px 24px -10px rgba(0,0,0,.4);opacity:.92;transition:opacity .2s;}
.backlink:hover{opacity:1;}

/* ============================================================
   HERO FEATURED STORY (story-led homepage)
   ============================================================ */
.hero-feature{margin-top:46px;background:var(--paper);border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:0 24px 50px -34px oklch(0.43 0.08 250/.5);}
.hf-slide{display:none;grid-template-columns:0.82fr 1.18fr;}
.hf-slide.active{display:grid;}
@media(max-width:820px){.hf-slide.active{grid-template-columns:1fr;}}
.hf-photo{min-height:clamp(280px,34vw,420px);background:var(--sand-deep);position:relative;}
.hf-photo image-slot{width:100%;height:100%;border-radius:0;}
@media(max-width:820px){.hf-photo{min-height:260px;}}
.hf-body{padding:clamp(28px,4vw,52px);display:flex;flex-direction:column;justify-content:center;}
.hf-label{font-size:12.5px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--clay);margin-bottom:20px;display:flex;align-items:center;gap:11px;}
.hf-label::before{content:"";width:26px;height:2px;background:var(--gold);}
.hf-quote{font-family:"Newsreader",serif;font-weight:300;font-size:clamp(23px,2.7vw,36px);line-height:1.26;letter-spacing:-0.01em;color:var(--ink);}
.hf-quote em{font-style:italic;color:var(--terra);}
.hf-by{margin-top:24px;font-size:14px;color:var(--muted);}
.hf-by b{display:block;font-family:"Newsreader",serif;font-weight:500;font-size:18px;color:var(--ink);margin-bottom:2px;}
.hf-controls{display:flex;align-items:center;justify-content:space-between;gap:16px 22px;padding:16px clamp(28px,4vw,52px);border-top:1px solid var(--line);flex-wrap:wrap;}
.hf-controls .left{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.hf-dots{display:flex;gap:9px;align-items:center;}
.hf-dot{width:9px;height:9px;border-radius:999px;background:var(--line);border:none;padding:0;cursor:pointer;transition:all .25s;}
.hf-dot.active{background:var(--terra);width:28px;}
.hf-more{font-size:13.5px;font-weight:700;color:var(--terra-deep);text-decoration:none;display:inline-flex;gap:7px;align-items:center;white-space:nowrap;}
.hf-more svg{transition:transform .2s;}
.hf-more:hover svg{transform:translateX(4px);}
.hf-flag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--gold-deep);background:var(--gold-soft);border-radius:999px;padding:5px 11px;}

/* ============================================================
   PARTNERS & BACKBONE
   ============================================================ */
.backbone{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(30px,5vw,60px);align-items:center;background:var(--ink-bg);color:var(--sand);border-radius:24px;padding:clamp(30px,5vw,56px);}
@media(max-width:840px){.backbone{grid-template-columns:1fr;gap:28px;}}
.backbone .eyebrow{color:var(--gold-bright);display:block;margin-bottom:16px;}
.backbone h3{font-family:"Newsreader",serif;font-weight:300;font-size:clamp(26px,3.4vw,40px);color:var(--sand);letter-spacing:-0.015em;line-height:1.12;}
.backbone h3 em{font-style:italic;color:var(--gold);}
.backbone p{font-size:15.5px;color:oklch(0.84 0.02 250);margin-top:16px;max-width:50ch;}
.backbone .role-rows{display:flex;flex-direction:column;gap:0;}
.backbone .rr{display:flex;justify-content:space-between;gap:18px;padding:14px 0;border-bottom:1px solid oklch(0.45 0.05 252);font-size:14.5px;}
.backbone .rr:last-child{border:none;}
.backbone .rr .k{color:oklch(0.78 0.03 250);}
.backbone .rr .v{font-weight:600;color:var(--sand);text-align:right;}

.partners-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px;}
@media(max-width:860px){.partners-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.partners-grid{grid-template-columns:1fr;}}
.partner{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:24px;transition:transform .2s,border-color .2s;}
.partner:hover{transform:translateY(-3px);border-color:var(--terra);}
.partner .ptag{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--clay);margin-bottom:10px;}
.partner h4{font-size:19px;font-weight:400;margin-bottom:7px;line-height:1.2;}
.partner p{font-size:13.8px;color:var(--muted);}
.tables-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.psub{font-family:"Newsreader",serif;font-weight:400;font-size:clamp(22px,2.8vw,30px);margin:0 0 6px;}
.psub.spaced{margin-top:56px;padding-top:52px;border-top:1px solid var(--line);}
.psub-lead{color:var(--muted);font-size:16px;margin-bottom:22px;max-width:62ch;}
.tablechip{font-size:13px;font-weight:600;border:1px solid var(--line);border-radius:999px;padding:9px 16px;color:var(--ink-soft);background:var(--sand);display:inline-flex;gap:8px;align-items:center;}
.tablechip::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold-deep);}

/* ============================================================
   RESOURCES / DOWNLOADS
   ============================================================ */
.dl-feature{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
@media(max-width:760px){.dl-feature{grid-template-columns:1fr;}}
.dl-list{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:760px){.dl-list{grid-template-columns:1fr;}}
.dl{display:flex;gap:16px;align-items:center;padding:20px 22px;border:1px solid var(--line);border-radius:16px;background:var(--paper);text-decoration:none;color:inherit;transition:transform .2s,border-color .2s,box-shadow .2s;}
.dl:hover{transform:translateY(-3px);border-color:var(--terra);box-shadow:0 16px 32px -24px oklch(0.43 0.10 250/.5);}
.dl.feat{background:var(--terra);border-color:var(--terra);color:#fff;}
.dl .ic{width:46px;height:54px;border-radius:6px;background:var(--red);position:relative;flex-shrink:0;display:grid;place-items:end center;padding-bottom:7px;}
.dl.feat .ic{background:#fff;}
.dl .ic::after{content:"PDF";font-size:9px;font-weight:800;letter-spacing:0.04em;color:#fff;}
.dl.feat .ic::after{color:var(--red);}
.dl .ic::before{content:"";position:absolute;top:0;right:0;border-width:0 13px 13px 0;border-style:solid;border-color:transparent oklch(0.97 0.008 82) transparent transparent;}
.dl .dmeta{min-width:0;}
.dl .dt{font-weight:700;font-size:15.5px;line-height:1.25;margin-bottom:3px;}
.dl.feat .dt{font-size:18px;}
.dl .dd{font-size:12.5px;color:var(--muted);}
.dl.feat .dd{color:oklch(0.92 0.02 250);}
.dl .arrow{margin-left:auto;color:var(--terra-deep);flex-shrink:0;}
.dl.feat .arrow{color:#fff;}

/* ============================================================
   STORIES
   ============================================================ */
.stories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:860px){.stories-grid{grid-template-columns:1fr;}}
.story-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;}
.story-card:hover{transform:translateY(-4px);box-shadow:0 20px 42px -26px oklch(0.43 0.08 250/.5);}
.story-card .sc-img{height:230px;background:var(--sand-deep);}
.story-card .sc-img image-slot{width:100%;height:100%;border-radius:0;}
.story-card .sc-body{padding:26px;display:flex;flex-direction:column;flex:1;}
.story-card .sc-tag{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--clay);margin-bottom:12px;}
.story-card blockquote{font-family:"Newsreader",serif;font-size:21px;font-weight:300;font-style:italic;line-height:1.32;color:var(--ink);margin-bottom:16px;flex:1;}
.story-card .sc-by{font-size:13.5px;color:var(--muted);font-weight:600;}
.story-card .sc-by b{color:var(--ink);font-weight:700;display:block;font-family:"Newsreader",serif;font-style:normal;font-size:16px;}
.placeholder-flag{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--gold-deep);background:var(--gold-soft);border-radius:999px;padding:6px 13px;margin-bottom:18px;}

/* ============================================================
   BRAND STRUCTURAL MARKS  (Durham "Rare & Brief")
   navy spine · gold section rules · converging-arcs motif
   ============================================================ */

/* The spine — a navy band down the left margin of every page,
   with a gold tab capping the top. The brand's signature mark. */
body::before{content:"";position:fixed;top:0;left:0;bottom:0;width:16px;background:var(--navy);z-index:120;pointer-events:none;}
body::after{content:"";position:fixed;top:0;left:0;width:16px;height:132px;background:var(--gold);z-index:121;pointer-events:none;}
@media(max-width:600px){body::before,body::after{width:7px;}body::after{height:96px;}}

/* Section title gets a short gold underline rule — the brand's
   "title + gold rule" component, applied to web section heads. */
.sh h2::after,
.form-card h2::after{content:"";display:block;width:54px;height:3px;border-radius:2px;background:var(--gold);margin-top:24px;}
.sub-hero h1::after{content:"";display:block;width:54px;height:3px;border-radius:2px;background:var(--gold);margin-top:26px;}

/* The converging-arcs / horizon motif — four nested half-arcs rising
   from a single point ("many efforts, one number; many neighbors,
   one community"). A quiet signature at the top of every page, set
   above the eyebrow in the logo's red / gold / navy. One per page.
   Rendered as a real inline <svg class="brandmark"> in each hero. */
.brandmark{display:block;width:94px;height:auto;margin:0 0 24px;}
@media(max-width:600px){.brandmark{width:78px;margin-bottom:18px;}}
