/* African Renaissance Trust — Continental Maps Vault
   Design language: warm pan-African earth tones, policy-grade typography,
   generous whitespace, donor-presentation surface. */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@300;400;500;600;700&display=swap');

:root{
  /* Palette */
  --ink:        #1B1410;
  --ink-soft:   #2B201A;
  --muted:      #6B5E54;
  --faint:      #A89A8E;
  --line:       #E6DCCF;
  --line-soft:  #F1E9DC;
  --cream:      #F8F1E3;
  --cream-warm: #F4E9D8;
  --paper:      #FBF6EB;

  /* Brand accents — earth + horizon */
  --terra:      #B8531C;   /* primary accent — terracotta */
  --terra-deep: #8A3E15;
  --savanna:    #C89B3C;   /* gold ochre */
  --acacia:     #4A6B3A;   /* olive green */
  --indigo:     #2E4A6B;   /* night sky */
  --ruby:       #8B2727;   /* deep red */

  /* Sequential scale (single-hue, terracotta family) */
  --seq-0: #F4E9D8;
  --seq-1: #EAC9A0;
  --seq-2: #DEA970;
  --seq-3: #C98148;
  --seq-4: #A75A22;
  --seq-5: #6E3711;

  /* Type */
  --font-display: "Zodiak", Georgia, "Times New Roman", serif;
  --font-body:    "Satoshi", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono:    ui-monospace, "SF Mono", Menlo, monospace;

  --radius: 4px;
  --radius-lg: 10px;
  --shadow-1: 0 1px 2px rgba(27,20,16,.04), 0 2px 8px rgba(27,20,16,.05);
  --shadow-2: 0 4px 24px rgba(27,20,16,.08), 0 1px 3px rgba(27,20,16,.06);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--paper);
  font-variant-numeric: tabular-nums lining-nums;
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4{font-family:var(--font-display); font-weight:500; letter-spacing:-0.01em; line-height:1.12; margin:0}
p{margin:0}
a{color:inherit; text-decoration:none}
button{font-family:inherit}

/* HEADER — styled to match the main ART site header */
.site-header{
  display:flex; align-items:center; justify-content:space-between;
  padding: 0 clamp(20px, 4vw, 56px);
  height: 72px;
  border-bottom:1px solid #E0D5C8;
  background: #FAF7F1;
  position: sticky; top:0; z-index:50; backdrop-filter: blur(6px);
}
.brand{display:flex; align-items:center; gap:12px; color:#5A1A2B; text-decoration:none}
.brand-mark{height:36px; width:auto; max-width:240px; flex-shrink:0; object-fit:contain; display:block}
.brand-text{display:flex; flex-direction:column; line-height:1.05}
.brand-name{
  font-family:"Fraunces", Georgia, "Times New Roman", serif;
  font-weight:600; font-size:17px; color:#5A1A2B;
  letter-spacing:-0.005em;
}
.brand-tag{
  font-family:"Source Sans 3", "Segoe UI", sans-serif;
  font-size:11px; color:#8A6D5A;
  letter-spacing:0.08em; text-transform:uppercase; margin-top:2px;
}
.site-nav{display:flex; gap:28px; align-items:center}
.site-nav a{
  font-family:"Source Sans 3","Segoe UI",sans-serif;
  font-size:14px; font-weight:500;
  color:#2B1A1D; transition: color .15s; text-decoration:none;
}
.site-nav a:hover{color:#D4A52A}
@media (max-width: 640px){
  .site-nav{display:none}
}

/* HERO */
.hero{
  position:relative;
  padding: clamp(48px, 8vw, 96px) clamp(20px, 4vw, 56px) clamp(28px, 4vw, 48px);
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-inner{position:relative; z-index:2; max-width: 1100px}
.eyebrow{
  display:inline-block;
  font-size:11.5px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--terra); font-weight:600; margin-bottom:18px;
}
.hero h1{
  font-size: clamp(38px, 5.8vw, 72px);
  font-weight:500; color:var(--ink);
  letter-spacing:-0.025em;
}
.lede{
  max-width: 720px;
  margin-top: 22px;
  font-size: clamp(16px, 1.4vw, 19px);
  line-height:1.55;
  color:var(--ink-soft);
}
.hero-stats{
  display:grid; grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 18px;
  margin-top: 44px; max-width: 720px;
}
.hero-stats > div{
  padding: 14px 18px;
  border-left: 2px solid var(--terra);
  background: rgba(184,83,28,0.04);
}
.hero-stats strong{
  display:block;
  font-family:var(--font-display); font-size:30px; font-weight:500;
  color:var(--ink); letter-spacing:-0.02em;
}
.hero-stats span{
  display:block; font-size:12px; color:var(--muted);
  letter-spacing:0.04em; margin-top:2px;
}
@media (max-width: 720px){
  .hero-stats{grid-template-columns: repeat(2,1fr)}
}
.hero-pattern{
  position:absolute; inset:0; width:100%; height:100%;
  color: var(--terra); opacity:0.6; pointer-events:none; z-index:1;
  mask-image: linear-gradient(to right, transparent 0%, black 60%, black 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 60%, black 100%);
}

/* VAULT */
.vault{
  padding: 36px clamp(20px, 4vw, 56px) 80px;
}
.vault-controls{
  display:flex; flex-direction:column; gap:18px;
  padding: 18px 22px;
  background: white;
  border:1px solid var(--line);
  border-radius: var(--radius-lg);
  margin-bottom: 26px;
  box-shadow: var(--shadow-1);
}
.layer-tabs{
  display:flex; flex-wrap:wrap; gap:6px;
  border-bottom:1px solid var(--line-soft);
  padding-bottom:14px;
}
.layer-tab{
  display:flex; align-items:center; gap:10px;
  padding: 10px 16px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius);
  font-size: 14px; font-weight: 500;
  color: var(--muted);
  cursor:pointer;
  transition: all .15s;
}
.layer-tab:hover{color: var(--ink); background: var(--line-soft)}
.layer-tab.active{
  color: var(--terra-deep);
  background: rgba(184,83,28,0.08);
  border-color: rgba(184,83,28,0.18);
}
.layer-tab .tab-icon{
  font-size: 17px; line-height:1;
}
.indicator-row{display:flex; align-items:center; gap:18px; flex-wrap:wrap}
.indicator-label{
  font-size:11.5px; letter-spacing:0.12em; text-transform:uppercase;
  color: var(--faint); font-weight:600;
}
.indicator-chips{display:flex; flex-wrap:wrap; gap:6px}
.indicator-chip{
  padding: 7px 13px;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 13px; color: var(--ink-soft);
  cursor:pointer; transition: all .15s;
}
.indicator-chip:hover{border-color: var(--terra); color: var(--terra)}
.indicator-chip.active{
  background: var(--ink);
  border-color: var(--ink);
  color: var(--cream-warm);
}

/* MAP STAGE */
.map-stage{
  display:grid;
  grid-template-columns: 280px 1fr 320px;
  gap:20px;
  align-items:stretch;
}
@media (max-width: 1180px){
  .map-stage{grid-template-columns: 1fr; }
}

/* LEGEND PANEL */
.legend-panel{
  background: white;
  border:1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 22px;
  box-shadow: var(--shadow-1);
  display:flex; flex-direction:column; gap:18px;
}
.legend-head{display:flex; gap:14px; align-items:flex-start}
.layer-icon{
  font-size: 26px; line-height: 1;
  color: var(--terra);
  flex-shrink:0;
}
.legend-head h2{font-size: 19px; color:var(--ink)}
.legend-head p{font-size:13px; color:var(--muted); margin-top:6px; line-height:1.45}
.indicator-meta{
  padding: 12px 14px;
  background: var(--line-soft);
  border-radius: var(--radius);
}
.indicator-meta h3{
  font-family:var(--font-body);
  font-size: 14px; font-weight: 600;
  color: var(--ink);
}
.indicator-meta p{
  font-size:11.5px; color:var(--muted);
  margin-top:4px; letter-spacing:0.02em;
}

.legend{display:flex; flex-direction:column; gap:6px}
.legend-bar{
  height: 12px; border-radius: 2px;
  background: linear-gradient(to right, var(--seq-0), var(--seq-1), var(--seq-2), var(--seq-3), var(--seq-4), var(--seq-5));
}
.legend-ticks{
  display:flex; justify-content:space-between;
  font-size:11px; color:var(--muted); font-variant-numeric: tabular-nums;
}
.legend-note{
  font-size:12px; color:var(--muted); font-style:italic;
  border-left: 2px solid var(--line);
  padding-left: 10px;
}

.ranks{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
.rank-block h4{
  font-family:var(--font-body); font-size:11px; letter-spacing:0.1em;
  text-transform:uppercase; color: var(--faint); font-weight:600;
  margin-bottom:8px;
}
.rank-block ol{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:5px;
}
.rank-block li{
  display:flex; justify-content:space-between; gap:6px; align-items:baseline;
  font-size:11.5px; color:var(--ink-soft);
  padding: 4px 0;
  border-bottom:1px solid var(--line-soft);
  cursor:pointer; transition: color .12s;
}
.rank-block li:hover{color:var(--terra)}
.rank-block li:last-child{border-bottom:none}
.rank-name{
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  flex:1; min-width:0;
}
.rank-val{color: var(--muted); font-variant-numeric: tabular-nums; font-size:11px; flex-shrink:0}

.region-bars h4{
  font-family:var(--font-body); font-size:11px; letter-spacing:0.1em;
  text-transform:uppercase; color: var(--faint); font-weight:600;
  margin-bottom:10px;
}
.bars{display:flex; flex-direction:column; gap:8px}
.bar-row{display:grid; grid-template-columns: 72px 1fr 50px; gap:8px; align-items:center; font-size:12px}
.bar-name{color:var(--ink-soft)}
.bar-track{height:6px; background:var(--line-soft); border-radius:2px; overflow:hidden}
.bar-fill{height:100%; background:var(--terra); border-radius:2px; transition: width .4s ease}
.bar-val{color:var(--muted); text-align:right; font-variant-numeric: tabular-nums}

.legend-actions{display:flex; gap:8px; margin-top:auto; padding-top:6px}
.btn-ghost{
  display:inline-flex; align-items:center; gap:6px;
  padding: 7px 12px;
  background: transparent;
  border:1px solid var(--line);
  border-radius: var(--radius);
  font-size:12px; color:var(--ink-soft);
  cursor:pointer; transition: all .15s;
}
.btn-ghost:hover{border-color: var(--terra); color: var(--terra)}

/* MAP */
.map-wrapper{
  position:relative;
  background: white;
  border:1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 16px;
  box-shadow: var(--shadow-1);
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
#map{
  width:100%;
  height: auto;
  display:block;
  max-width: 100%;
}
.country{
  stroke: white;
  stroke-width: 0.5;
  cursor:pointer;
  transition: opacity .15s, stroke-width .15s;
}
.country.no-data{
  fill: #EFE6D5;
  stroke: #D8C9B0;
}
.country:hover{
  stroke: var(--ink);
  stroke-width: 1.4;
  opacity:0.92;
}
.country.selected{
  stroke: var(--ink);
  stroke-width: 2;
}
.country-label{
  font-size: 10px; fill: var(--ink-soft);
  pointer-events:none;
  font-family: var(--font-body);
  font-weight: 500;
  paint-order: stroke;
  stroke: rgba(255,255,255,0.85);
  stroke-width: 2.5px;
  stroke-linejoin: round;
}
.tooltip{
  position:absolute;
  pointer-events:none;
  background: var(--ink);
  color: var(--cream-warm);
  padding: 9px 13px;
  border-radius: var(--radius);
  font-size: 12.5px;
  white-space: nowrap;
  opacity:0;
  transition: opacity .12s;
  z-index: 20;
  box-shadow: var(--shadow-2);
}
.tooltip strong{display:block; color:white; font-weight:600; margin-bottom:2px}
.tooltip .tt-val{color: var(--savanna); font-weight:500}
.tooltip .tt-nodata{color: var(--faint); font-style:italic; font-size:11px}
.map-credit{
  position:absolute; bottom:10px; right:14px;
  font-size:10px; color: var(--faint); letter-spacing:0.04em;
}

/* DETAIL PANEL */
.detail-panel{
  background: white;
  border:1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 22px;
  box-shadow: var(--shadow-1);
  min-height: 540px;
}
.detail-empty{
  text-align:center;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:100%; min-height: 400px;
  color: var(--muted);
}
.detail-empty-icon{color: var(--line); margin-bottom: 16px}
.detail-empty h3{font-size:18px; color: var(--ink-soft); margin-bottom: 8px}
.detail-empty p{font-size:13px; line-height:1.55; max-width: 240px}

.detail-content{display:flex; flex-direction:column; gap:18px}
.detail-flag{
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; letter-spacing:0.1em; text-transform:uppercase;
  color: var(--faint); font-weight:600;
}
.detail-flag .iso-pill{
  padding: 3px 8px;
  background: var(--ink);
  color: var(--cream-warm);
  border-radius: 999px;
  font-size: 10px; letter-spacing:0.08em;
}
.detail-content h3.country-name{
  font-family: var(--font-display);
  font-size: 26px; font-weight:500;
  color:var(--ink);
  margin-top:4px;
}
.detail-region{
  font-size:12px; color:var(--muted);
  margin-top:2px;
}
.detail-headline{
  padding: 14px 16px;
  background: linear-gradient(135deg, rgba(184,83,28,0.06), rgba(184,83,28,0.02));
  border-left: 3px solid var(--terra);
  border-radius: var(--radius);
}
.detail-headline .dh-label{
  font-size:11px; color:var(--terra-deep);
  letter-spacing:0.06em; font-weight:600;
  text-transform:uppercase;
}
.detail-headline .dh-value{
  font-family: var(--font-display);
  font-size: 32px; font-weight:500;
  color: var(--ink);
  letter-spacing:-0.02em;
  margin-top: 6px;
}
.detail-headline .dh-rank{
  font-size:12px; color:var(--muted);
  margin-top:4px;
}

.metric-grid{
  display:grid; grid-template-columns: 1fr;
  gap: 10px;
}
.metric-card{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  padding: 10px 12px;
  background: var(--paper);
  border-radius: var(--radius);
  border-left: 2px solid var(--line);
}
.metric-card.in-theme{border-left-color: var(--terra)}
.metric-card .mc-label{
  font-size: 12px;
  color: var(--ink-soft);
  line-height:1.3;
}
.metric-card .mc-sub{
  font-size:10.5px; color: var(--faint);
  margin-top:2px;
}
.metric-card .mc-val{
  font-family: var(--font-display);
  font-size: 18px; font-weight: 500;
  color: var(--ink);
  text-align:right;
  white-space:nowrap;
}
.metric-card .mc-val.nodata{
  color: var(--faint); font-size:11px;
  font-family: var(--font-body); font-style:italic;
}

.detail-sources{
  font-size:11px; color:var(--faint);
  line-height: 1.5;
  padding-top: 10px;
  border-top: 1px solid var(--line-soft);
}

/* METHODOLOGY + ABOUT */
.methodology, .about{
  padding: clamp(60px, 8vw, 110px) clamp(20px, 4vw, 56px);
  border-top:1px solid var(--line);
}
.methodology{background: white}
.about{background: var(--paper)}
.container{max-width: 1180px; margin:0 auto}
.methodology h2, .about h2{
  font-size: clamp(28px, 3.4vw, 42px);
  margin-top: 14px; margin-bottom: 36px;
  max-width: 720px;
  font-weight: 500;
}
.meth-grid{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 28px 36px;
}
.meth-grid h3{
  font-family: var(--font-body);
  font-size: 14px; font-weight:600;
  color: var(--terra-deep);
  letter-spacing:0.03em;
  margin-bottom: 10px;
}
.meth-grid p, .meth-grid ul{
  font-size:14px; color: var(--ink-soft);
  line-height:1.65;
}
.meth-grid ul{padding-left:18px; margin:0}
.meth-grid ul li{margin-bottom:6px}
.meth-grid em{font-style:italic; color: var(--terra-deep)}
.about p{
  font-size:15px; color: var(--ink-soft);
  line-height: 1.7; max-width: 760px;
  margin-bottom: 18px;
}
.footer-line{
  font-size:12px; color: var(--muted);
  border-top:1px solid var(--line);
  padding-top: 22px;
  margin-top: 32px;
}

/* No-data legend chip */
.nodata-key{
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; color:var(--muted);
  margin-top:6px;
}
.nodata-key .swatch{
  display:inline-block; width:12px; height:12px;
  background:#EFE6D5; border:1px solid #D8C9B0; border-radius:2px;
}

/* Print/screenshot helper */
@media (max-width: 760px){
  .ranks{grid-template-columns: 1fr 1fr}
  .map-wrapper{min-height: 380px}
  #map{min-height: 380px}
  .legend-panel, .detail-panel{min-height: auto}
}

/* ============================================================
   Expansion: categorical (parliaments) + overlay (corridors/markets)
   ============================================================ */

/* Categorical legend (parliaments) */
.cat-legend{display:flex; flex-direction:column; gap:8px; margin-top:4px}
.cat-row{display:flex; align-items:center; gap:10px; font-size:13px; color:var(--ink); line-height:1.35}
.cat-swatch{
  width:22px; height:12px; border-radius:3px; flex-shrink:0;
  box-shadow: 0 0 0 1px rgba(0,0,0,.06) inset;
}
.cat-line{
  width:22px; height:3px; border-radius:2px; flex-shrink:0;
  display:inline-block;
}
.cat-line.inline{margin-right:6px; vertical-align:middle}
.cat-dot{
  width:10px; height:10px; border-radius:50%;
  background:#B8531C; border:2px solid #FBF6EB;
  box-shadow:0 0 0 1px rgba(0,0,0,.08);
  flex-shrink:0;
}
.overlay-legend{max-height:280px; overflow:auto; padding-right:4px}
.overlay-legend .cat-row{font-size:12px}
.overlay-key{display:flex; flex-direction:column; gap:6px}
.overlay-hint{font-size:12px; color:var(--muted); line-height:1.45; margin-top:4px}

/* Stacked bar (parliaments by region) */
.stacked-track{
  height:8px; display:flex; gap:0; border-radius:3px; overflow:hidden;
  background:transparent;
}
.stacked-track > span{display:inline-block; height:100%}
.region-bars-hint{
  font-size:11px; color:var(--muted); margin-top:8px; line-height:1.4;
  font-style:italic;
}

/* SVG overlay layers */
.g-overlay .corridor{
  pointer-events: stroke;
  transition: stroke-width .15s ease, opacity .15s ease;
}
.g-overlay .corridor:hover{ stroke-width: 4.2px; }
.g-overlay .market{
  transition: r .15s ease, fill .15s ease;
}
.g-overlay .market:hover{ r: 7; }

/* Tooltip note line (for parliaments/markets/corridors) */
.tt-note{
  display:block; margin-top:6px; font-size:11.5px; color:var(--muted);
  max-width:240px; line-height:1.4;
}

/* ============================================================
   EXPANSION 2 — bubble, ratification, vault submenu, stories
   ============================================================ */

/* Bubble (proportional symbol) legend */
.bubble-legend{
  display:flex; align-items:flex-end; padding:6px 0 2px;
}
.bubble-legend svg{ overflow:visible }

/* SVG bubble layer */
.g-bubbles .bubble{
  transition: fill-opacity .15s ease;
  pointer-events: all;
}
.g-bubbles .bubble:hover{ fill-opacity: 0.82; }
.g-bubbles .bubble-lbl{
  pointer-events: none;
  letter-spacing: 0.02em;
}

/* Renaissance Vault submenu (top nav) */
.site-nav{position:relative}
.nav-group{
  position:relative; display:inline-block;
}
.nav-group > .nav-trigger{
  font-family:"Source Sans 3","Segoe UI",sans-serif;
  font-size:14px; font-weight:500; color:#2B1A1D;
  display:inline-flex; align-items:center; gap:6px;
  cursor:pointer; background:none; border:none; padding:0;
}
.nav-group > .nav-trigger:hover{ color: #D4A52A }
.nav-group > .nav-trigger::after{
  content:"\25BE"; font-size:10px; opacity:.6; transform:translateY(1px);
}
.nav-submenu{
  position:absolute; top: calc(100% + 14px); right: 0;
  min-width: 320px;
  background: var(--paper);
  border:1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
  box-shadow: 0 18px 40px -18px rgba(40, 22, 8, .22),
              0 2px 6px -2px rgba(40, 22, 8, .08);
  display:none;
  z-index: 50;
}
.nav-submenu.open{ display:block }
.nav-submenu .nav-sub-head{
  font-family: var(--font-display);
  font-size: 11.5px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted); margin: 4px 6px 10px;
}
.nav-submenu ul{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns: 1fr 1fr; gap:2px 12px;
}
.nav-submenu a{
  display:flex; align-items:center; gap:8px;
  padding: 7px 8px; border-radius: 7px;
  font-size: 13px; color: var(--ink-soft);
  text-decoration: none;
  transition: background .14s, color .14s;
}
.nav-submenu a:hover{ background: #F5EFE6; color: #5A1A2B }
.nav-submenu .sub-icon{
  width:20px; text-align:center; color: #D4A52A;
  font-size: 14px;
}
@media (max-width: 720px){
  .nav-submenu{ right:auto; left:0; min-width: 260px }
  .nav-submenu ul{ grid-template-columns: 1fr }
}

/* ============================================================
   STORY PAGES (stories/*.html)
   ============================================================ */
body.story-page{ background: var(--paper) }
.story-hero{
  background: linear-gradient(180deg, #1B1410 0%, #2B201A 100%);
  color: var(--cream);
  padding: 96px 32px 72px;
  position:relative; overflow:hidden;
}
.story-hero .container{
  max-width: 920px; margin: 0 auto;
}
.story-hero .eyebrow{
  display:inline-block;
  font-family: var(--font-body); font-size: 11.5px;
  letter-spacing: .18em; text-transform: uppercase;
  color: rgba(248, 241, 227, 0.7);
  padding: 5px 11px;
  border:1px solid rgba(248, 241, 227, 0.22);
  border-radius: 999px;
  margin-bottom: 22px;
}
.story-hero h1{
  font-family: var(--font-display);
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.06; letter-spacing: -0.018em;
  font-weight: 500;
  margin: 0 0 18px;
}
.story-hero .lede{
  font-size: 17px; line-height: 1.6;
  color: rgba(248, 241, 227, 0.86);
  max-width: 700px;
  margin: 0;
}
.story-hero .meta{
  margin-top: 26px;
  font-size: 12.5px;
  color: rgba(248, 241, 227, 0.6);
  letter-spacing: .04em;
}
.story-hero .meta a{ color: var(--savanna); text-decoration: none }
.story-hero .meta a:hover{ text-decoration: underline }

.story-body{
  max-width: 760px; margin: 0 auto;
  padding: 64px 32px 32px;
  font-family: var(--font-body);
  color: var(--ink-soft); font-size: 17px; line-height: 1.7;
}
.story-body h2{
  font-family: var(--font-display);
  font-size: 28px; font-weight: 500;
  color: var(--ink);
  margin: 48px 0 14px;
  letter-spacing: -0.012em;
}
.story-body h3{
  font-family: var(--font-body);
  font-size: 13px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--terra-deep); font-weight: 700;
  margin: 36px 0 10px;
}
.story-body p{ margin: 0 0 18px }
.story-body .pullquote{
  border-left: 3px solid var(--terra);
  padding: 6px 0 6px 22px;
  margin: 28px 0;
  font-family: var(--font-display);
  font-size: 22px; font-style: italic;
  line-height: 1.45;
  color: var(--ink);
}
.story-body ul{ padding-left: 22px }
.story-body li{ margin: 6px 0 }
.story-body .stat-row{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 18px;
  background: var(--line-soft);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 24px;
  margin: 28px 0;
}
.story-body .stat-row .stat-val{
  font-family: var(--font-display);
  font-size: 30px; font-weight: 500;
  color: var(--terra-deep); line-height: 1.05;
  letter-spacing: -0.01em;
}
.story-body .stat-row .stat-lbl{
  display:block; margin-top: 6px;
  font-size: 12.5px; color: var(--muted); line-height: 1.4;
}

/* Map embed (iframe) container inside a story */
.story-embed{
  margin: 36px auto 16px;
  max-width: 1180px;
  padding: 0 16px;
}
.story-embed iframe{
  width: 100%; height: 820px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--cream);
  box-shadow: 0 10px 30px -14px rgba(40, 22, 8, 0.18);
}
.story-embed .embed-caption{
  margin-top: 10px;
  font-size: 12.5px; color: var(--muted);
  text-align: center;
  font-style: italic;
}
@media (max-width: 720px){
  .story-embed iframe{ height: 680px }
  .story-body{ font-size: 16px; padding: 48px 22px 24px }
}

.story-footer{
  max-width: 760px; margin: 16px auto 60px;
  padding: 32px;
  border-top: 1px solid var(--line);
  font-size: 13px; line-height: 1.55; color: var(--muted);
}
.story-footer .sources strong{ color: var(--ink-soft) }
.story-footer .sources a{
  color: var(--terra-deep); text-decoration: none;
  border-bottom: 1px dotted var(--terra);
}
.story-footer .sources a:hover{ color: var(--terra) }
.story-footer .back{
  display:inline-block; margin-top: 22px;
  font-size: 13px; font-weight: 500;
  color: var(--ink-soft); text-decoration: none;
}
.story-footer .back:hover{ color: var(--terra-deep) }

/* Stories index page tiles */
.stories-grid{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
  max-width: 1180px;
  margin: 36px auto 72px;
  padding: 0 32px;
}
.story-tile{
  display:block;
  background: var(--cream-warm);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 28px 26px;
  text-decoration: none;
  color: var(--ink);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s;
}
.story-tile:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 36px -22px rgba(40, 22, 8, 0.28);
  border-color: var(--terra);
}
.story-tile .tile-icon{
  font-size: 26px; color: var(--terra);
  margin-bottom: 14px; display:block;
}
.story-tile h3{
  font-family: var(--font-display);
  font-size: 22px; font-weight: 500;
  margin: 0 0 10px;
  letter-spacing: -0.01em;
}
.story-tile p{
  font-size: 14px; line-height: 1.55;
  color: var(--muted); margin: 0;
}
.story-tile .tile-arrow{
  display:inline-block; margin-top: 14px;
  font-size: 12.5px; color: var(--terra-deep);
  letter-spacing: .08em; text-transform: uppercase;
  font-weight: 600;
}
