/* ============================================================
   THE GREEN DIVIDE — styles.css
   Fonts: Cormorant Garamond (display) · Source Serif 4 (body)
   ============================================================ */

/* ── Custom Properties ──────────────────────────────────────────────────── */
:root {
  /* Palette */
  --c-green:      #1e3a2f;
  --c-green-mid:  #2a5040;
  --c-sage:       #6b8c6b;
  --c-cream:      #f5f0e8;
  --c-cream-dk:   #ede7d9;
  --c-amber:      #c8690a;
  --c-amber-lt:   #e07f22;
  --c-dark:       #19201e;
  --c-dark-alt:   #0f1a14;
  --c-text:       #1c1c18;
  --c-text-mid:   #3d3d35;
  --c-muted:      #666658;
  --c-rule:       rgba(200,105,10,.2);
  --c-rule-lt:    rgba(255,255,255,.12);

  /* Fonts */
  --f-display:    'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --f-body:       'Source Serif 4', Georgia, 'Times New Roman', serif;

  /* Fluid type scale */
  --t-xs:   clamp(.72rem, 1vw, .8rem);
  --t-sm:   clamp(.85rem, 1.1vw, .95rem);
  --t-base: clamp(.98rem, 1.3vw, 1.08rem);
  --t-md:   clamp(1.1rem, 1.6vw, 1.3rem);
  --t-lg:   clamp(1.35rem, 2vw, 1.75rem);
  --t-xl:   clamp(1.7rem, 3vw, 2.5rem);
  --t-2xl:  clamp(2.2rem, 4.5vw, 3.8rem);
  --t-hero: clamp(3.2rem, 9vw, 7.5rem);
  --t-stat: clamp(4.5rem, 13vw, 9.5rem);

  /* Spacing */
  --sp-1: .5rem;
  --sp-2: 1rem;
  --sp-3: 1.5rem;
  --sp-4: 2rem;
  --sp-6: 3rem;
  --sp-8: 4rem;
  --sp-12: 6rem;
  --sp-16: 8rem;
  --sp-20: 10rem;

  /* Section padding */
  --sec-y: clamp(5rem, 10vw, 9rem);

  /* Layout */
  --w-narrow:  720px;
  --w-default: 1160px;
  --w-wide:    1380px;
  --pad-x:     clamp(1.25rem, 5vw, 3rem);

  /* Transitions */
  --ease:     cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(0,0,.2,1);
  --spring:   cubic-bezier(.34,1.56,.64,1);
}

/* ── Reset ──────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--f-body);
  font-size: var(--t-base);
  color: var(--c-text);
  background: var(--c-cream);
  line-height: 1.7;
  overflow-x: hidden;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
cite { font-style: normal; }

/* Grain texture overlay on every section */
.section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='1'/%3E%3C/svg%3E");
  opacity: .028;
  pointer-events: none;
  z-index: 0;
}

/* ── Layout helpers ─────────────────────────────────────────────────────── */
.container {
  max-width: var(--w-default);
  margin-inline: auto;
  padding-inline: var(--pad-x);
}
.container--narrow { max-width: var(--w-narrow); }
.container--wide   { max-width: var(--w-wide); }

.section {
  position: relative;
  padding-block: var(--sec-y);
}
.section--cream    { background: var(--c-cream); color: var(--c-text); }
.section--green    { background: var(--c-green); color: var(--c-cream); }
.section--dark     { background: var(--c-dark-alt); color: var(--c-cream); }

/* ── Scroll animations ─────────────────────────────────────────────────── */
[data-animate] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
[data-animate].is-vis {
  opacity: 1;
  transform: translateY(0);
}
[data-delay="80"]  { transition-delay:  80ms; }
[data-delay="100"] { transition-delay: 100ms; }
[data-delay="120"] { transition-delay: 120ms; }
[data-delay="130"] { transition-delay: 130ms; }
[data-delay="150"] { transition-delay: 150ms; }
[data-delay="160"] { transition-delay: 160ms; }
[data-delay="200"] { transition-delay: 200ms; }
[data-delay="240"] { transition-delay: 240ms; }
[data-delay="260"] { transition-delay: 260ms; }
[data-delay="300"] { transition-delay: 300ms; }
[data-delay="350"] { transition-delay: 350ms; }
[data-delay="360"] { transition-delay: 360ms; }
[data-delay="400"] { transition-delay: 400ms; }

@media (prefers-reduced-motion: reduce) {
  [data-animate], [data-reveal] { opacity: 1; transform: none; transition: none; animation: none; }
}

/* ── Navigation ─────────────────────────────────────────────────────────── */
.site-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding-block: .9rem;
  transition: background .35s var(--ease), box-shadow .35s var(--ease);
}
.site-nav--solid {
  background: rgba(14,25,19,.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 2px 20px rgba(0,0,0,.35);
}
.site-nav__inner {
  max-width: var(--w-wide);
  margin-inline: auto;
  padding-inline: var(--pad-x);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
}
.site-nav__brand {
  font-family: var(--f-display);
  font-size: var(--t-md);
  font-weight: 600;
  color: var(--c-cream);
  text-decoration: none;
  letter-spacing: -.01em;
  white-space: nowrap;
  opacity: 0;
  transition: opacity .35s;
}
.site-nav--solid .site-nav__brand { opacity: 1; }

.site-nav__links {
  display: flex;
  gap: var(--sp-6);
  align-items: center;
}
.site-nav__link {
  font-family: var(--f-body);
  font-size: var(--t-xs);
  font-weight: 400;
  color: rgba(245,240,232,.7);
  text-decoration: none;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: color .2s;
}
.site-nav__link:hover,
.site-nav__link.is-active { color: var(--c-amber-lt); }

.site-nav__toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: var(--sp-1);
}
.site-nav__toggle span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--c-cream);
  transition: transform .25s, opacity .25s;
}
.site-nav--open .site-nav__toggle span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.site-nav--open .site-nav__toggle span:nth-child(2) { opacity: 0; }
.site-nav--open .site-nav__toggle span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile nav overlay */
@media (max-width: 820px) {
  .site-nav__toggle { display: flex; }
  .site-nav__links {
    position: fixed;
    inset: 0;
    background: var(--c-dark-alt);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: var(--sp-6);
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s;
  }
  .site-nav--open .site-nav__links { opacity: 1; pointer-events: all; }
  .site-nav__link { font-size: var(--t-lg); letter-spacing: .04em; color: var(--c-cream); }
}

/* ── Section typography shared ──────────────────────────────────────────── */
.section__heading {
  font-family: var(--f-display);
  font-size: var(--t-2xl);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -.02em;
  color: var(--c-green);
  margin-bottom: var(--sp-8);
}
.section__heading--light { color: var(--c-cream); }

.section__subhead {
  font-family: var(--f-body);
  font-size: var(--t-md);
  color: var(--c-text-mid);
  max-width: 680px;
  margin-top: calc(-1 * var(--sp-6));
  margin-bottom: var(--sp-8);
  line-height: 1.55;
}
.section__subhead--light { color: rgba(245,240,232,.75); }

.section__prose {
  font-size: var(--t-base);
  line-height: 1.78;
  max-width: 680px;
}
.section__prose--light { color: rgba(245,240,232,.88); }
.section__prose p + p { margin-top: var(--sp-3); }
.section__lede {
  font-size: var(--t-md);
  font-weight: 400;
  line-height: 1.55;
  color: var(--c-text);
  margin-bottom: var(--sp-4);
}

/* ── HERO ───────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  background:
    radial-gradient(ellipse at 15% 60%, rgba(56,100,70,.25) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 20%, rgba(30,58,47,.6) 0%, transparent 65%),
    var(--c-green);
  overflow: hidden;
}

/* Organic leaf-vein texture overlay */
.hero__texture {
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(
      135deg,
      rgba(255,255,255,.018) 0px,
      rgba(255,255,255,.018) 1px,
      transparent 1px,
      transparent 60px
    );
  pointer-events: none;
}

.hero__content {
  position: relative;
  z-index: 1;
  max-width: var(--w-default);
  margin-inline: auto;
  width: 100%;
  padding: calc(var(--sec-y) + 4rem) var(--pad-x) var(--sec-y);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.hero__eyebrow {
  font-family: var(--f-body);
  font-size: var(--t-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(245,240,232,.5);
}

.hero__headline {
  font-family: var(--f-display);
  font-size: clamp(3.2rem, 12vw, 11rem);
  font-weight: 700;
  line-height: .95;
  letter-spacing: -.03em;
  color: var(--c-cream);
}

.hero__counter {
  font-family: var(--f-display);
  font-size: clamp(1.8rem, 6.5vw, 6rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1;
  color: var(--c-amber-lt);
  margin-top: calc(-1 * var(--sp-2));
}

.hero__subhead {
  font-family: var(--f-body);
  font-size: var(--t-md);
  line-height: 1.55;
  color: rgba(245,240,232,.72);
  max-width: 560px;
}

.hero__byline {
  font-family: var(--f-body);
  font-size: var(--t-sm);
  color: rgba(245,240,232,.45);
  letter-spacing: .04em;
}

.hero__cue {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--f-body);
  font-size: var(--t-sm);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(245,240,232,.5);
  text-decoration: none;
  padding-top: var(--sp-4);
  transition: color .2s;
  animation: cue-float 2.4s ease-in-out infinite;
}
.hero__cue:hover { color: var(--c-cream); }

@keyframes cue-float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(6px); }
}

/* Hero staggered reveal */
[data-reveal] {
  opacity: 0;
  transform: translateY(20px);
}
[data-reveal].revealed {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .8s var(--ease-out), transform .8s var(--ease-out);
}
[data-reveal="0"].revealed { transition-delay:   0ms; }
[data-reveal="1"].revealed { transition-delay: 150ms; }
[data-reveal="2"].revealed { transition-delay: 600ms; }
[data-reveal="3"].revealed { transition-delay: 900ms; }
[data-reveal="4"].revealed { transition-delay:1050ms; }
[data-reveal="5"].revealed { transition-delay:1200ms; }

/* ── Score display (section 2) ──────────────────────────────────────────── */
.score-display {
  text-align: center;
  padding-bottom: var(--sp-12);
  border-bottom: 1px solid var(--c-rule);
  margin-bottom: var(--sp-12);
}
.score-display__num-wrap {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: .1em;
  line-height: 1;
}
.score-display__num {
  font-family: var(--f-display);
  font-size: var(--t-stat);
  font-weight: 700;
  color: var(--c-green);
  letter-spacing: -.04em;
}
.score-display__denom {
  font-family: var(--f-display);
  font-size: clamp(2rem, 5vw, 4.5rem);
  font-weight: 400;
  color: var(--c-sage);
  padding-top: .3em;
}
.score-display__label {
  font-family: var(--f-body);
  font-size: var(--t-sm);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-muted);
  margin-top: var(--sp-3);
  line-height: 1.6;
}
.score-display__label cite { color: var(--c-sage); }

/* Inline blockquote */
.inline-quote {
  border-left: 3px solid var(--c-amber);
  padding-left: var(--sp-4);
  margin-block: var(--sp-6);
  font-style: italic;
  color: var(--c-text-mid);
  font-size: var(--t-md);
  line-height: 1.6;
}
.inline-quote cite {
  display: block;
  margin-top: var(--sp-2);
  font-family: var(--f-body);
  font-style: normal;
  font-size: var(--t-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--c-muted);
}

/* ── Stat cards (section 3) ─────────────────────────────────────────────── */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-4);
  position: relative;
  z-index: 1;
}
.stat-card {
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.1);
  border-top: 2px solid var(--c-amber);
  padding: var(--sp-6) var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  text-align: center;
  align-items: center;
  overflow: hidden;
}
.stat-card__num {
  font-family: var(--f-display);
  font-size: clamp(2.8rem, 5.5vw, 5rem);
  font-weight: 700;
  color: var(--c-amber-lt);
  line-height: 1;
  letter-spacing: -.02em;
  width: 100%;
  text-align: center;
  overflow: hidden;
  text-overflow: clip;
  white-space: nowrap;
}
.stat-card__label {
  font-family: var(--f-body);
  font-size: var(--t-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(245,240,232,.55);
}
.stat-card__desc {
  font-size: var(--t-sm);
  line-height: 1.65;
  color: rgba(245,240,232,.8);
  margin-top: auto;
  padding-top: var(--sp-2);
  text-align: center;
}
.stat-card__src {
  font-size: var(--t-xs);
  letter-spacing: .06em;
  color: rgba(245,240,232,.35);
  text-transform: uppercase;
}

/* ── Photo placeholders ─────────────────────────────────────────────────── */
.photo-ph {
  position: relative;
  aspect-ratio: 4/3;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.photo-ph--wide { aspect-ratio: 16/6; }

.photo-ph__body {
  position: relative;
  z-index: 1;
  padding: var(--sp-4);
  width: 100%;
  background: linear-gradient(to top, rgba(0,0,0,.55), transparent);
  display: flex;
  flex-direction: column;
  gap: .3rem;
}
.photo-ph__place {
  font-family: var(--f-display);
  font-size: var(--t-lg);
  font-weight: 600;
  color: #fff;
  line-height: 1.1;
}
.photo-ph__loc {
  font-family: var(--f-body);
  font-size: var(--t-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
}
.photo-ph__size {
  font-family: var(--f-display);
  font-size: var(--t-xl);
  font-style: italic;
  color: var(--c-amber-lt);
  line-height: 1;
}
.photo-ph__credit {
  font-family: var(--f-body);
  font-size: var(--t-xs);
  color: rgba(255,255,255,.38);
  letter-spacing: .06em;
}

/* Specific photo colors */
.photo-ph--common {
  background:
    radial-gradient(ellipse at 30% 70%, rgba(40,90,55,.9) 0%, rgba(25,60,35,.6) 100%),
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,.03) 0px, rgba(255,255,255,.03) 1px,
      transparent 1px, transparent 12px
    ),
    #1a4025;
}
.photo-ph--nubian {
  background:
    radial-gradient(ellipse at 60% 40%, rgba(80,95,75,.8) 0%, rgba(50,60,45,.7) 100%),
    #3a4535;
}
.photo-ph--lot {
  background:
    radial-gradient(ellipse at 40% 60%, rgba(60,80,50,.85) 0%, rgba(45,55,40,.9) 100%),
    repeating-linear-gradient(
      -45deg,
      rgba(255,255,255,.02) 0px, rgba(255,255,255,.02) 1px,
      transparent 1px, transparent 18px
    ),
    #2e3828;
}
.photo-ph--nubian-wide {
  background:
    radial-gradient(ellipse at 50% 55%, rgba(70,90,60,.8) 0%, rgba(45,60,40,.85) 100%),
    #333e2d;
}

/* ── Comparison (section 4) ─────────────────────────────────────────────── */
.comparison {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--sp-4);
  align-items: start;
  margin-bottom: var(--sp-8);
}
.comparison__figure { display: flex; flex-direction: column; gap: var(--sp-3); }
.comparison__cap {
  font-size: var(--t-sm);
  line-height: 1.65;
  color: var(--c-text-mid);
}
.comparison__cap strong { color: var(--c-text); }

.comparison__divider {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-height: 200px;
}
.comparison__vs {
  font-family: var(--f-display);
  font-size: var(--t-xl);
  font-style: italic;
  font-weight: 300;
  color: var(--c-amber);
  opacity: .65;
  writing-mode: vertical-lr;
  letter-spacing: .05em;
}

.comparison__note {
  font-size: var(--t-xs);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--c-muted);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--c-rule);
}

@media (max-width: 680px) {
  .comparison {
    grid-template-columns: 1fr;
    gap: var(--sp-6);
  }
  .comparison__divider {
    flex-direction: row;
    min-height: auto;
    justify-content: flex-start;
  }
  .comparison__vs { writing-mode: horizontal-tb; }
}

/* ── Map (section 5) ────────────────────────────────────────────────────── */
.map-header { margin-bottom: var(--sp-8); }
.map-header__intro {
  font-size: var(--t-md);
  line-height: 1.6;
  color: rgba(245,240,232,.7);
  max-width: 640px;
}

.map-wrap {
  position: relative;
  border-radius: 2px;
  overflow: hidden;
  box-shadow: 0 12px 48px rgba(0,0,0,.5);
}
.map-iframe { display: block; width: 100%; height: 600px; border: none; }

/* Map placeholder */
.map-ph {
  position: relative;
  height: 520px;
  background: #0e1a12;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.map-ph__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(107,140,107,.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(107,140,107,.12) 1px, transparent 1px);
  background-size: 50px 50px;
}
.map-ph__pins {
  position: absolute;
  inset: 0;
}
.map-pin {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.map-pin__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(245,240,232,.4);
  border: 1px solid rgba(245,240,232,.3);
  position: relative;
}
.map-pin__dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 1px solid rgba(245,240,232,.15);
  animation: pin-pulse 2.5s ease-out infinite;
}
.map-pin--focus .map-pin__dot {
  background: var(--c-amber);
  border-color: var(--c-amber-lt);
  box-shadow: 0 0 12px rgba(200,105,10,.6);
}
.map-pin--focus .map-pin__dot::after { border-color: rgba(200,105,10,.3); }

.map-pin__lbl {
  font-family: var(--f-body);
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(245,240,232,.6);
  white-space: nowrap;
  background: rgba(14,26,18,.8);
  padding: 2px 6px;
  border-radius: 2px;
}
.map-pin--focus .map-pin__lbl { color: var(--c-amber-lt); }

@keyframes pin-pulse {
  0%   { transform: scale(1); opacity: .8; }
  100% { transform: scale(3); opacity: 0; }
}

.map-ph__note {
  position: relative;
  z-index: 1;
  font-size: var(--t-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(245,240,232,.25);
  padding: var(--sp-4);
}

.map-footer {
  margin-top: var(--sp-4);
  font-size: var(--t-xs);
  letter-spacing: .06em;
  color: rgba(245,240,232,.3);
}
.map-footer a { color: rgba(245,240,232,.45); text-decoration: underline; text-underline-offset: 3px; }
.map-footer a:hover { color: var(--c-amber-lt); }

/* ── Charts (section 6) ─────────────────────────────────────────────────── */
.chart-block {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: var(--sp-12);
  align-items: center;
  padding-block: var(--sp-12);
  border-top: 1px solid var(--c-rule);
}
.chart-block--flip { grid-template-columns: 1.6fr 1fr; }
.chart-block--flip .chart-block__text { order: 2; }
.chart-block--flip .chart-wrap { order: 1; }

.chart-block__title {
  font-family: var(--f-display);
  font-size: var(--t-xl);
  font-weight: 600;
  color: var(--c-green);
  letter-spacing: -.02em;
  line-height: 1.1;
  margin-bottom: var(--sp-4);
}
.chart-block p {
  font-size: var(--t-base);
  line-height: 1.75;
  color: var(--c-text-mid);
  margin-bottom: var(--sp-3);
}
.chart-block p strong { color: var(--c-text); font-weight: 500; }
.chart-block__note {
  font-size: var(--t-xs) !important;
  letter-spacing: .04em;
  color: var(--c-muted) !important;
  border-top: 1px solid var(--c-rule);
  padding-top: var(--sp-3);
  margin-top: var(--sp-2);
}
.chart-wrap { min-width: 0; }

@media (max-width: 820px) {
  .chart-block, .chart-block--flip {
    grid-template-columns: 1fr;
    gap: var(--sp-8);
  }
  .chart-block--flip .chart-block__text { order: 0; }
  .chart-block--flip .chart-wrap { order: 0; }
}

/* ── Bar chart ──────────────────────────────────────────────────────────── */
.bar-chart {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.bar-chart__row {
  display: grid;
  grid-template-columns: 160px 1fr 40px;
  align-items: center;
  gap: var(--sp-3);
}
.bar-chart__label {
  font-family: var(--f-body);
  font-size: var(--t-xs);
  color: var(--c-muted);
  letter-spacing: .03em;
  text-align: right;
}
.bar-chart__track {
  height: 28px;
  background: rgba(30,58,47,.08);
  border-radius: 2px;
  overflow: hidden;
}
.bar-chart__fill {
  height: 100%;
  width: 0;
  background: var(--c-green);
  border-radius: 2px;
  transition: width 1.1s cubic-bezier(0,.7,.3,1);
}
.bar-chart__fill.is-animated { width: var(--w); }
.bar-chart__fill--accent { background: var(--c-amber); }
.bar-chart__val {
  font-family: var(--f-display);
  font-size: var(--t-md);
  font-weight: 600;
  color: var(--c-green);
}
.bar-chart__row--accent .bar-chart__val { color: var(--c-amber); }
.bar-chart__legend {
  font-size: var(--t-xs);
  letter-spacing: .06em;
  color: var(--c-muted);
  text-align: center;
  margin-top: var(--sp-2);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--c-rule);
}

@media (max-width: 500px) {
  .bar-chart__row { grid-template-columns: 110px 1fr 36px; gap: var(--sp-2); }
}

/* ── Scatter SVG ────────────────────────────────────────────────────────── */
.scatter { width: 100%; font-family: var(--f-body); overflow: visible; }
.scatter__grid line {
  stroke: rgba(30,58,47,.1);
  stroke-width: 1;
}
.scatter__grid line:first-child { stroke: rgba(30,58,47,.2); } /* Y-axis */
.scatter__labels text {
  fill: var(--c-muted);
  font-size: .72rem;
  font-family: var(--f-body);
}
.scatter__axis-title {
  fill: var(--c-muted);
  font-size: .68rem !important;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.scatter__trend {
  stroke: var(--c-amber);
  stroke-width: 1.8;
  stroke-dasharray: 5 3;
  opacity: .85;
}
.scatter__dots circle {
  fill: var(--c-sage);
  opacity: .7;
}
.scatter__annotation {
  fill: var(--c-amber);
  font-family: var(--f-display);
  font-style: italic;
  font-size: .85rem;
}

/* ── Pull quote ─────────────────────────────────────────────────────────── */
.pullquote {
  position: relative;
  margin-block: var(--sp-12);
  padding: var(--sp-8) var(--sp-8) var(--sp-6);
  border-top: 1px solid rgba(245,240,232,.18);
  border-bottom: 1px solid rgba(245,240,232,.18);
  z-index: 1;
}
.pullquote::before {
  content: '\201C';
  font-family: var(--f-display);
  font-size: clamp(6rem, 15vw, 12rem);
  line-height: .7;
  color: rgba(107,140,107,.3);
  position: absolute;
  top: var(--sp-4);
  left: var(--sp-4);
  pointer-events: none;
}
.pullquote__text {
  font-family: var(--f-display);
  font-size: var(--t-xl);
  font-style: italic;
  font-weight: 400;
  line-height: 1.45;
  color: var(--c-cream);
  position: relative;
  z-index: 1;
}
.pullquote__src {
  display: block;
  margin-top: var(--sp-4);
  font-family: var(--f-body);
  font-size: var(--t-xs);
  letter-spacing: .09em;
  text-transform: uppercase;
  color: rgba(245,240,232,.4);
}

/* ── Informal photo ─────────────────────────────────────────────────────── */
.informal-photo {
  margin-top: var(--sp-12);
  position: relative;
  z-index: 1;
}
.informal-photo__cap {
  font-size: var(--t-xs);
  line-height: 1.65;
  color: rgba(245,240,232,.5);
  margin-top: var(--sp-3);
  font-style: italic;
  max-width: 560px;
}

/* ── Proposal (section 8) ───────────────────────────────────────────────── */
.proposal-hdr {
  max-width: 760px;
  margin-bottom: var(--sp-12);
}
.proposal-hdr__eyebrow {
  font-family: var(--f-body);
  font-size: var(--t-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-amber);
  margin-bottom: var(--sp-3);
}
.proposal-hdr__intro {
  font-size: var(--t-md);
  line-height: 1.6;
  color: var(--c-text-mid);
  margin-top: var(--sp-4);
}

.proposal-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
  margin-bottom: var(--sp-12);
}
.proposal-card {
  padding-top: var(--sp-4);
  border-top: 2px solid var(--c-amber);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.proposal-card__n {
  font-family: var(--f-display);
  font-size: clamp(3.5rem, 7vw, 6rem);
  font-weight: 300;
  color: rgba(30,58,47,.12);
  line-height: 1;
  letter-spacing: -.02em;
}
.proposal-card__title {
  font-family: var(--f-display);
  font-size: var(--t-lg);
  font-weight: 600;
  color: var(--c-green);
  line-height: 1.2;
  letter-spacing: -.01em;
}
.proposal-card__desc {
  font-size: var(--t-base);
  line-height: 1.75;
  color: var(--c-text-mid);
}

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

.proposal-photo { }
.proposal-photo__cap {
  font-size: var(--t-xs);
  line-height: 1.65;
  color: var(--c-muted);
  margin-top: var(--sp-3);
  font-style: italic;
  max-width: 560px;
}

/* ── Org cards (section 9) ──────────────────────────────────────────────── */
.orgs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
  margin-top: var(--sp-8);
  position: relative;
  z-index: 1;
}
.org-card {
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.09);
  padding: var(--sp-6) var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  position: relative;
}
.org-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--c-amber), transparent);
}
.org-card__name {
  font-family: var(--f-display);
  font-size: var(--t-lg);
  font-weight: 600;
  color: var(--c-cream);
  line-height: 1.1;
}
.org-card__loc {
  font-size: var(--t-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(245,240,232,.4);
}
.org-card__desc {
  font-size: var(--t-sm);
  line-height: 1.65;
  color: rgba(245,240,232,.72);
  flex: 1;
  padding-top: var(--sp-2);
}
.org-card__link {
  font-family: var(--f-body);
  font-size: var(--t-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--c-amber-lt);
  text-decoration: none;
  padding-top: var(--sp-2);
  transition: color .2s;
}
.org-card__link:hover { color: var(--c-cream); }

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

/* ── Sources (section 10) ───────────────────────────────────────────────── */
.sources-note {
  font-size: var(--t-base);
  line-height: 1.7;
  color: var(--c-muted);
  margin-bottom: var(--sp-8);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--c-rule);
}
.sources-list {
  list-style: decimal;
  padding-left: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  position: relative;
  z-index: 1;
}
.sources-list__item {
  font-size: var(--t-sm);
  line-height: 1.75;
  color: var(--c-text-mid);
}
.sources-list__item em { color: var(--c-text); font-style: italic; }
.src-au { font-weight: 500; color: var(--c-text); }
.src-yr { color: var(--c-muted); }

/* ── Footer ─────────────────────────────────────────────────────────────── */
.site-footer {
  background: var(--c-dark-alt);
  padding-block: var(--sp-12);
  text-align: center;
}
.site-footer__title {
  font-family: var(--f-display);
  font-size: var(--t-xl);
  font-style: italic;
  color: var(--c-cream);
  margin-bottom: var(--sp-2);
}
.site-footer__meta {
  font-size: var(--t-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(245,240,232,.35);
  margin-bottom: var(--sp-2);
}
.site-footer__disc {
  font-size: var(--t-xs);
  color: rgba(245,240,232,.2);
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  :root { --sec-y: clamp(4rem, 8vw, 7rem); }
}

@media (max-width: 640px) {
  :root { --sec-y: 3.5rem; }

  .score-display { padding-bottom: var(--sp-8); margin-bottom: var(--sp-8); }

  .bar-chart__row {
    grid-template-columns: 1fr;
    gap: var(--sp-1);
  }
  .bar-chart__label { text-align: left; }
  .bar-chart__val { font-size: var(--t-base); }

  .pullquote { padding: var(--sp-6) var(--sp-3) var(--sp-4); }
  .pullquote::before { display: none; }

  .proposal-hdr { margin-bottom: var(--sp-8); }

  .site-nav__links { gap: var(--sp-8); }
}

/* ── Print ──────────────────────────────────────────────────────────────── */
@media print {
  .site-nav, .hero__cue { display: none; }
  .section { break-inside: avoid; }
  [data-animate] { opacity: 1; transform: none; }
}
