/* The Field's Edge — Impact Dashboard. Mobile-first. */

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--tfe-cream);
  color: var(--tfe-black);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body { overflow-x: hidden; }
img { max-width: 100%; display: block; }

.page {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 20px 64px;
  position: relative;
}
.page::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(50,68,70,0.03) 1px, transparent 1px);
  background-size: 4px 4px;
  z-index: 0;
}
section { position: relative; z-index: 1; }
a { color: inherit; text-decoration: none; }

/* ============================================================
   SECTION TYPOGRAPHY (shared)
   ============================================================ */
.section-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.section-title {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(34px, 9.5vw, 54px);
  line-height: 1.0;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 16px;
  text-wrap: balance;
}
.section-lede {
  font-family: var(--font-body);
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--tfe-slate);
  max-width: 580px;
  margin-bottom: 28px;
  text-wrap: pretty;
}
.section-lede strong, .section-lede em {
  color: var(--tfe-black);
  font-weight: 600;
}
.section-lede em { font-style: italic; font-weight: 400; }

/* ============================================================
   MASTHEAD — TFE 10 yrs · 2 programs
   ============================================================ */
.masthead {
  padding: 32px 0 24px;
  text-align: center;
  border-bottom: 1px solid var(--divider);
}
.masthead-logo {
  margin: 0 auto;
  width: clamp(220px, 60%, 320px);
  height: auto;
}
.masthead-tag {
  font-family: var(--font-subheading);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--tfe-sage);
  margin-top: 12px;
  margin-bottom: 18px;
}
.masthead-programs {
  display: inline-flex;
  align-items: stretch;
  gap: 0;
  background: var(--tfe-bone);
  padding: 18px 36px;
  border-radius: 14px;
  border: 1px solid var(--divider);
}
.mp {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 0 22px;
}
.mp-num {
  font-family: var(--font-heading);
  font-size: 64px;
  line-height: 0.95;
  color: var(--tfe-black);
  letter-spacing: 0.01em;
}
.mp-unit {
  font-family: var(--font-subheading);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--tfe-sage);
  margin-left: 6px;
  vertical-align: 30%;
}
.mp-label {
  font-family: var(--font-subheading);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--tfe-slate);
  margin-top: 4px;
}
.mp-div {
  width: 1px;
  background: var(--divider);
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  padding: 36px 0 40px;
  text-align: center;
}
.hero-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 18px;
}
.hero-title {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(40px, 12vw, 76px);
  line-height: 1.0;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 24px;
  text-wrap: balance;
}
.hero-lede {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--tfe-slate);
  max-width: 540px;
  margin: 0 auto 32px;
  text-wrap: pretty;
}
.hero-lede strong { color: var(--tfe-black); font-weight: 600; }

.hero-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 24px 0;
  border-top: 2px solid var(--divider);
  border-bottom: 2px solid var(--divider);
}
.hero-stat {
  text-align: center;
  padding: 0 4px;
  min-width: 0;
}
.hero-stat:not(:last-child) {
  border-right: 1px solid var(--divider);
}
.hero-stat-num {
  font-family: var(--font-heading);
  font-size: clamp(22px, 6.5vw, 42px);
  line-height: 0.95;
  letter-spacing: 0.01em;
  color: var(--tfe-slate);
  font-feature-settings: "tnum" 1;
  word-break: keep-all;
}
.hero-stat--hard .hero-stat-num { color: var(--accent); }
.hero-stat--hard .hero-stat-label {
  color: var(--accent);
  opacity: 0.85;
}
.hero-stat-label {
  font-family: var(--font-subheading);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tfe-sage);
  margin-top: 10px;
  line-height: 1.35;
}
.hero-stat-sub {
  font-family: var(--font-subheading);
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: 6px;
  line-height: 1.3;
  opacity: 0.85;
}
.hero-stats-foot {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.65;
  color: var(--tfe-slate);
  margin-top: 24px;
  padding: 20px 22px;
  background: var(--tfe-bone);
  border-radius: 8px;
  border-left: 3px solid var(--accent);
  text-wrap: pretty;
}
.hero-stats-foot strong { color: var(--tfe-black); font-weight: 600; }
.hero-stats-foot em { color: var(--accent); font-style: italic; font-weight: 500; }

/* ============================================================
   VILLAGE — image hero, moved up
   ============================================================ */
.village {
  padding: 56px 0 32px;
  position: relative;
}

.village-hero {
  position: relative;
  margin: 0 -20px 28px;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: var(--tfe-slate);
}
.village-hero img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.village-hero-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 28px 24px 26px;
  background: linear-gradient(to top, rgba(20,26,28,0.85) 0%, rgba(20,26,28,0.5) 40%, rgba(20,26,28,0.05) 75%, transparent 100%);
  color: var(--tfe-cream);
}
.village-hero-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--tfe-bone);
  margin-bottom: 12px;
}
.village-hero-title {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(40px, 12vw, 68px);
  line-height: 0.95;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-cream);
  text-wrap: balance;
  text-shadow: 0 2px 16px rgba(0,0,0,0.5);
}
.village-hero-title .em { color: #d4d18f; }

.village-lede {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--tfe-slate);
  margin-bottom: 28px;
  max-width: 580px;
  text-wrap: pretty;
}
.village-lede strong { color: var(--tfe-black); font-weight: 600; }

.village-headline {
  background: var(--tfe-slate);
  color: var(--tfe-cream);
  border-radius: 14px;
  padding: 28px 24px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 22px;
  align-items: center;
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 16px 40px -12px rgba(50,68,70,0.3);
}
.village-headline::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 100%, rgba(114,126,78,0.3), transparent 60%);
  pointer-events: none;
}
.village-headline-num {
  font-family: var(--font-heading);
  font-size: clamp(96px, 26vw, 156px);
  line-height: 0.85;
  letter-spacing: 0.01em;
  color: var(--tfe-cream);
  font-feature-settings: "tnum" 1;
  position: relative;
  z-index: 1;
}
.village-headline-text {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.village-headline-text strong {
  font-family: var(--font-subheading);
  font-size: 15px;
  font-weight: 600;
  color: var(--tfe-cream);
  letter-spacing: 0.02em;
  line-height: 1.3;
}
.village-headline-text span {
  font-family: var(--font-body);
  font-size: 13px;
  color: rgba(229,226,217,0.8);
  font-style: italic;
  line-height: 1.4;
}

.village-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 24px;
}
.village-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px 16px;
}
.village-card--hard {
  background: var(--tfe-bone);
  border-color: var(--tfe-sage);
}
.village-card-num {
  font-family: var(--font-heading);
  font-size: clamp(40px, 12vw, 56px);
  line-height: 1;
  color: var(--accent);
  letter-spacing: 0.02em;
}
.village-card--hard .village-card-num { color: var(--tfe-slate); }
.village-card-num-unit {
  font-size: 0.45em;
  font-family: var(--font-subheading);
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-left: 4px;
  color: var(--tfe-sage);
  vertical-align: 18%;
}
.village-card-label {
  font-family: var(--font-subheading);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--tfe-black);
  margin-top: 8px;
  line-height: 1.4;
}

/* NEIGHBORHOODS */
.neighborhoods {
  background: var(--tfe-bone);
  border-radius: 12px;
  padding: 24px 22px 22px;
  margin-bottom: 18px;
}
.neighborhoods-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}
.neighborhoods-title {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(26px, 7vw, 34px);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 14px;
  line-height: 1.05;
}
.neighborhoods-body {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--tfe-slate);
  margin-bottom: 18px;
  text-wrap: pretty;
}
.neighborhoods-body strong { color: var(--tfe-black); font-weight: 600; }

/* VILLAGE RENDERING */
.village-render {
  margin: 0;
  border-radius: 10px;
  overflow: hidden;
  background: var(--tfe-slate);
  box-shadow: 0 18px 40px -16px rgba(50,68,70,0.35);
}
.village-render img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.village-render figcaption {
  padding: 16px 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.village-render-cap-label {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--tfe-cream);
  opacity: 0.75;
}
.village-render-cap-detail {
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--tfe-cream);
  text-wrap: pretty;
}

/* VILLAGE BUILD — the $9.8M rebuttal, hero-tier */
.village-build {
  background: var(--tfe-slate);
  color: var(--tfe-cream);
  border: none;
  border-radius: 14px;
  padding: 40px 28px 32px;
  margin: 0 -20px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 24px 60px -16px rgba(50,68,70,0.4);
}
.village-build::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, rgba(114,126,78,0.25), transparent 55%);
  pointer-events: none;
}
.village-build > * { position: relative; z-index: 1; }
.village-build-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: #d4715a;
  margin-bottom: 14px;
}
.village-build-claim {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(28px, 7.5vw, 42px);
  line-height: 1.1;
  letter-spacing: 0.01em;
  color: var(--tfe-cream);
  margin-bottom: 24px;
  padding: 18px 20px;
  background: rgba(212,113,90,0.12);
  border-left: 4px solid #d4715a;
  border-radius: 4px;
  font-style: italic;
  text-wrap: balance;
}
.village-build-claim strong {
  font-style: normal;
  color: #f5b8a7;
  font-weight: 600;
}
.village-build-divider {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 28px 0 20px;
}
.village-build-divider::before,
.village-build-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: rgba(229,226,217,0.25);
}
.village-build-divider span {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--tfe-bone);
}
.village-build-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(28px, 7.5vw, 42px);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-cream);
  margin-bottom: 18px;
  line-height: 1.0;
  text-wrap: balance;
}
.village-build-head .em { color: #d0c994; font-style: normal; }
.village-build-body {
  font-family: var(--font-body);
  font-size: 15.5px;
  line-height: 1.6;
  color: rgba(229,226,217,0.9);
  margin-bottom: 18px;
  text-wrap: pretty;
}
.village-build-body strong { color: var(--tfe-cream); font-weight: 600; }
.village-build-list {
  list-style: none;
  padding: 0;
  margin: 0 0 22px 0;
  border-top: 1px solid rgba(229,226,217,0.18);
}
.village-build-list li {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 12px;
  font-size: 15px;
  line-height: 1.5;
  color: rgba(229,226,217,0.85);
  padding: 12px 0;
  border-bottom: 1px solid rgba(229,226,217,0.12);
}
.village-build-x {
  font-family: var(--font-subheading);
  font-weight: 700;
  color: #d4715a;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 13px;
  align-self: center;
}

/* Big rebuttal stats: $4.5M vs $880K */
.village-build-bigstats {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 14px;
  align-items: center;
  background: rgba(229,226,217,0.06);
  border: 1px solid rgba(229,226,217,0.18);
  border-radius: 12px;
  padding: 24px 16px;
  margin-bottom: 22px;
}
.vbb { text-align: center; }
.vbb-num {
  font-family: var(--font-heading);
  font-size: clamp(36px, 10vw, 56px);
  line-height: 1;
  color: var(--tfe-cream);
  letter-spacing: 0.01em;
}
.vbb:first-child .vbb-num { color: #d0c994; }
.vbb-label {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tfe-bone);
  margin-top: 10px;
  line-height: 1.4;
}
.vbb-vs {
  font-family: var(--font-heading);
  font-size: 22px;
  color: rgba(229,226,217,0.4);
  font-style: italic;
  letter-spacing: 0.04em;
}

.village-build-foot {
  font-family: var(--font-body);
  font-size: 14.5px;
  color: rgba(229,226,217,0.85);
  font-style: italic;
  padding-top: 16px;
  border-top: 1px solid rgba(229,226,217,0.18);
  line-height: 1.6;
  text-wrap: pretty;
}
.village-build-foot strong { color: var(--tfe-cream); font-weight: 600; font-style: normal; }

/* OPERATING COSTS — reframing overhead */
.opcosts {
  margin-top: 28px;
  padding: 32px 24px;
  background: var(--tfe-cream);
  border: 1px solid var(--border);
  border-top: 4px solid var(--accent);
  border-radius: 12px;
}
.opcosts-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.opcosts-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(26px, 6.8vw, 38px);
  line-height: 1.05;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 16px;
  text-wrap: balance;
}
.opcosts-head .em { color: var(--accent); font-style: normal; }
.opcosts-body {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--tfe-slate);
  margin-bottom: 24px;
  text-wrap: pretty;
}
.opcosts-body strong { color: var(--tfe-black); font-weight: 600; }

.opcosts-budget {
  text-align: center;
  padding: 22px 18px;
  background: var(--tfe-bone);
  border-radius: 10px;
  margin-bottom: 24px;
  border: 1px solid var(--divider);
}
.opcosts-budget-num {
  font-family: var(--font-heading);
  font-size: clamp(48px, 14vw, 72px);
  line-height: 0.95;
  color: var(--tfe-black);
  letter-spacing: 0.01em;
}
.opcosts-budget-label {
  font-family: var(--font-subheading);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tfe-slate);
  margin-top: 12px;
  line-height: 1.5;
}
.opcosts-budget-label span {
  display: block;
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: none;
  font-size: 11.5px;
  font-style: italic;
  color: var(--tfe-slate);
  opacity: 0.75;
  margin-top: 4px;
}

.opcosts-breakdown {
  margin-bottom: 28px;
}
.opcosts-row {
  margin-bottom: 18px;
}
.opcosts-row-bar {
  position: relative;
  background: var(--accent);
  color: var(--tfe-cream);
  padding: 12px 16px;
  border-radius: 4px;
  min-width: 32%;
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}
/* row 1 = wages to neighbors — make this the loudest */
.opcosts-row--hero .opcosts-row-bar {
  background: var(--accent);
  padding: 16px 18px;
  box-shadow: 0 6px 22px -10px rgba(114,126,78,0.5);
  min-width: 38%;
}
.opcosts-row--hero .opcosts-row-pct {
  font-size: 30px;
}
.opcosts-row--hero .opcosts-row-label {
  font-size: 12px;
}
/* row 2 = staff comp */
.opcosts-row:nth-of-type(2) .opcosts-row-bar {
  background: var(--tfe-slate);
}
/* row 3 = direct program */
.opcosts-row:nth-of-type(3) .opcosts-row-bar {
  background: #a8a08a;
}
/* row 4 = admin/fundraising — muted */
.opcosts-row:nth-of-type(4) .opcosts-row-bar {
  background: #c2bba4;
  color: var(--tfe-black);
}
.opcosts-row-pct {
  font-family: var(--font-heading);
  font-size: 22px;
  letter-spacing: 0.01em;
  line-height: 1;
}
.opcosts-row-label {
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.opcosts-row-note {
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--tfe-slate);
  padding: 10px 4px 0 4px;
  text-wrap: pretty;
}

.opcosts-compare {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 10px;
  padding: 22px 20px;
  margin-bottom: 22px;
}
.opcosts-compare-head {
  font-family: var(--font-subheading);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--divider);
}
.opcosts-compare-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.opcosts-compare-list li {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 14px;
  align-items: center;
}
.oc-num {
  font-family: var(--font-heading);
  font-size: 36px;
  color: var(--accent);
  text-align: right;
  line-height: 1;
  letter-spacing: 0.01em;
}
.oc-txt {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.5;
  color: var(--tfe-slate);
  text-wrap: pretty;
}

.opcosts-foot {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--tfe-slate);
  padding: 20px 22px;
  background: var(--tfe-slate);
  color: var(--tfe-cream);
  border-radius: 8px;
  text-wrap: pretty;
}
.opcosts-foot strong {
  display: block;
  font-family: var(--font-heading);
  font-size: 18px;
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-cream);
  margin-bottom: 8px;
  line-height: 1.2;
}
.opcosts-foot em {
  font-style: italic;
  color: #d0c994;
  font-weight: 500;
}

/* ============================================================
   GLEANUP
   ============================================================ */
.glean {
  padding: 56px 0 32px;
  border-top: 1px solid var(--divider);
}

/* GLEAN UP HERO — full-bleed slate, monumental type */
.glean-hero {
  position: relative;
  background: var(--tfe-slate);
  color: var(--tfe-cream);
  border-radius: 14px;
  padding: 44px 28px 32px;
  margin: 0 -20px 28px;
  overflow: hidden;
  box-shadow: 0 24px 60px -16px rgba(50,68,70,0.4);
}
.glean-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 0% 100%, rgba(114,126,78,0.32), transparent 55%);
  pointer-events: none;
}
.glean-hero-bg {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}
.glean-hero-bg span {
  font-family: var(--font-heading);
  font-size: clamp(180px, 38vw, 320px);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 0.85;
  color: var(--accent);
  opacity: 0.18;
  white-space: nowrap;
  transform: translate(2%, 4%);
  font-feature-settings: "tnum" 1;
}
.glean-hero-content {
  position: relative;
  z-index: 1;
}
.glean-hero-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 18px;
}
.glean-hero-title {
  font-family: var(--font-heading);
  font-size: clamp(44px, 11vw, 78px);
  font-weight: 400;
  line-height: 0.95;
  letter-spacing: 0.005em;
  margin: 0 0 18px;
  color: var(--tfe-cream);
}
.glean-hero-title .em {
  color: var(--accent);
  font-style: italic;
  font-weight: 500;
}
.glean-hero-kicker {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--tfe-cream);
  opacity: 0.9;
  margin: 0 0 28px;
  max-width: 36ch;
}
.glean-hero-kicker strong { color: var(--accent); font-weight: 600; }
.glean-hero-strip {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid rgba(232,225,210,0.18);
  border-left: 1px solid rgba(232,225,210,0.18);
}
.ghs {
  padding: 16px 14px;
  border-right: 1px solid rgba(232,225,210,0.18);
  border-bottom: 1px solid rgba(232,225,210,0.18);
}
.ghs-num {
  font-family: var(--font-heading);
  font-size: clamp(28px, 8vw, 40px);
  line-height: 0.95;
  letter-spacing: 0.01em;
  color: var(--tfe-cream);
  font-feature-settings: "tnum" 1;
  margin-bottom: 6px;
}
.ghs-label {
  font-family: var(--font-subheading);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  opacity: 0.95;
}

.glean-lede {
  margin-bottom: 28px;
}

@media (min-width: 720px) {
  .glean-hero { padding: 64px 56px 48px; margin: 0 0 36px; border-radius: 18px; }
  .glean-hero-strip { grid-template-columns: repeat(4, 1fr); }
  .glean-hero-kicker { font-size: 18px; }
}

.glean-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 24px;
}
.glean-stat {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.glean-stat-num {
  font-family: var(--font-heading);
  font-size: clamp(34px, 10vw, 48px);
  line-height: 1;
  color: var(--tfe-black);
  letter-spacing: 0.01em;
  font-feature-settings: "tnum" 1;
}
.glean-stat-label {
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tfe-slate);
  margin-top: 8px;
  line-height: 1.4;
}

.why-sa {
  background: var(--accent-soft);
  border-left: 4px solid var(--accent);
  padding: 22px 22px 22px 24px;
  border-radius: 4px;
}
.why-sa-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.why-sa p {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--tfe-slate);
  text-wrap: pretty;
}
.why-sa p + p { margin-top: 12px; }
.why-sa strong {
  color: var(--tfe-black);
  font-weight: 600;
}
.why-sa em {
  font-style: italic;
  color: var(--tfe-black);
  font-weight: 500;
}

.glean-foot {
  margin-top: 18px;
  font-family: var(--font-body);
  font-size: 13px;
  font-style: italic;
  color: var(--tfe-sage);
  line-height: 1.5;
  text-wrap: pretty;
}
.glean-foot em { color: var(--tfe-slate); font-weight: 500; }

/* ============================================================
   EQUIVALENT
   ============================================================ */
.equiv { padding: 48px 0 32px; }
.equiv-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.equiv-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px 18px;
  display: grid;
  grid-template-columns: 56px 1fr;
  grid-template-rows: auto auto;
  gap: 4px 16px;
}
.equiv-icon {
  grid-row: 1 / 3;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--accent-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  border: 1px solid rgba(114,126,78,0.2);
}
.equiv-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: 22px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--accent);
  line-height: 1.05;
  align-self: end;
}
.equiv-body {
  font-size: 14px;
  line-height: 1.5;
  color: var(--tfe-slate);
  text-wrap: pretty;
}

/* ============================================================
   DOUBLED — much bigger, hero-tier
   ============================================================ */
.doubled {
  padding: 56px 0 32px;
  margin: 0 -20px;
  padding-left: 20px;
  padding-right: 20px;
}
.doubled-banner {
  background: linear-gradient(140deg, var(--accent) 0%, #5f6a41 60%, var(--tfe-slate) 100%);
  color: var(--tfe-cream);
  border-radius: 16px;
  padding: 56px 28px 48px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 24px 60px -16px rgba(50,68,70,0.4);
  margin-bottom: 22px;
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.doubled-banner::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -30%;
  width: 80%;
  height: 200%;
  background: radial-gradient(ellipse, rgba(229,226,217,0.18), transparent 60%);
  pointer-events: none;
}
.doubled-banner::after {
  content: "2×";
  position: absolute;
  bottom: -100px;
  right: -60px;
  font-family: var(--font-heading);
  font-size: clamp(500px, 130vw, 900px);
  line-height: 1;
  color: rgba(229,226,217,0.07);
  pointer-events: none;
  font-weight: 700;
  letter-spacing: -0.05em;
}
.doubled-eyebrow {
  position: relative;
  z-index: 1;
  font-family: var(--font-subheading);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--tfe-bone);
  margin-bottom: 28px;
}
.doubled-mega {
  position: relative;
  z-index: 1;
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(72px, 22vw, 152px);
  line-height: 0.88;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  color: var(--tfe-cream);
  margin-bottom: 36px;
  text-wrap: balance;
}
.doubled-mega .just {
  font-style: italic;
  font-size: 0.55em;
  letter-spacing: 0.04em;
  font-weight: 400;
  opacity: 0.92;
}
.doubled-deck {
  position: relative;
  z-index: 1;
  font-family: var(--font-body);
  font-size: clamp(17px, 4vw, 21px);
  line-height: 1.55;
  color: rgba(229,226,217,0.95);
  max-width: 580px;
  text-wrap: pretty;
}
.doubled-deck strong { color: var(--tfe-cream); font-weight: 700; }
.doubled-deck em { font-style: italic; color: var(--tfe-cream); }

/* YTD section */
.doubled-section {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 26px 22px 24px;
  margin-bottom: 16px;
  box-shadow: 0 4px 16px rgba(50,68,70,0.05);
}
.doubled-section-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--tfe-sage);
  margin-bottom: 4px;
}
.doubled-section-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(24px, 6.5vw, 32px);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 22px;
  line-height: 1.05;
}
.doubled-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.doubled-stat {
  text-align: center;
  padding: 6px 4px;
}
.doubled-stat:nth-child(odd) {
  border-right: 1px solid var(--divider);
}
.doubled-stat-num {
  font-family: var(--font-heading);
  font-size: clamp(32px, 8.5vw, 44px);
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--tfe-black);
}
.doubled-stat-label {
  font-family: var(--font-subheading);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tfe-slate);
  margin-top: 8px;
  line-height: 1.3;
}

/* Projection section */
.doubled-section--proj {
  background: var(--tfe-slate);
  color: var(--tfe-cream);
  border-color: var(--tfe-slate);
  position: relative;
  overflow: hidden;
}
.doubled-section--proj::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, rgba(114,126,78,0.3), transparent 60%);
  pointer-events: none;
}
.doubled-section-eyebrow--proj {
  color: rgba(168,167,140,0.9);
  position: relative;
  z-index: 1;
}
.doubled-section--proj .doubled-section-head {
  color: var(--tfe-cream);
  position: relative;
  z-index: 1;
}
.doubled-projgrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  position: relative;
  z-index: 1;
}
.doubled-proj {
  background: rgba(251,248,239,0.06);
  border: 1px solid rgba(229,226,217,0.18);
  border-radius: 10px;
  padding: 18px 16px;
}
.doubled-proj--lead {
  grid-column: 1 / -1;
  background: var(--accent);
  border-color: var(--accent);
}
.doubled-proj-num {
  font-family: var(--font-heading);
  font-size: clamp(34px, 10vw, 54px);
  line-height: 1;
  letter-spacing: 0.01em;
  color: var(--tfe-cream);
  font-feature-settings: "tnum" 1;
}
.doubled-proj-label {
  font-family: var(--font-subheading);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tfe-bone);
  margin-top: 8px;
}
.doubled-proj-vs {
  font-size: 12.5px;
  color: rgba(229,226,217,0.7);
  margin-top: 8px;
  font-style: italic;
  line-height: 1.4;
}

/* ============================================================
   OVERHEAD MYTH — the centerpiece rebuttal
   ============================================================ */
.overhead-sec {
  padding: 64px 0 40px;
  position: relative;
}

/* HERO HEADLINE */
.overhead-hero {
  text-align: left;
  margin-bottom: 44px;
  padding: 36px 28px 32px;
  background: var(--tfe-cream);
  border: 1px solid var(--border);
  border-radius: 14px;
  border-top: 6px solid var(--accent);
}
.overhead-eyebrow {
  font-family: var(--font-subheading);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 18px;
}
.overhead-mega {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(40px, 12vw, 76px);
  line-height: 0.95;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 24px;
  text-wrap: balance;
}
.overhead-mega-em {
  color: var(--accent);
  font-style: italic;
}
.overhead-lede {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--tfe-slate);
  text-wrap: pretty;
  max-width: 560px;
}
.overhead-lede strong { color: var(--tfe-black); font-weight: 600; }
.overhead-lede em { color: var(--tfe-black); font-style: italic; font-weight: 500; }

/* THE LETTER — pull quote */
.overhead-letter {
  background: var(--tfe-slate);
  color: var(--tfe-cream);
  border-radius: 14px;
  padding: 36px 28px 28px;
  margin-bottom: 44px;
  position: relative;
  box-shadow: 0 24px 60px -16px rgba(50,68,70,0.4);
}
.overhead-letter-head {
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(229,226,217,0.18);
}
.overhead-letter-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: #d0c994;
  margin-bottom: 12px;
}
.overhead-letter-signers {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.overhead-letter-signers .signer {
  font-family: var(--font-heading);
  font-size: clamp(17px, 4.4vw, 22px);
  letter-spacing: 0.02em;
  color: var(--tfe-cream);
  line-height: 1.1;
}
.overhead-letter-signers .signer-dot {
  color: rgba(229,226,217,0.4);
  font-size: 18px;
}
.overhead-quote {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  position: relative;
}
.overhead-quote .quote-mark {
  position: absolute;
  top: -28px;
  left: -8px;
  font-family: var(--font-heading);
  font-size: 88px;
  line-height: 1;
  color: rgba(208,201,148,0.3);
  pointer-events: none;
}
.overhead-quote p {
  font-family: var(--font-body);
  font-size: clamp(15.5px, 3.8vw, 17.5px);
  line-height: 1.55;
  color: var(--tfe-cream);
  margin-bottom: 14px;
  text-wrap: pretty;
}
.overhead-quote p:last-of-type { margin-bottom: 0; }
.overhead-quote strong { color: #f5e8b0; font-weight: 600; }
.overhead-quote em { color: #f5e8b0; font-style: italic; }
.overhead-quote .quote-kicker {
  font-family: var(--font-heading);
  font-size: clamp(18px, 4.6vw, 24px);
  line-height: 1.25;
  letter-spacing: 0.01em;
  color: var(--tfe-cream);
  font-style: italic;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(229,226,217,0.18);
}
.overhead-link {
  display: inline-block;
  margin-top: 22px;
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #d0c994;
  border-bottom: 1px solid rgba(208,201,148,0.5);
  padding-bottom: 2px;
}

/* PERRYMAN ROI */
.overhead-perryman {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 32px 26px;
  margin-bottom: 44px;
}
.overhead-perryman-eyebrow {
  font-family: var(--font-subheading);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.overhead-perryman-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(22px, 5.8vw, 32px);
  line-height: 1.15;
  letter-spacing: 0.01em;
  color: var(--tfe-black);
  margin-bottom: 24px;
  text-wrap: balance;
}
.overhead-perryman-head .big {
  display: block;
  margin-top: 6px;
  color: var(--accent);
  font-size: 1.1em;
  letter-spacing: 0.02em;
}

.overhead-roi {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: stretch;
  margin-bottom: 24px;
  background: var(--tfe-bone);
  border-radius: 10px;
  padding: 32px 22px;
  border: 1px solid var(--divider);
}
.overhead-roi-col {
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.overhead-roi-col--big .overhead-roi-num {
  font-size: clamp(58px, 18vw, 110px);
  color: var(--accent);
  letter-spacing: 0;
}
.overhead-roi-num {
  font-family: var(--font-heading);
  font-size: clamp(40px, 11vw, 64px);
  line-height: 0.95;
  color: var(--tfe-slate);
  letter-spacing: 0.01em;
}
.overhead-roi-label {
  font-family: var(--font-subheading);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tfe-slate);
  margin-top: 16px;
  line-height: 1.45;
}
.overhead-roi-source {
  font-family: var(--font-body);
  font-size: 11.5px;
  font-style: italic;
  color: var(--tfe-slate);
  opacity: 0.7;
  margin-top: 10px;
}

/* 4-up Perryman grid */
.overhead-perryman-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  margin-bottom: 22px;
  border-top: 1px solid var(--divider);
  border-left: 1px solid var(--divider);
}
.opg {
  padding: 22px 18px;
  border-right: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
  background: #fff;
  text-align: left;
}
.opg-num {
  font-family: var(--font-heading);
  font-size: clamp(28px, 7vw, 38px);
  line-height: 1;
  color: var(--accent);
  letter-spacing: 0.01em;
  margin-bottom: 10px;
}
.opg-label {
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.45;
  color: var(--tfe-slate);
  text-wrap: pretty;
}
.opg-label strong { color: var(--tfe-black); font-weight: 600; }
.opg-label em { color: var(--tfe-black); font-style: italic; font-weight: 500; }

.overhead-perryman-foot {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--tfe-slate);
  text-wrap: pretty;
  padding-top: 6px;
}
.overhead-perryman-foot strong { color: var(--tfe-black); font-weight: 600; }

/* CLOSING */
.overhead-foot {
  text-align: center;
  padding: 24px 0 8px;
}
.overhead-foot-num {
  font-family: var(--font-heading);
  font-size: clamp(28px, 7.5vw, 42px);
  line-height: 1.15;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  text-wrap: balance;
  margin-bottom: 22px;
}
.overhead-foot-em {
  font-family: var(--font-heading);
  font-size: clamp(22px, 6vw, 32px);
  line-height: 1.25;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  text-wrap: balance;
}
.overhead-foot-em em {
  color: var(--accent);
  font-style: italic;
  font-weight: 500;
}

/* ============================================================
   FOOTER
   ============================================================ */
.foot {
  margin-top: 32px;
  padding: 48px 24px 28px;
  background: var(--tfe-slate);
  color: var(--tfe-cream);
  border-radius: 14px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.foot-mark {
  width: 56px;
  height: 56px;
  margin: 0 auto 14px;
  opacity: 0.95;
}
.foot-mark img { width: 100%; height: 100%; object-fit: contain; }
.foot-tag {
  font-family: var(--font-heading);
  font-size: 18px;
  letter-spacing: 0.32em;
  margin-bottom: 20px;
  color: var(--tfe-bone);
}
.foot-mission {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(229,226,217,0.85);
  font-style: italic;
  max-width: 460px;
  margin: 0 auto 20px;
  text-wrap: pretty;
}
.foot-meta {
  font-family: var(--font-subheading);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: rgba(229,226,217,0.55);
  margin-bottom: 18px;
  line-height: 1.5;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}
.foot-cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-subheading);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--tfe-bone);
}
.foot-link {
  color: var(--tfe-cream);
  border-bottom: 1px solid rgba(229,226,217,0.4);
  padding-bottom: 1px;
}
.foot-dot { opacity: 0.4; }

/* ============================================================
   DESKTOP TWEAKS
   ============================================================ */
@media (min-width: 640px) {
  .equiv-grid { grid-template-columns: repeat(3, 1fr); }
  .glean-stats { grid-template-columns: repeat(4, 1fr); }
  .doubled-stats { grid-template-columns: repeat(4, 1fr); }
  .doubled-stat:nth-child(odd) { border-right: none; }
  .doubled-stat:not(:last-child) { border-right: 1px solid var(--divider); }
  .doubled-projgrid { grid-template-columns: repeat(2, 1fr); }
  .doubled-proj--lead { grid-column: 1 / -1; }
  .village-grid { grid-template-columns: repeat(4, 1fr); }
  .village-hero { aspect-ratio: 21 / 10; }
}
@media (min-width: 720px) {
  .page { padding: 0 32px 64px; }
  .village-hero { margin-left: -32px; margin-right: -32px; }
  .doubled { margin: 0 -32px; padding-left: 32px; padding-right: 32px; }
}

/* ============================================================
   APRIL 2026 EDITS — OVERRIDES + NEW SECTIONS
   ============================================================ */

/* ---------- Hero typography bumps for mobile ---------- */
.hero-stats-foot {
  font-size: 17px !important;
  line-height: 1.55 !important;
  max-width: 720px;
}
@media (min-width: 720px) {
  .hero-stats-foot { font-size: 18px !important; }
}

/* ---------- Big section eyebrow used on equiv ---------- */
.equiv { padding: 56px 0 40px; }
.equiv-eyebrow {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(28px, 7vw, 44px);
  line-height: 1.05;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 22px;
  text-wrap: balance;
  padding-right: 8px;
}
.equiv-eyebrow::before {
  content: "";
  display: block;
  width: 48px;
  height: 3px;
  background: var(--accent);
  margin-bottom: 14px;
}

/* ---------- Equiv card text size bump for mobile ---------- */
.equiv-head { font-size: 24px !important; }
.equiv-body { font-size: 15px !important; }

/* ---------- Hero stat label/sub bump ---------- */
.hero-stat-label { font-size: 13px !important; line-height: 1.3 !important; }
.hero-stat-sub { font-size: 12px !important; }
.hero-stat-num { font-size: clamp(40px, 11vw, 64px) !important; }
@media (min-width: 720px) {
  .hero-stat-num { font-size: clamp(54px, 7vw, 78px) !important; }
}

/* ---------- Glean hero new title em-2 (second em line) ---------- */
.glean-hero-title .em-2 {
  color: var(--tfe-cream);
  opacity: 0.92;
  font-style: italic;
  font-size: 0.7em;
}

/* ---------- Section: Operating-costs program allocation ---------- */
.opcosts-breakdown-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(22px, 5.6vw, 32px);
  line-height: 1.1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin: 18px 0 8px;
}
.opcosts-breakdown-sub {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--tfe-slate);
  margin-bottom: 18px;
  text-wrap: pretty;
  max-width: 640px;
}
.opcosts-breakdown-sub em { color: var(--tfe-black); font-style: italic; font-weight: 500; }

/* Reset old nth-of-type colors and apply new 5-row palette */
.opcosts-row:nth-of-type(2) .opcosts-row-bar,
.opcosts-row:nth-of-type(3) .opcosts-row-bar,
.opcosts-row:nth-of-type(4) .opcosts-row-bar { background: initial; }

.opcosts-row:nth-of-type(1) .opcosts-row-bar { background: var(--accent); }
.opcosts-row:nth-of-type(2) .opcosts-row-bar { background: var(--tfe-slate); }
.opcosts-row:nth-of-type(3) .opcosts-row-bar { background: #8b8a72; }
.opcosts-row:nth-of-type(4) .opcosts-row-bar { background: #a8a08a; }
.opcosts-row--admin .opcosts-row-bar {
  background: #c2bba4 !important;
  color: var(--tfe-black) !important;
}
.opcosts-row--admin .opcosts-row-pct,
.opcosts-row--admin .opcosts-row-label {
  color: var(--tfe-black);
}

.opcosts-allocation-note {
  background: var(--tfe-cream);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: 6px;
  padding: 14px 16px;
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--tfe-slate);
  margin-top: 8px;
  margin-bottom: 24px;
  text-wrap: pretty;
}
.opcosts-allocation-note strong { color: var(--tfe-black); font-weight: 600; }
.opcosts-allocation-note em { color: var(--tfe-black); font-style: italic; font-weight: 500; }

/* ---------- Why-SA kicker + Coalition section ---------- */
.why-sa-kicker {
  margin-top: 14px !important;
  padding-top: 12px;
  border-top: 1px solid rgba(114,126,78,0.3);
  font-size: 15.5px !important;
}
.why-sa-kicker strong { color: var(--accent); }

.coalition {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 26px 22px;
  margin: 22px 0 8px;
}
.coalition-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.coalition-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(26px, 6.5vw, 38px);
  line-height: 1.05;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 16px;
  text-wrap: balance;
}
.coalition-head .em { color: var(--accent); font-style: italic; }
.coalition-body {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--tfe-slate);
  text-wrap: pretty;
}
.coalition-body + .coalition-body { margin-top: 12px; }
.coalition-body strong { color: var(--tfe-black); font-weight: 600; }
.coalition-body em { color: var(--tfe-black); font-style: italic; font-weight: 500; }

/* ---------- Doubled record callout ---------- */
.doubled-record {
  margin-top: 28px;
  padding: 20px 22px;
  background: rgba(229,226,217,0.12);
  border: 1px solid rgba(229,226,217,0.25);
  border-left: 4px solid var(--tfe-cream);
  border-radius: 6px;
}
.doubled-record-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: #d0c994;
  margin-bottom: 8px;
}
.doubled-record p {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.55;
  color: var(--tfe-cream);
  text-wrap: pretty;
}
.doubled-record strong { color: #fff; font-weight: 600; }

/* ---------- Overhead link row (replaces broken external link) ---------- */
.overhead-link-row {
  display: inline-block;
  margin-top: 20px;
  padding: 8px 14px;
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #d0c994;
  background: rgba(229,226,217,0.08);
  border: 1px solid rgba(229,226,217,0.2);
  border-radius: 4px;
}

/* ---------- Overhead → Mission goals (HOW TFE WORKS) ---------- */
.overhead-mission {
  background: var(--tfe-cream);
  border: 1px solid var(--border);
  border-top: 4px solid var(--accent);
  border-radius: 14px;
  padding: 32px 24px 28px;
  margin-bottom: 44px;
}
.overhead-mission-eyebrow {
  font-family: var(--font-subheading);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.overhead-mission-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(26px, 6.5vw, 40px);
  line-height: 1.1;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 16px;
  text-wrap: balance;
}
.overhead-mission-head .em { color: var(--accent); font-style: italic; }
.overhead-mission-body {
  font-family: var(--font-body);
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--tfe-slate);
  margin-bottom: 22px;
  text-wrap: pretty;
}
.overhead-mission-body strong { color: var(--tfe-black); font-weight: 600; }

.overhead-goals {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: goal;
  display: grid;
  gap: 14px;
}
.overhead-goals li {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px 18px;
}
.og-num {
  font-family: var(--font-heading);
  font-size: 32px;
  letter-spacing: 0.02em;
  color: var(--accent);
  line-height: 1;
  align-self: start;
  padding-top: 4px;
}
.og-head {
  font-family: var(--font-subheading);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 6px;
}
.og-body {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--tfe-slate);
  text-wrap: pretty;
}
.og-body strong { color: var(--tfe-black); font-weight: 600; }

/* ---------- Overhead → Combat costs (CHP + PA students) ---------- */
.overhead-combat {
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px dashed var(--divider);
}
.overhead-combat-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}
.overhead-combat-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(22px, 5.6vw, 32px);
  line-height: 1.15;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 14px;
  text-wrap: balance;
}
.overhead-combat-head .em { color: var(--accent); font-style: italic; }
.overhead-combat-body {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--tfe-slate);
  margin-bottom: 18px;
  text-wrap: pretty;
}
.overhead-combat-body strong { color: var(--tfe-black); font-weight: 600; }
.overhead-combat-body em { color: var(--tfe-black); font-style: italic; font-weight: 500; }

.overhead-combat-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 640px) {
  .overhead-combat-grid { grid-template-columns: 1fr 1fr; }
}
.ocg {
  background: var(--accent-soft);
  border: 1px solid rgba(114,126,78,0.25);
  border-radius: 8px;
  padding: 18px 18px;
}
.ocg-tag {
  display: inline-block;
  font-family: var(--font-subheading);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #fff;
  background: var(--accent);
  padding: 3px 10px;
  border-radius: 999px;
  margin-bottom: 10px;
}
.ocg-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: 21px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  line-height: 1.1;
  margin-bottom: 8px;
}
.ocg-body {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.55;
  color: var(--tfe-slate);
  text-wrap: pretty;
}
.ocg-body strong { color: var(--tfe-black); font-weight: 600; }

/* ---------- Section title size bumps across the board (mobile) ---------- */
.section-eyebrow {
  font-size: 12.5px !important;
}
.opcosts-head {
  font-size: clamp(28px, 7.5vw, 44px) !important;
  line-height: 1.05 !important;
}
.glean-hero-title {
  font-size: clamp(38px, 11vw, 70px) !important;
  line-height: 0.98 !important;
}
.doubled-deck { font-size: 16px !important; line-height: 1.55 !important; }

/* ---------- Ted / Chain of Love story ---------- */
.ted-story {
  margin: 28px 0 36px;
  padding: 28px 22px 26px;
  background: linear-gradient(180deg, #fff 0%, var(--tfe-cream) 100%);
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent);
  border-radius: 12px;
  box-shadow: 0 6px 24px -10px rgba(50,68,70,0.12);
}
.ted-story-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 18px;
}
.ted-story-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  align-items: start;
}
@media (min-width: 720px) {
  .ted-story-grid { grid-template-columns: 280px 1fr; gap: 32px; }
}
.ted-story-quote {
  position: relative;
  padding: 18px 16px 14px 22px;
  background: var(--accent-soft);
  border-radius: 8px;
  border: 1px solid rgba(114,126,78,0.2);
}
.ted-story-quote-mark {
  position: absolute;
  top: -8px;
  left: 12px;
  font-family: var(--font-heading);
  font-size: 56px;
  line-height: 1;
  color: var(--accent);
  opacity: 0.5;
}
.ted-story-quote p {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(20px, 4.6vw, 26px);
  line-height: 1.2;
  letter-spacing: 0.01em;
  color: var(--tfe-black);
  margin: 8px 0 12px;
  text-wrap: balance;
}
.ted-story-quote p em { font-style: italic; color: var(--accent); }
.ted-story-quote p strong { font-weight: 600; color: var(--accent); }
.ted-story-attr {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tfe-slate);
}
.ted-story-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(24px, 6vw, 34px);
  line-height: 1.05;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 14px;
  text-wrap: balance;
}
.ted-story-head .em { color: var(--accent); font-style: italic; }
.ted-story-body p {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--tfe-slate);
  margin-bottom: 12px;
  text-wrap: pretty;
}
.ted-story-body p strong { color: var(--tfe-black); font-weight: 600; }
.ted-story-body p em { color: var(--tfe-black); font-style: italic; font-weight: 500; }
.ted-story-kicker {
  padding: 12px 14px;
  background: rgba(114,126,78,0.08);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  font-size: 15px !important;
  margin-top: 8px !important;
}
.ted-story-link {
  display: inline-block;
  margin-top: 12px;
  font-family: var(--font-subheading);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
  padding: 8px 14px;
  border: 1.5px solid var(--accent);
  border-radius: 4px;
  transition: background 0.18s, color 0.18s;
}
.ted-story-link:hover { background: var(--accent); color: #fff; }

/* ---------- Site plan SVG diagram ---------- */
.village-render--plan { margin: 24px 0 8px; }
.siteplan {
  background: #f4f1e8;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  padding: 6px;
}
.siteplan-svg {
  width: 100%;
  height: auto;
  display: block;
}

/* ---------- vbb label detail ---------- */
.vbb-label-detail {
  display: block;
  margin-top: 4px;
  font-size: 10px;
  letter-spacing: 0.12em;
  opacity: 0.75;
  font-weight: 500;
}

/* ---------- Mobile padding/margins tighter so headers feel bigger ---------- */
@media (max-width: 480px) {
  .page { padding: 0 16px 56px !important; }
  .overhead-hero { padding: 28px 20px 26px !important; }
  .overhead-letter { padding: 28px 20px 22px !important; }
  .overhead-mission { padding: 26px 18px 22px !important; }
  .overhead-perryman { padding: 26px 18px !important; }
  .opcosts { padding: 20px 18px !important; }
  .glean-hero { padding: 36px 22px 32px !important; }
  .doubled-banner { padding: 44px 22px 36px !important; }
  .why-sa { padding: 22px 18px !important; }
  .coalition { padding: 22px 18px !important; }
}



/* ====================================================== */
/* NEW SECTIONS — Origin, ApplicationCriteria, SA Flow,    */
/*   Coalition members, Site plan image, Equiv horizontal, */
/*   Ted inline, Perryman explainer                        */
/* ====================================================== */

/* ---------- Origin / Leviticus 23:22 ---------- */
.origin {
  padding: 56px 22px 36px;
  background: linear-gradient(180deg, var(--tfe-cream) 0%, #fff 100%);
}
.origin-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 22px;
  text-align: center;
}
.origin-head {
  text-align: center;
  margin: 0 auto 22px !important;
  max-width: 720px;
}
.origin-verse {
  position: relative;
  padding: 22px 22px 20px;
  margin: 0 auto 22px;
  max-width: 680px;
  background: var(--tfe-cream);
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent);
  border-radius: 10px;
}
.origin-body {
  max-width: 720px;
  margin: 0 auto;
}
.origin-verse-ref {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.origin-verse-text {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(18px, 4.4vw, 22px);
  line-height: 1.4;
  letter-spacing: 0.005em;
  color: var(--tfe-black);
  font-style: italic;
}
.origin-verse-text strong { font-style: normal; color: var(--accent); }
.origin-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(28px, 7vw, 40px);
  line-height: 1.05;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 18px;
  text-wrap: balance;
}
.origin-head .em { color: var(--accent); font-style: italic; }
.origin-body p {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--tfe-slate);
  margin-bottom: 12px;
  text-wrap: pretty;
}
.origin-body p strong { color: var(--tfe-black); font-weight: 600; }
.origin-body p em { color: var(--tfe-black); font-style: italic; font-weight: 500; }
.origin-kicker {
  margin-top: 14px !important;
  padding: 14px 16px;
  background: var(--accent-soft);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  font-size: 16px !important;
}

/* ---------- Application criteria ---------- */
.appcrit {
  margin: 32px 0 36px;
  padding: 30px 22px 26px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 6px 24px -10px rgba(50,68,70,0.10);
}
.appcrit-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
}
.appcrit-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(24px, 6vw, 32px);
  line-height: 1.05;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 14px;
  text-wrap: balance;
}
.appcrit-head .em { color: var(--accent); font-style: italic; }
.appcrit-lede {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.55;
  color: var(--tfe-slate);
  margin-bottom: 22px;
  text-wrap: pretty;
}
.appcrit-list { list-style: none; padding: 0; margin: 0 0 18px; display: grid; gap: 14px; }
@media (min-width: 720px) {
  .appcrit-list { grid-template-columns: 1fr 1fr; gap: 16px 22px; }
}
.appcrit-list li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: start;
  padding: 14px 14px 12px;
  background: var(--tfe-cream);
  border-radius: 8px;
  border: 1px solid var(--border);
}
.appcrit-num {
  font-family: var(--font-heading);
  font-size: 28px;
  font-weight: 400;
  color: var(--accent);
  letter-spacing: 0.04em;
  line-height: 1;
}
.appcrit-h {
  font-family: var(--font-subheading);
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--tfe-black);
  margin-bottom: 4px;
  text-transform: none;
}
.appcrit-h em { color: var(--accent); font-style: italic; }
.appcrit-b {
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--tfe-slate);
}
.appcrit-foot {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.55;
  color: var(--tfe-slate);
  padding-top: 16px;
  border-top: 1px solid var(--border);
  text-wrap: pretty;
}
.appcrit-foot strong { color: var(--tfe-black); }
.appcrit-link {
  display: inline-block;
  margin-left: 4px;
  font-family: var(--font-subheading);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1.5px solid var(--accent);
  padding-bottom: 1px;
}
.appcrit-link:hover { color: var(--tfe-black); border-color: var(--tfe-black); }

/* ---------- Site plan image with markers ---------- */
.siteplan-figure { margin: 24px 0 8px; }
.siteplan-image {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  background: #1a1a1a;
}
.siteplan-image img {
  width: 100%;
  height: auto;
  display: block;
}
.siteplan-marker {
  position: absolute;
  padding: 6px 10px 7px;
  background: rgba(255,255,255,0.96);
  border-radius: 6px;
  border: 2px solid var(--accent);
  box-shadow: 0 6px 20px rgba(0,0,0,0.4);
  min-width: 110px;
  text-align: left;
  font-family: var(--font-subheading);
}
.siteplan-marker--built {
  top: 6%;
  right: 6%;
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}
.siteplan-marker--next-1 {
  top: 38%;
  right: 10%;
  border-style: dashed;
}
.siteplan-marker--next-2 {
  top: 64%;
  right: 18%;
  border-style: dashed;
}
.siteplan-marker-tag {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  opacity: 0.85;
}
.siteplan-marker-status {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin-top: 1px;
}
.siteplan-marker-detail {
  font-family: var(--font-body);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0;
  margin-top: 3px;
  line-height: 1.3;
  opacity: 0.9;
}
.siteplan-marker--built .siteplan-marker-status { color: #fff; }
.siteplan-marker--built .siteplan-marker-detail { color: rgba(255,255,255,0.95); }
.siteplan-marker--next .siteplan-marker-status { color: var(--accent); }
.siteplan-marker--next .siteplan-marker-detail { color: var(--tfe-slate); }
@media (max-width: 600px) {
  .siteplan-marker { padding: 4px 7px 5px; min-width: 80px; }
  .siteplan-marker-tag { font-size: 8px; letter-spacing: 0.14em; }
  .siteplan-marker-status { font-size: 10px; }
  .siteplan-marker-detail { font-size: 9px; }
  .siteplan-marker--next-1 { top: 38%; right: 4%; }
  .siteplan-marker--next-2 { top: 62%; right: 14%; }
}
.siteplan-figure figcaption {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.village-build-clarify {
  margin-top: 10px;
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.55;
  color: var(--tfe-slate);
  font-style: italic;
  padding: 10px 12px;
  background: var(--tfe-cream);
  border-left: 3px solid var(--border);
  border-radius: 4px;
}
.village-build-clarify strong { color: var(--tfe-black); font-style: normal; }

/* ---------- Ted story (inline / no quote box) ---------- */
.ted-story--inline { background: linear-gradient(180deg, #fff 0%, var(--tfe-cream) 100%); }
.ted-story-p {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--tfe-slate);
  margin-bottom: 12px;
  text-wrap: pretty;
}
.ted-story-p strong { color: var(--tfe-black); font-weight: 600; }
.ted-story-p em { color: var(--tfe-black); font-style: italic; font-weight: 500; }
.ted-story-pull {
  position: relative;
  margin: 20px 0 18px;
  padding: 18px 18px 16px 30px;
  background: var(--accent-soft);
  border-left: 4px solid var(--accent);
  border-radius: 6px;
}
.ted-story-pull-mark {
  position: absolute;
  top: 4px;
  left: 8px;
  font-family: var(--font-heading);
  font-size: 56px;
  line-height: 1;
  color: var(--accent);
  opacity: 0.55;
}
.ted-story-pull p {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(20px, 4.6vw, 24px);
  line-height: 1.2;
  letter-spacing: 0.01em;
  color: var(--tfe-black);
  margin: 0 0 8px;
  text-wrap: balance;
}
.ted-story-pull p em { font-style: italic; color: var(--accent); }
.ted-story-pull p strong { font-weight: 600; color: var(--accent); }
.ted-story-pull cite {
  display: block;
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 600;
  font-style: normal;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tfe-slate);
}

/* ---------- Equivalent cards horizontal ---------- */
.equiv-grid--horizontal {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 600px) {
  .equiv-grid--horizontal { grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
}
.equiv-card--horizontal {
  display: grid !important;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 14px;
  padding: 16px 16px 16px !important;
  text-align: left !important;
}
.equiv-card--horizontal .equiv-icon {
  font-size: 36px;
  margin: 0 !important;
  align-self: center;
}
.equiv-card-content { min-width: 0; }
.equiv-card--horizontal .equiv-head {
  margin-bottom: 4px !important;
  font-size: 14px !important;
}
.equiv-card--horizontal .equiv-body {
  font-size: 13px !important;
  line-height: 1.45 !important;
}
@media (min-width: 600px) {
  .equiv-card--horizontal {
    grid-template-columns: 1fr;
    text-align: center !important;
  }
  .equiv-card--horizontal .equiv-icon { margin: 0 auto 8px !important; }
}

/* ---------- Salvation Army partnership (pizzazz) ---------- */
.sa-partnership {
  margin: 36px 0 32px;
  padding: 36px 22px 32px;
  background: linear-gradient(180deg, var(--tfe-black) 0%, #1f2c2e 100%);
  color: #fff;
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}
.sa-partnership::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, #d8252b 0%, #d8252b 50%, var(--accent) 50%, var(--accent) 100%);
}
.sa-partnership-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: #d8252b;
  margin-bottom: 16px;
}
.sa-partnership-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(28px, 7vw, 38px);
  line-height: 1.04;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 16px;
  text-wrap: balance;
}
.sa-partnership-head .em {
  color: #d8252b;
  font-style: italic;
  display: inline-block;
  text-shadow: 0 0 30px rgba(216,37,43,0.35);
}
.sa-partnership-deck {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255,255,255,0.85);
  margin-bottom: 26px;
  text-wrap: pretty;
}
.sa-partnership-deck strong { color: #fff; }

.sa-flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  align-items: stretch;
  margin: 22px 0 28px;
}
@media (min-width: 720px) {
  .sa-flow {
    grid-template-columns: 1fr auto 1fr auto 1fr;
    gap: 14px;
    align-items: stretch;
  }
}
.sa-flow-step {
  position: relative;
  padding: 16px 14px 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px;
}
.sa-flow-step--1 { border-left: 4px solid #d8252b; }
.sa-flow-step--2 { border-left: 4px solid var(--accent); }
.sa-flow-step--3 { border-left: 4px solid #f4f1e8; }
.sa-flow-step-num {
  position: absolute;
  top: -10px;
  left: 14px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--tfe-black);
  border: 2px solid rgba(255,255,255,0.4);
  color: #fff;
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
}
.sa-flow-step--1 .sa-flow-step-num { border-color: #d8252b; }
.sa-flow-step--2 .sa-flow-step-num { border-color: var(--accent); }
.sa-flow-step--3 .sa-flow-step-num { border-color: #f4f1e8; }
.sa-flow-step-tag {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.95);
  margin-bottom: 6px;
}
.sa-flow-step--1 .sa-flow-step-tag { color: #d8252b; }
.sa-flow-step--2 .sa-flow-step-tag { color: var(--accent); }
.sa-flow-step--3 .sa-flow-step-tag { color: #f4f1e8; }
.sa-flow-step-body {
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.45;
  color: rgba(255,255,255,0.85);
}
.sa-flow-arrow {
  display: none;
  align-self: center;
  font-family: var(--font-heading);
  font-size: 28px;
  color: var(--accent);
  text-align: center;
  padding: 0 4px;
}
@media (min-width: 720px) {
  .sa-flow-arrow { display: block; }
}

.sa-fruit {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 18px 0 22px;
}
@media (min-width: 640px) {
  .sa-fruit { grid-template-columns: 1fr 1fr; gap: 16px; }
}
.sa-fruit-card {
  padding: 18px 16px 16px;
  border-radius: 10px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
}
.sa-fruit-card--alive { border-left: 4px solid var(--accent); }
.sa-fruit-card--lord { border-left: 4px solid rgba(255,255,255,0.4); background: rgba(255,255,255,0.03); }
.sa-fruit-num {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(48px, 11vw, 64px);
  line-height: 1;
  color: #fff;
  margin-bottom: 6px;
}
.sa-fruit-card--alive .sa-fruit-num { color: var(--accent); }
.sa-fruit-card--lord .sa-fruit-num { color: rgba(255,255,255,0.85); }
.sa-fruit-label {
  font-family: var(--font-subheading);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  color: #fff;
  margin-bottom: 8px;
  text-wrap: balance;
}
.sa-fruit-label em { color: var(--accent); font-style: italic; }
.sa-fruit-detail {
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.5;
  color: rgba(255,255,255,0.78);
}
.sa-fruit-detail strong { color: #fff; }
.sa-fruit-detail em { color: rgba(255,255,255,0.95); font-style: italic; }
.sa-partnership-kicker {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.55;
  color: rgba(255,255,255,0.92);
  padding: 14px 16px;
  background: rgba(216,37,43,0.12);
  border-left: 3px solid #d8252b;
  border-radius: 4px;
  text-wrap: pretty;
}
.sa-partnership-kicker strong { color: #fff; }
.sa-partnership-kicker em { color: var(--accent); font-style: italic; }

/* ---------- Coalition members ---------- */
.coalition-members {
  margin: 18px 0 14px;
  padding: 16px 16px 14px;
  background: var(--accent-soft);
  border-radius: 8px;
  border: 1px solid rgba(114,126,78,0.2);
}
.coalition-members-eyebrow {
  font-family: var(--font-subheading);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.coalition-members-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.coalition-members-list span {
  display: inline-block;
  padding: 5px 10px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 999px;
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 600;
  color: var(--tfe-black);
  letter-spacing: 0.02em;
}
.coalition-foot {
  margin-top: 12px !important;
  font-style: italic;
}

/* ---------- Goal body meta line ---------- */
.og-body-meta {
  display: block;
  margin-top: 10px;
  padding: 10px 12px;
  background: rgba(114,126,78,0.08);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  font-size: 13.5px;
  font-style: normal;
  font-weight: 500;
  color: var(--tfe-slate);
}
.og-body-meta strong { color: var(--accent); font-weight: 700; }
.og-body-meta em { color: var(--tfe-black); font-style: italic; }

/* ---------- Perryman explainer ---------- */
.overhead-perryman-source {
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.55;
  color: var(--tfe-slate);
  margin: 12px 0 22px;
  font-style: italic;
}
.overhead-perryman-source strong { color: var(--tfe-black); font-style: normal; }
.overhead-perryman-explainer {
  margin: 0 0 24px;
  padding: 18px 18px 16px;
  background: #fff;
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent);
  border-radius: 8px;
}
.overhead-perryman-explainer-head {
  font-family: var(--font-subheading);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--tfe-black);
  margin-bottom: 10px;
}
.overhead-perryman-explainer-head em { color: var(--accent); font-style: italic; }
.overhead-perryman-explainer-list {
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  display: grid;
  gap: 8px;
}
.overhead-perryman-explainer-list li {
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--tfe-slate);
  padding-left: 16px;
  position: relative;
  text-wrap: pretty;
}
.overhead-perryman-explainer-list li::before {
  content: '·';
  position: absolute;
  left: 4px;
  top: -2px;
  font-size: 24px;
  font-weight: 700;
  color: var(--accent);
}
.overhead-perryman-explainer-list li strong { color: var(--tfe-black); font-weight: 600; }
.overhead-perryman-explainer-foot {
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--tfe-slate);
  padding-top: 10px;
  border-top: 1px dashed var(--border);
  text-wrap: pretty;
}
.overhead-perryman-explainer-foot strong { color: var(--tfe-black); }
.overhead-perryman-grid-source {
  margin-top: 10px;
  font-family: var(--font-body);
  font-size: 11.5px;
  line-height: 1.4;
  color: var(--tfe-slate);
  font-style: italic;
  text-align: center;
}
.overhead-perryman-grid-source em { font-style: italic; color: var(--tfe-black); }
.overhead-perryman-foot-fine {
  margin-top: 8px !important;
  font-family: var(--font-body) !important;
  font-size: 12.5px !important;
  line-height: 1.5 !important;
  color: var(--tfe-slate) !important;
  font-style: italic;
  text-align: left !important;
}

/* ---------- Hero: pounds bag count ---------- */
.hero-stat-sub-inline {
  display: block;
  margin-top: 4px;
  font-size: 10.5px;
  letter-spacing: 0.06em;
  color: var(--accent);
  font-weight: 600;
}

/* ---------- Mobile: SA flow ---------- */
@media (max-width: 480px) {
  .sa-partnership { padding: 28px 18px 24px; }
  .siteplan-marker--built { top: 4%; right: 3%; }
}

/* =========================================================
   SA partnership — LIGHT variant (override dark)
   ========================================================= */
.sa-partnership--light {
  background: #fff !important;
  color: var(--tfe-black);
  border: 1px solid var(--border);
}
.sa-partnership--light .sa-partnership-eyebrow { color: #d8252b; }
.sa-partnership--light .sa-partnership-head { color: var(--tfe-black); }
.sa-partnership--light .sa-partnership-head .em {
  color: #d8252b;
  text-shadow: none;
}
.sa-partnership--light .sa-partnership-deck { color: var(--tfe-slate); }
.sa-partnership--light .sa-partnership-deck strong { color: var(--tfe-black); }

.sa-partnership--light .sa-flow-step {
  background: var(--tfe-cream);
  border: 1px solid var(--border);
}
.sa-partnership--light .sa-flow-step--1 { border-left: 4px solid #d8252b; }
.sa-partnership--light .sa-flow-step--2 { border-left: 4px solid var(--accent); }
.sa-partnership--light .sa-flow-step--3 { border-left: 4px solid var(--tfe-black); }
.sa-partnership--light .sa-flow-step-num {
  background: #fff;
  color: var(--tfe-black);
}
.sa-partnership--light .sa-flow-step--3 .sa-flow-step-num { border-color: var(--tfe-black); }
.sa-partnership--light .sa-flow-step--3 .sa-flow-step-tag { color: var(--tfe-black); }
.sa-partnership--light .sa-flow-step-body { color: var(--tfe-slate); }
.sa-partnership--light .sa-flow-arrow { color: var(--accent); }

.sa-partnership--light .sa-fruit-card {
  background: var(--tfe-cream);
  border: 1px solid var(--border);
}
.sa-partnership--light .sa-fruit-card--lord {
  background: var(--tfe-cream);
  border-left: 4px solid var(--tfe-black);
}
.sa-partnership--light .sa-fruit-card--lord .sa-fruit-num { color: var(--tfe-black); }
.sa-partnership--light .sa-fruit-label { color: var(--tfe-black); }
.sa-partnership--light .sa-fruit-detail { color: var(--tfe-slate); }
.sa-partnership--light .sa-fruit-detail strong { color: var(--tfe-black); }
.sa-partnership--light .sa-fruit-detail em { color: var(--tfe-black); }

.sa-partnership--light .sa-partnership-kicker {
  background: var(--tfe-cream);
  border-left: 3px solid #d8252b;
  padding: 14px 16px;
  border-radius: 4px;
  color: var(--tfe-slate);
}
.sa-partnership--light .sa-partnership-kicker strong { color: var(--tfe-black); }
.sa-partnership--light .sa-partnership-kicker em { color: #d8252b; }

/* ARC sub-block inside light SA partnership */
.sa-arc {
  margin: 18px 0 18px;
  padding: 16px 18px 14px;
  background: linear-gradient(180deg, rgba(216,37,43,0.06) 0%, rgba(216,37,43,0.02) 100%);
  border: 1px solid rgba(216,37,43,0.18);
  border-left: 4px solid #d8252b;
  border-radius: 8px;
}
.sa-arc-tag {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #d8252b;
  margin-bottom: 8px;
}
.sa-arc-body {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.55;
  color: var(--tfe-slate);
  margin: 0;
  text-wrap: pretty;
}
.sa-arc-body strong { color: var(--tfe-black); font-weight: 600; }
.sa-arc-body em { color: var(--tfe-black); font-style: italic; font-weight: 500; }

/* =========================================================
   Site plan — clean variant (no markers)
   ========================================================= */
.siteplan-image--clean {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: #fff;
}
.siteplan-image--clean img {
  width: 100%;
  height: auto;
  display: block;
}

/* =========================================================
   Accusations — point by point card stack
   ========================================================= */
.accusations {
  margin: 36px 0 28px;
  padding: 36px 22px 30px;
  background: linear-gradient(180deg, var(--tfe-cream) 0%, #fff 100%);
  border: 1px solid var(--border);
  border-radius: 14px;
  position: relative;
}
.accusations-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.accusations-head {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(28px, 7vw, 40px);
  line-height: 1.05;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--tfe-black);
  margin-bottom: 16px;
  text-wrap: balance;
}
.accusations-head .em { color: var(--accent); font-style: italic; }
.accusations-lede {
  font-family: var(--font-body);
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--tfe-slate);
  margin-bottom: 26px;
  text-wrap: pretty;
}
.accusations-lede strong { color: var(--tfe-black); font-weight: 600; }
.accusations-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.acc {
  position: relative;
  padding: 18px 18px 18px 60px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 4px 16px -8px rgba(50,68,70,0.08);
}
.acc-num {
  position: absolute;
  top: 16px;
  left: 16px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--tfe-black);
  color: #fff;
  font-family: var(--font-subheading);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 4px;
}
.acc-claim {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(16px, 4.2vw, 19px);
  line-height: 1.35;
  letter-spacing: 0.005em;
  color: var(--tfe-black);
  font-style: italic;
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px dashed rgba(50,68,70,0.18);
  text-wrap: balance;
}
.acc-claim strong {
  font-style: normal;
  color: #d8252b;
  font-weight: 600;
}
.acc-tag {
  display: inline-block;
  font-family: var(--font-subheading);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: #d8252b;
  font-style: normal;
  margin-right: 10px;
  padding: 3px 7px;
  background: rgba(216,37,43,0.08);
  border-radius: 3px;
  vertical-align: middle;
}
.acc-fact {
  font-family: var(--font-body);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--tfe-slate);
  text-wrap: pretty;
}
.acc-fact strong { color: var(--tfe-black); font-weight: 600; }
.acc-fact em { color: var(--tfe-black); font-style: italic; font-weight: 500; }
.acc-fact p { margin: 0 0 12px 0; }
.acc-fact p:last-child { margin-bottom: 0; }
.acc-fact-kicker {
  margin-top: 14px !important;
  padding-top: 12px;
  border-top: 1px dashed rgba(50,68,70,0.18);
  font-style: italic;
  color: var(--tfe-black);
  font-weight: 500;
}
.acc-fact-tag {
  display: inline-block;
  font-family: var(--font-subheading);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--accent);
  margin-right: 10px;
  padding: 3px 7px;
  background: var(--accent-soft);
  border-radius: 3px;
  vertical-align: middle;
}
.accusations-foot {
  margin-top: 22px;
  padding: 14px 16px;
  background: var(--tfe-cream);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.55;
  color: var(--tfe-slate);
  text-wrap: pretty;
}
.accusations-foot strong { color: var(--tfe-black); font-weight: 600; }

@media (max-width: 480px) {
  .accusations { padding: 28px 18px 24px; }
  .acc { padding: 16px 14px 16px 52px; }
  .acc-num { top: 14px; left: 12px; width: 28px; height: 28px; font-size: 12px; }
}

/* =========================================================
   Open letter — LIGHT variant (override dark slate)
   ========================================================= */
.overhead-letter--light {
  background: var(--tfe-cream) !important;
  color: var(--tfe-black) !important;
  border: 1px solid var(--border);
  border-left: 6px solid var(--accent);
  padding: 40px 36px 32px !important;
  border-radius: 10px;
  box-shadow: 0 8px 28px -16px rgba(50,68,70,0.18) !important;
  margin: 32px 0;
  position: relative;
}
.overhead-letter--light .overhead-letter-eyebrow {
  font-family: var(--font-subheading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
  border: none;
}
.overhead-letter--light .overhead-letter-signers {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: baseline;
  padding-bottom: 22px;
  margin-bottom: 28px;
  border-bottom: 1px solid rgba(50,68,70,0.18);
}
.overhead-letter--light .overhead-letter-signers .signer {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(18px, 4.4vw, 22px);
  letter-spacing: 0.01em;
  color: var(--tfe-black);
  line-height: 1.1;
}
.overhead-letter--light .overhead-letter-signers .signer-dot {
  color: var(--accent);
  font-size: 18px;
  font-weight: 700;
}
.overhead-letter-pullquote {
  position: relative;
  padding: 6px 0 22px 0;
  margin-bottom: 22px;
  border-bottom: 1px dashed rgba(50,68,70,0.2);
}
.overhead-letter-pullquote::before {
  content: '\201C';
  position: absolute;
  top: -32px;
  left: -8px;
  font-family: var(--font-heading);
  font-size: 88px;
  line-height: 1;
  color: var(--accent);
  opacity: 0.25;
  pointer-events: none;
}
.overhead-letter-pullquote p {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(20px, 5vw, 28px);
  line-height: 1.3;
  letter-spacing: 0.005em;
  color: var(--tfe-black);
  margin: 0;
  text-wrap: balance;
  position: relative;
}
.overhead-letter-pullquote strong {
  color: var(--accent);
  font-weight: 600;
}
.overhead-letter-pullquote em {
  font-style: italic;
  color: var(--tfe-black);
}
.overhead-letter-body {
  font-family: var(--font-body);
  font-size: clamp(15px, 3.6vw, 16.5px);
  line-height: 1.65;
  color: var(--tfe-slate);
  margin: 0 0 18px 0;
  text-wrap: pretty;
}
.overhead-letter-body strong { color: var(--tfe-black); font-weight: 600; }
.overhead-letter-body em { color: var(--tfe-black); font-style: italic; }
.overhead-letter-body--kicker {
  font-family: var(--font-heading);
  font-size: clamp(16px, 3.8vw, 19px);
  line-height: 1.4;
  color: var(--tfe-black);
  padding: 14px 16px;
  background: #fff;
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  margin-bottom: 24px;
}
.overhead-letter-source {
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid rgba(50,68,70,0.15);
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.overhead-letter-source-label {
  font-family: var(--font-subheading);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--accent);
  flex-shrink: 0;
  padding-top: 2px;
}
.overhead-letter-source-text {
  font-family: var(--font-body);
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--tfe-slate);
  font-style: italic;
}
@media (max-width: 480px) {
  .overhead-letter--light { padding: 28px 20px 24px !important; }
  .overhead-letter-source { flex-direction: column; gap: 6px; }
}
