/* ============================================================
   Brand mark
   ============================================================ */

.brand {
  display: inline-flex;
  align-items: center;
  line-height: 0;
  transition: opacity var(--dur-1) var(--ease-out);
}
.brand:hover { opacity: 0.82; }

.brand__img {
  display: block;
  width: auto;
  height: 44px;
  max-width: 220px;
}
@media (max-width: 600px) {
  .brand__img { height: 36px; max-width: 180px; }
}

.brand--footer .brand__img { height: 56px; max-width: 280px; }

/* ============================================================
   Buttons
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: 0.95rem 1.6rem;
  font-family: var(--font-sans);
  font-size: var(--step--1);
  font-weight: 600;
  letter-spacing: 0.01em;
  border-radius: var(--radius-pill);
  transition: all var(--dur-2) var(--ease-out);
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  border: 1.5px solid transparent;
  position: relative;
  overflow: hidden;
}
.btn--sm { padding: 0.6rem 1.1rem; font-size: var(--step--2); }
.btn--lg { padding: 1.1rem 2.1rem; font-size: var(--step-0); }
.btn--block { width: 100%; }

.btn--primary {
  background: var(--color-navy);
  color: var(--color-white);
  border-color: var(--color-navy);
}
.btn--primary:hover {
  background: var(--color-red);
  border-color: var(--color-red);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
}

.btn--secondary {
  background: var(--color-red);
  color: var(--color-white);
  border-color: var(--color-red);
}
.btn--secondary:hover {
  background: var(--color-red-deep);
  border-color: var(--color-red-deep);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
}

.btn--ghost {
  background: transparent;
  color: var(--color-navy);
  border-color: var(--color-line);
}
.btn--ghost:hover { border-color: var(--color-navy); color: var(--color-navy); background: var(--color-white); }

.btn--ghost-light {
  background: transparent;
  color: var(--color-white);
  border-color: rgba(255,255,255,.4);
}
.btn--ghost-light:hover { background: var(--color-white); color: var(--color-navy); }

.btn .arrow { transition: transform var(--dur-2) var(--ease-out); }
.btn:hover .arrow { transform: translateX(4px); }

.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-weight: 600;
  color: var(--color-navy);
  font-size: var(--step--1);
  letter-spacing: 0.01em;
}
.link-arrow::after {
  content: "→";
  transition: transform var(--dur-2) var(--ease-out);
}
.link-arrow:hover { color: var(--color-red); }
.link-arrow:hover::after { transform: translateX(4px); }

/* ============================================================
   Header & nav
   ============================================================ */

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(250, 250, 247, 0.85);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-2), background-color var(--dur-2);
}
.site-header.is-scrolled { border-bottom-color: var(--color-line); background: rgba(255,255,255,0.92); }

.site-header__bar {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: var(--space-5);
  padding: var(--space-4) var(--gutter);
  max-width: var(--container-wide);
  margin-inline: auto;
}

.primary-nav { display: flex; justify-content: center; }
.primary-nav__list {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}
.primary-nav__link {
  display: inline-block;
  padding: 0.55rem 0.9rem;
  font-size: var(--step--1);
  font-weight: 500;
  color: var(--color-graphite);
  border-radius: var(--radius-pill);
  position: relative;
  transition: color var(--dur-1) var(--ease-out);
}
.primary-nav__link:hover { color: var(--color-navy); }
.primary-nav__link.is-active { color: var(--color-navy); }
.primary-nav__link.is-active::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  background: var(--color-red);
  border-radius: 50%;
}

.nav-toggle { display: none; width: 44px; height: 44px; flex-direction: column; justify-content: center; align-items: center; gap: 5px; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: var(--color-navy); transition: all var(--dur-2) var(--ease-out); border-radius: 2px; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-nav {
  display: none;
  background: var(--color-white);
  border-top: 1px solid var(--color-line);
  padding: var(--space-5) var(--gutter) var(--space-6);
}
.mobile-nav__list { display: flex; flex-direction: column; gap: var(--space-1); margin-bottom: var(--space-5); }
.mobile-nav__link {
  display: block;
  padding: var(--space-3) var(--space-4);
  font-size: var(--step-1);
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--color-ink);
  border-radius: var(--radius);
}
.mobile-nav__link.is-active { color: var(--color-red); }

@media (max-width: 1100px) {
  .primary-nav, .site-header__cta { display: none; }
  .nav-toggle { display: inline-flex; }
  .site-header__bar { grid-template-columns: 1fr auto; }
  .mobile-nav[data-mobile-nav]:not([hidden]) { display: block; }
}

/* ============================================================
   Hero
   ============================================================ */

.hero {
  position: relative;
  padding-block: clamp(4rem, 9vw, 9rem) clamp(3rem, 7vw, 7rem);
  background:
    radial-gradient(1100px 600px at 80% -10%, rgba(200,16,46,0.08), transparent 60%),
    radial-gradient(900px 500px at 0% 0%, rgba(14,42,110,0.08), transparent 60%),
    var(--color-paper);
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(14,42,110,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(14,42,110,0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, black 30%, transparent 75%);
  pointer-events: none;
}

.hero__inner { position: relative; display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--space-9); align-items: center; }
@media (max-width: 1000px) { .hero__inner { grid-template-columns: 1fr; gap: var(--space-7); } }

.hero__title { font-family: var(--font-serif); font-size: clamp(2.75rem, 2.1rem + 3.25vw, 5.25rem); line-height: 1; letter-spacing: -0.028em; font-weight: 700; color: var(--color-ink); }
.hero__title em { font-style: italic; color: var(--color-red); font-weight: 500; }

/* Cycling phrase in the hero headline */
.hero__cycle {
  display: inline-grid;
  vertical-align: baseline;
  position: relative;
}
.hero__cycle em {
  grid-column: 1;
  grid-row: 1;
  font-style: italic;
  color: var(--color-red);
  font-weight: 500;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(0.35em);
  animation: hero-word-cycle 16s infinite var(--ease-out);
}
.hero__cycle em:first-child { opacity: 1; transform: none; }
.hero__cycle em:nth-child(1) { animation-delay: 0s; }
.hero__cycle em:nth-child(2) { animation-delay: 4s; }
.hero__cycle em:nth-child(3) { animation-delay: 8s; }
.hero__cycle em:nth-child(4) { animation-delay: 12s; }
@keyframes hero-word-cycle {
  0%   { opacity: 0; transform: translateY(0.35em); }
  3%   { opacity: 1; transform: translateY(0); }
  22%  { opacity: 1; transform: translateY(0); }
  26%  { opacity: 0; transform: translateY(-0.35em); }
  100% { opacity: 0; transform: translateY(-0.35em); }
}

.hero__lede { margin-top: var(--space-6); }
.hero__cta { margin-top: var(--space-7); display: flex; flex-wrap: wrap; gap: var(--space-3); }

.hero__meta { margin-top: var(--space-7); display: flex; gap: var(--space-7); flex-wrap: wrap; }
.hero__meta-item { display: flex; flex-direction: column; gap: var(--space-1); padding-left: var(--space-4); border-left: 2px solid var(--color-red); }
.hero__meta-num { font-family: var(--font-serif); font-size: var(--step-3); font-weight: 700; color: var(--color-ink); line-height: 1; }
.hero__meta-label { font-size: var(--step--2); text-transform: uppercase; letter-spacing: 0.16em; color: var(--color-slate); font-weight: 600; }

.hero__visual {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-3);
  isolation: isolate;
}
.hero__visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, transparent 40%, rgba(14,42,110,0.45) 100%);
  z-index: 1;
  pointer-events: none;
}

/* Sliding image carousel */
.hero__slides { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero__slide  {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateX(-100%);
  animation: hero-slide-cycle 16s infinite cubic-bezier(0.65, 0, 0.35, 1);
  will-change: transform, opacity;
}
.hero__slide:first-child { opacity: 1; transform: none; } /* default for reduced-motion */
.hero__slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero__slide:nth-child(1) { animation-delay: 0s; }
.hero__slide:nth-child(2) { animation-delay: 4s; }
.hero__slide:nth-child(3) { animation-delay: 8s; }
.hero__slide:nth-child(4) { animation-delay: 12s; }
@keyframes hero-slide-cycle {
  0%   { opacity: 0; transform: translateX(-100%); }
  3%   { opacity: 1; transform: translateX(0); }
  22%  { opacity: 1; transform: translateX(0); }
  28%  { opacity: 0; transform: translateX(60%); }
  100% { opacity: 0; transform: translateX(60%); }
}

@media (prefers-reduced-motion: reduce) {
  .hero__slide,
  .hero__cycle em { animation: none !important; }
  .hero__slide:not(:first-child),
  .hero__cycle em:not(:first-child) { display: none; }
}
.hero__badge {
  position: absolute;
  bottom: var(--space-5);
  left: var(--space-5);
  right: var(--space-5);
  padding: var(--space-5);
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-lg);
  z-index: 2;
}
.hero__badge h4 { font-family: var(--font-serif); color: var(--color-ink); font-size: var(--step-1); margin-bottom: var(--space-2); }
.hero__badge p { font-size: var(--step--1); color: var(--color-graphite); margin: 0; }

/* ============================================================
   Marquee strip
   ============================================================ */

.strip {
  background: var(--color-navy);
  color: rgba(255,255,255,0.92);
  overflow: hidden;
  border-block: 1px solid rgba(255,255,255,0.08);
}
.strip__track {
  display: flex;
  gap: var(--space-7);
  align-items: center;
  padding: var(--space-5) 0;
  white-space: nowrap;
  animation: marquee 38s linear infinite;
}
.strip__item {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--step-2);
  letter-spacing: -0.01em;
}
.strip__item .dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  background: var(--color-red);
  border-radius: 50%;
  margin-inline: var(--space-5);
  vertical-align: middle;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============================================================
   Cards
   ============================================================ */

.card {
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out), border-color var(--dur-2);
  position: relative;
  overflow: hidden;
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  border-color: transparent;
}
.card__num {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 600;
  color: var(--color-red);
  line-height: 1;
  display: inline-block;
  margin-bottom: var(--space-4);
}
.card__title {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: var(--space-3);
  line-height: 1.2;
}
.card__body { color: var(--color-graphite); font-size: var(--step-0); }
.card::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-navy), var(--color-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.card:hover::after { transform: scaleX(1); }

.card--dark {
  background: var(--color-navy);
  border-color: rgba(255,255,255,0.1);
  color: var(--color-white);
}
.card--dark:hover { border-color: var(--color-red); }
.card--dark .card__title { color: var(--color-white); }
.card--dark .card__body { color: rgba(255,255,255,0.78); }
.card--dark .card__num { color: var(--color-red-soft); }

/* ============================================================
   Core Values section (home): Roman-numeral manifesto grid
   ============================================================ */

.values__head {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-9);
}
@media (max-width: 800px) {
  .values__head { grid-template-columns: 1fr; align-items: start; gap: var(--space-5); }
}

.values__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.6rem + 2.5vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.values__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--color-red);
}
.values__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 50ch;
}

/* Hairline 3×3 grid (parent bg shows through 1px gaps) */
.values__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--color-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-1);
}
@media (max-width: 900px) { .values__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .values__grid { grid-template-columns: 1fr; } }

.val-tile {
  background: var(--color-paper);
  padding: clamp(1.75rem, 2.5vw, 2.5rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: background var(--dur-2) var(--ease-out);
  position: relative;
}
.val-tile:hover { background: var(--color-cream); }

/* Featured first tile, anchors the grid */
.val-tile--feature {
  background: linear-gradient(165deg, var(--color-navy), var(--color-navy-deep));
  color: var(--color-white);
}
.val-tile--feature:hover { background: linear-gradient(165deg, var(--color-navy-soft), var(--color-navy)); }

/* Roman numeral, the visual signature */
.val-tile__num {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.7rem + 1.6vw, 3rem);
  font-weight: 600;
  line-height: 0.85;
  letter-spacing: 0.02em;
  color: var(--color-red);
  font-feature-settings: "smcp" off;
}
.val-tile--feature .val-tile__num { color: #FFB3BB; }

.val-tile__title {
  font-family: var(--font-serif);
  font-size: clamp(1.15rem, 1rem + 0.4vw, 1.4rem);
  font-weight: 600;
  line-height: 1.22;
  color: var(--color-ink);
  margin-top: var(--space-2);
}
.val-tile--feature .val-tile__title { color: var(--color-white); }

.val-tile__body {
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: 1.6;
  color: var(--color-graphite);
}
.val-tile--feature .val-tile__body { color: rgba(255, 255, 255, 0.78); }

/* ============================================================
   Value tile (compact, with icon)
   ============================================================ */

.value-tile {
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: all var(--dur-2) var(--ease-out);
  position: relative;
}
.value-tile:hover { border-color: var(--color-navy); transform: translateY(-3px); }
.value-tile__icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-navy), var(--color-navy-soft));
  display: grid;
  place-items: center;
  color: var(--color-white);
}
.value-tile__icon svg { width: 24px; height: 24px; }
.value-tile h3 { font-family: var(--font-serif); font-size: var(--step-1); font-weight: 600; color: var(--color-ink); }
.value-tile p { font-size: var(--step--1); color: var(--color-graphite); }

/* ============================================================
   Page header (interior pages)
   ============================================================ */

.page-head {
  padding-block: clamp(4rem, 8vw, 7rem) clamp(2rem, 4vw, 4rem);
  background:
    radial-gradient(800px 400px at 100% 0%, rgba(200,16,46,0.06), transparent 60%),
    var(--color-paper);
  border-bottom: 1px solid var(--color-line);
}
.page-head__inner { max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.page-head h1 { font-family: var(--font-serif); font-size: var(--step-6); line-height: 1.05; letter-spacing: -0.025em; font-weight: 700; color: var(--color-ink); margin-block: var(--space-4) var(--space-5); max-width: 22ch; }
.page-head__lede { font-family: var(--font-serif); font-size: var(--step-2); color: var(--color-graphite); font-weight: 400; max-width: 60ch; line-height: 1.4; }
.breadcrumb { display: flex; gap: var(--space-2); font-size: var(--step--2); text-transform: uppercase; letter-spacing: 0.14em; color: var(--color-mute); font-weight: 600; }
.breadcrumb a { color: var(--color-slate); }
.breadcrumb a:hover { color: var(--color-navy); }
.breadcrumb__sep { color: var(--color-line); }

/* ============================================================
   Targets section (home)
   ============================================================ */

.targets__head {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-9);
}
@media (max-width: 800px) {
  .targets__head { grid-template-columns: 1fr; align-items: start; gap: var(--space-5); }
}

.targets__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.6rem + 2.5vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.targets__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--color-red);
}
.targets__lede {
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 50ch;
}

/* Bento grid: 3 cols on wide, feature spans 2x2 */
.targets__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: minmax(220px, auto);
  gap: var(--space-5);
}
@media (max-width: 900px) {
  .targets__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: auto; }
}
@media (max-width: 560px) {
  .targets__grid { grid-template-columns: 1fr; }
}

/* Regular card */
.target-card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out),
              border-color var(--dur-2);
}
.target-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-navy), var(--color-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
  z-index: 1;
}
.target-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  border-color: transparent;
}
.target-card:hover::before { transform: scaleX(1); }

.target-card__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.target-card__num {
  font-family: var(--font-serif);
  font-size: var(--step-4);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.target-card__total {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-mute);
  font-weight: 700;
}
.target-card__title {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 600;
  line-height: 1.2;
  color: var(--color-ink);
  margin-top: var(--space-1);
}
.target-card__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.55;
  color: var(--color-graphite);
}

/* ─── Featured card (2x2 bento hero) ─── */
.target-card--feature {
  grid-column: span 2;
  grid-row: span 2;
  padding: clamp(2rem, 3.5vw, 3.5rem);
  background:
    radial-gradient(circle at 80% 20%, rgba(200,16,46,0.18), transparent 55%),
    linear-gradient(165deg, var(--color-navy), var(--color-navy-deep));
  border-color: var(--color-navy-deep);
  color: var(--color-white);
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: var(--space-5);
}
@media (max-width: 900px) {
  .target-card--feature { grid-column: span 2; grid-row: span 1; }
}
@media (max-width: 560px) {
  .target-card--feature { grid-column: span 1; }
}

.target-card--feature::before {
  transform: scaleX(1);
  background: var(--color-red);
  height: 4px;
}
.target-card--feature:hover { transform: none; box-shadow: var(--shadow-3); }

.target-card__bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 70% 80% at 30% 40%, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at 30% 40%, black 30%, transparent 75%);
  pointer-events: none;
  z-index: 0;
}

.target-card--feature > * { position: relative; z-index: 1; }

.target-card--feature .target-card__head { align-items: flex-end; }
.target-card--feature .target-card__num {
  font-size: clamp(4.5rem, 3.5rem + 5vw, 8rem);
  line-height: 0.85;
  color: #FFB3BB;
  letter-spacing: -0.045em;
}
.target-card--feature .target-card__total {
  color: rgba(255, 255, 255, 0.55);
  padding-bottom: 0.6em;
}

.target-card--feature .target-card__title {
  color: var(--color-white);
  font-size: clamp(1.85rem, 1.4rem + 2vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.018em;
  max-width: 18ch;
}
.target-card--feature .target-card__body {
  color: rgba(255, 255, 255, 0.82);
  font-size: var(--step-1);
  line-height: 1.55;
  max-width: 48ch;
  margin-top: var(--space-4);
}

.target-card__quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--step-2);
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.92);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  max-width: 38ch;
}
.target-card__quote em { color: #FFB3BB; font-style: italic; font-weight: 500; }
.target-card__quote::before {
  content: "“";
  color: var(--color-red);
  font-style: normal;
  font-weight: 700;
  margin-right: 0.08em;
}
.target-card__quote::after {
  content: "”";
  color: var(--color-red);
  font-style: normal;
  font-weight: 700;
}

.targets__foot {
  margin-top: var(--space-7);
  text-align: center;
}

/* ============================================================
   Vision &amp; Mission editorial spreads
   ============================================================ */

.vm-head {
  max-width: 60ch;
  margin: 0 auto var(--space-9);
  text-align: center;
}
.vm-head .eyebrow { justify-content: center; display: inline-flex; }
.vm-head__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.7rem + 2.4vw, 3.75rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-block: var(--space-4) var(--space-5);
}
.vm-head__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--color-red);
}
.vm-head__lede {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  line-height: 1.4;
  color: var(--color-graphite);
  font-weight: 400;
  letter-spacing: -0.005em;
  margin: 0 auto;
  max-width: 56ch;
}

.vm-spread {
  display: grid;
  grid-template-columns: 4fr 5fr;
  gap: clamp(2.5rem, 7vw, 7rem);
  align-items: stretch;
  padding-block: var(--space-8);
}
.vm-spread--reverse { grid-template-columns: 5fr 4fr; }
.vm-spread + .vm-spread { border-top: 1px solid var(--color-line); }

.vm-spread--reverse > .vm-spread__media { grid-column: 2; grid-row: 1; }
.vm-spread--reverse > .vm-spread__body  { grid-column: 1; grid-row: 1; }

@media (max-width: 900px) {
  .vm-spread,
  .vm-spread--reverse { grid-template-columns: 1fr; gap: var(--space-6); padding-block: var(--space-7); }
  .vm-spread > .vm-spread__media,
  .vm-spread--reverse > .vm-spread__media { grid-column: 1; grid-row: 1; }
  .vm-spread > .vm-spread__body,
  .vm-spread--reverse > .vm-spread__body  { grid-column: 1; grid-row: 2; }
  .vm-spread__media { aspect-ratio: 4/3; height: auto; }
}

.vm-spread__media {
  position: relative;
  height: 100%;
  min-height: 260px;
  max-height: 420px;
  align-self: center;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-3);
  isolation: isolate;
}
.vm-spread__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 8s var(--ease-out);
}
.vm-spread:hover .vm-spread__media img { transform: scale(1.04); }

.vm-spread__caption {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  padding: 0.45rem 0.95rem;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  letter-spacing: 0.06em;
  font-weight: 600;
  color: var(--color-ink);
  z-index: 1;
}

.vm-spread__body { max-width: 50ch; }

.vm-spread__label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-slate);
  font-weight: 700;
  margin-bottom: var(--space-5);
}
.vm-spread__num {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.025em;
  text-transform: none;
}
.vm-spread__quote {
  font-family: var(--font-serif);
  font-size: clamp(1.6rem, 1.2rem + 1.8vw, 2.6rem);
  line-height: 1.18;
  letter-spacing: -0.022em;
  font-weight: 600;
  color: var(--color-ink);
  margin-bottom: var(--space-5);
}
.vm-spread__quote::before {
  content: "“";
  font-style: normal;
  color: var(--color-red);
  margin-right: 0.05em;
  font-weight: 700;
}
.vm-spread__quote::after {
  content: "”";
  font-style: normal;
  color: var(--color-red);
  font-weight: 700;
}
.vm-spread__text {
  color: var(--color-graphite);
  font-size: var(--step-1);
  line-height: 1.6;
}

/* ============================================================
   Two column block (image + text)
   ============================================================ */

.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-9);
  align-items: center;
}
.two-col--reverse { direction: rtl; }
.two-col--reverse > * { direction: ltr; }
@media (max-width: 900px) {
  .two-col, .two-col--reverse { grid-template-columns: 1fr; gap: var(--space-7); direction: ltr; }
}
.two-col__media {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-3);
}
.two-col__media img { width: 100%; height: 100%; object-fit: cover; }
.two-col__media--wide { aspect-ratio: 5/4; }

/* ============================================================
   Framework section (home): bento-style two panels
   ============================================================ */

.fw__head {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) {
  .fw__head { grid-template-columns: 1fr; align-items: start; gap: var(--space-5); }
}

.fw__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.6rem + 2.5vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.fw__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--color-red);
}
.fw__lede {
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 50ch;
}

.fw__body {
  display: flex;
  flex-direction: column;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-2);
}

/* ─── Stripes (stacked: dark on top, light on bottom) ─── */
.fw-stripe {
  position: relative;
  padding: clamp(2rem, 4vw, 3.5rem) clamp(1.5rem, 3vw, 3rem);
  isolation: isolate;
  overflow: hidden;
}
.fw-stripe--core {
  background: linear-gradient(180deg, var(--color-navy), var(--color-navy-deep));
  color: var(--color-white);
}
.fw-stripe--ext {
  background: var(--color-cream);
  border-top: 1px solid var(--color-line);
}

.fw-stripe__bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 70% 80% at 30% 40%, black 25%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at 30% 40%, black 25%, transparent 75%);
  pointer-events: none;
  z-index: 0;
}
.fw-stripe > * { position: relative; z-index: 1; }

/* Stripe head: eyebrow+title left, sub right */
.fw-stripe__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  padding-bottom: var(--space-7);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  margin-bottom: var(--space-7);
}
.fw-stripe--ext .fw-stripe__head { border-bottom-color: var(--color-line); }

@media (max-width: 800px) {
  .fw-stripe__head { grid-template-columns: 1fr; align-items: start; gap: var(--space-4); }
}

.fw-stripe__label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-red);
}
.fw-stripe__label::before {
  content: "";
  display: inline-block;
  width: 28px;
  height: 1px;
  background: currentColor;
}
.fw-stripe--core .fw-stripe__label { color: #FFB3BB; }

.fw-stripe__title {
  font-family: var(--font-serif);
  font-size: clamp(1.85rem, 1.4rem + 1.6vw, 2.75rem);
  line-height: 1.08;
  font-weight: 700;
  letter-spacing: -0.022em;
  margin-top: var(--space-3);
  color: var(--color-ink);
  max-width: 18ch;
}
.fw-stripe--core .fw-stripe__title { color: var(--color-white); }

.fw-stripe__sub {
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: 1.6;
  color: var(--color-slate);
  max-width: 44ch;
}
.fw-stripe--core .fw-stripe__sub { color: rgba(255, 255, 255, 0.74); }

/* ─── Items: horizontal columns inside each stripe ─── */
.fw-stripe__items {
  display: grid;
  gap: 1px;
  background: rgba(255, 255, 255, 0.10);
}
.fw-stripe--ext .fw-stripe__items { background: var(--color-line); }

.fw-stripe__items--four { grid-template-columns: repeat(4, 1fr); }
.fw-stripe__items--five { grid-template-columns: repeat(5, 1fr); }

@media (max-width: 1300px) {
  .fw-stripe__items--five { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1100px) {
  .fw-stripe__items--four { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .fw-stripe__items--five { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .fw-stripe__items--four,
  .fw-stripe__items--five { grid-template-columns: 1fr; }
}

.fw-item {
  position: relative;
  padding: clamp(2.25rem, 3vw, 2.75rem) clamp(1.5rem, 2vw, 2rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  background: var(--color-navy-deep);
  transition: background var(--dur-2) var(--ease-out);
}
.fw-stripe--ext .fw-item { background: var(--color-cream); }

.fw-item:hover { background: rgba(0, 0, 0, 0.18); }
.fw-stripe--ext .fw-item:hover { background: rgba(14, 42, 110, 0.05); }

.fw-item__num {
  font-family: var(--font-serif);
  font-size: clamp(3rem, 2.2rem + 2.4vw, 4.5rem);
  font-weight: 700;
  line-height: 0.85;
  letter-spacing: -0.045em;
  color: #FFB3BB;
}
.fw-stripe--ext .fw-item__num { color: var(--color-red); }

.fw-item__tag {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.5);
  margin-top: var(--space-1);
}
.fw-stripe--ext .fw-item__tag { color: var(--color-mute); }

.fw-item__title {
  font-family: var(--font-serif);
  font-size: clamp(1.05rem, 0.95rem + 0.4vw, 1.3rem);
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-white);
  margin-top: var(--space-4);
}
.fw-stripe--ext .fw-item__title { color: var(--color-ink); }

.fw-item__text {
  font-family: var(--font-sans);
  font-size: 0.9rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.74);
  margin-top: var(--space-3);
}
.fw-stripe--ext .fw-item__text { color: var(--color-graphite); }

/* ============================================================
   Framework diagram (4S core + 5S extended)
   ============================================================ */

.framework {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-7);
}
@media (max-width: 1000px) { .framework { grid-template-columns: 1fr; } }

.framework__group {
  position: relative;
  padding: var(--space-7);
  border-radius: var(--radius-xl);
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
}
.framework__group--core { background: linear-gradient(180deg, var(--color-navy), var(--color-navy-deep)); color: var(--color-white); border-color: var(--color-navy-deep); }
.framework__group--core h3, .framework__group--core .framework__label { color: var(--color-white); }
.framework__group--core .framework__item { border-color: rgba(255,255,255,0.12); background: rgba(255,255,255,0.03); }
.framework__group--core .framework__item:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.3); }
.framework__group--core .framework__item-num { background: var(--color-red); color: var(--color-white); }

.framework__label { font-family: var(--font-sans); font-size: var(--step--2); text-transform: uppercase; letter-spacing: 0.18em; font-weight: 700; color: var(--color-red); }
.framework__title { font-family: var(--font-serif); font-size: var(--step-4); margin-block: var(--space-3) var(--space-2); font-weight: 700; }
.framework__sub { font-size: var(--step--1); color: var(--color-slate); margin-bottom: var(--space-6); }
.framework__group--core .framework__sub { color: rgba(255,255,255,0.7); }

.framework__list { display: flex; flex-direction: column; gap: var(--space-3); }
.framework__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: start;
  padding: var(--space-4) var(--space-5);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  transition: all var(--dur-2) var(--ease-out);
}
.framework__item:hover { border-color: var(--color-navy); }
.framework__item-num {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--color-navy);
  color: var(--color-white);
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: var(--step--1);
  flex-shrink: 0;
}
.framework__item-title { font-family: var(--font-serif); font-weight: 600; font-size: var(--step-1); margin-bottom: 2px; line-height: 1.25; }
.framework__item-body { font-size: var(--step--1); color: var(--color-graphite); }
.framework__group--core .framework__item-body { color: rgba(255,255,255,0.72); }

/* ============================================================
   Objectives accordion-list
   ============================================================ */

.obj-list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--color-line);
}
.obj-item { border-bottom: 1px solid var(--color-line); padding-block: var(--space-6); }
.obj-item__head { display: grid; grid-template-columns: auto 1fr; gap: var(--space-5); align-items: baseline; }
.obj-item__num { font-family: var(--font-serif); font-size: var(--step-3); color: var(--color-red); font-weight: 600; line-height: 1; }
.obj-item__title { font-family: var(--font-serif); font-size: var(--step-3); color: var(--color-ink); font-weight: 600; line-height: 1.15; }
.obj-item__body { display: grid; grid-template-columns: 2.2fr 1fr; gap: var(--space-7); margin-top: var(--space-5); padding-left: calc(var(--space-3) + 2.2rem); }
@media (max-width: 800px) {
  .obj-item__head { grid-template-columns: 1fr; gap: var(--space-2); }
  .obj-item__body { grid-template-columns: 1fr; padding-left: 0; }
}
.obj-item__goals { display: flex; flex-direction: column; gap: var(--space-3); }
.obj-item__goals li {
  position: relative;
  padding-left: var(--space-5);
  color: var(--color-graphite);
  font-size: var(--step-0);
  line-height: 1.5;
}
.obj-item__goals li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 8px;
  height: 1.5px;
  background: var(--color-red);
}
.obj-item__kpi {
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  align-self: start;
}
.obj-item__kpi-label { font-size: var(--step--2); text-transform: uppercase; letter-spacing: 0.16em; color: var(--color-red); font-weight: 700; margin-bottom: var(--space-3); }
.obj-item__kpi-text { font-family: var(--font-serif); font-size: var(--step-1); color: var(--color-ink); line-height: 1.35; }

/* ============================================================
   Journey timeline
   ============================================================ */

.journey {
  position: relative;
  padding-left: var(--space-6);
}
.journey::before {
  content: "";
  position: absolute;
  left: 13px;
  top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--color-navy), var(--color-red));
}
.journey__item { position: relative; padding-block: var(--space-6); padding-left: var(--space-6); }
.journey__item::before {
  content: "";
  position: absolute;
  left: -7px;
  top: var(--space-7);
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--color-white);
  border: 3px solid var(--color-red);
  box-shadow: 0 0 0 4px var(--color-paper);
}
.journey__stage {
  display: inline-block;
  padding: 0.3rem 0.8rem;
  background: var(--color-navy);
  color: var(--color-white);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 700;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-3);
}
.journey__age { font-size: var(--step--1); color: var(--color-slate); margin-bottom: var(--space-2); font-weight: 500; }
.journey__title { font-family: var(--font-serif); font-size: var(--step-3); color: var(--color-ink); margin-bottom: var(--space-3); line-height: 1.18; }
.journey__body { font-size: var(--step-0); color: var(--color-graphite); max-width: 60ch; }

/* ============================================================
   Global Ecosystem section (home)
   ============================================================ */

.globalsec {
  position: relative;
  padding-block: clamp(4rem, 7vw, 6rem);
  background: var(--color-ink);
  color: var(--color-white);
  isolation: isolate;
  overflow: hidden;
}
.globalsec__bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 90% 70% at 80% 30%, black 25%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 90% 70% at 80% 30%, black 25%, transparent 75%);
  pointer-events: none;
  z-index: 0;
}
.globalsec > .container-wide { position: relative; z-index: 1; }

.globalsec__head {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-9);
}
@media (max-width: 800px) {
  .globalsec__head { grid-template-columns: 1fr; align-items: start; gap: var(--space-5); }
}

.globalsec__eyebrow { color: #FFB3BB; }
.globalsec__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.6rem + 2.5vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-white);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.globalsec__title em {
  font-style: italic;
  font-weight: 500;
  color: #FFB3BB;
}
.globalsec__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  max-width: 50ch;
}

/* Stats grid: feature first column wider, hairline gaps via parent bg */
.globalsec__stats {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 1px;
  background: rgba(255, 255, 255, 0.10);
  border-block: 1px solid rgba(255, 255, 255, 0.10);
}
@media (max-width: 1000px) {
  .globalsec__stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .globalsec__stats { grid-template-columns: 1fr; }
}

.gstat {
  background: var(--color-ink);
  padding: clamp(1.75rem, 3vw, 2.5rem) clamp(1.25rem, 2vw, 2rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: background var(--dur-2) var(--ease-out);
}
.gstat--feature { background: var(--color-navy-deep); }
.gstat:hover { background: rgba(14, 42, 110, 0.55); }

.gstat__num {
  font-family: var(--font-serif);
  font-size: clamp(3rem, 2.2rem + 2.4vw, 5rem);
  font-weight: 700;
  line-height: 0.85;
  letter-spacing: -0.045em;
  color: var(--color-white);
}
.gstat--feature .gstat__num { color: #FFB3BB; }

.gstat__label {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.55);
  margin-top: var(--space-2);
}

.gstat__sub {
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.74);
  margin-top: var(--space-2);
  max-width: 36ch;
}

/* ============================================================
   Stats / metrics row
   ============================================================ */

.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,0.12);
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.stat { padding: var(--space-7) var(--space-5); border-right: 1px solid rgba(255,255,255,0.12); }
.stat:last-child { border-right: 0; }
.stat__num { font-family: var(--font-serif); font-size: var(--step-6); line-height: 1; font-weight: 700; color: var(--color-white); letter-spacing: -0.025em; margin-bottom: var(--space-3); }
.stat__num em { color: var(--color-red); font-style: normal; }
.stat__label { font-size: var(--step--2); text-transform: uppercase; letter-spacing: 0.16em; color: rgba(255,255,255,0.7); font-weight: 600; }
@media (max-width: 800px) {
  .stats { grid-template-columns: repeat(2,1fr); }
  .stat:nth-child(2) { border-right: 0; }
  .stat:nth-child(1), .stat:nth-child(2) { border-bottom: 1px solid rgba(255,255,255,0.12); }
}

/* ============================================================
   World map / continents
   ============================================================ */

.continents {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
@media (max-width: 900px) { .continents { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 500px) { .continents { grid-template-columns: 1fr; } }
.continent {
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  background: var(--color-white);
  transition: all var(--dur-2) var(--ease-out);
  position: relative;
  overflow: hidden;
}
.continent:hover { transform: translateY(-3px); border-color: var(--color-navy); }
.continent__svg { width: 70px; height: 50px; color: var(--color-navy); margin-bottom: var(--space-4); }
.continent h3 { font-family: var(--font-serif); font-size: var(--step-2); font-weight: 600; color: var(--color-ink); margin-bottom: var(--space-2); }
.continent p { font-size: var(--step--1); color: var(--color-graphite); }

/* ============================================================
   Manifesto pull-quote (home)
   ============================================================ */

.manifesto {
  padding-block: clamp(4rem, 8vw, 7rem);
  background: var(--color-paper);
  text-align: center;
}
.manifesto__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.manifesto__rule {
  width: 60px;
  height: 1px;
  background: var(--color-red);
  margin-bottom: var(--space-5);
}
.manifesto__eyebrow {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-red);
  margin-bottom: var(--space-7);
}
.manifesto__body {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.85rem, 1.3rem + 2vw, 3rem);
  line-height: 1.25;
  letter-spacing: -0.018em;
  color: var(--color-ink);
  font-weight: 400;
  position: relative;
  max-width: 26ch;
  margin: 0;
  padding-inline: 0.4em;
}
.manifesto__body em {
  font-style: italic;
  font-weight: 500;
  color: var(--color-red);
}
.manifesto__body::before,
.manifesto__body::after {
  position: absolute;
  font-style: normal;
  font-weight: 700;
  color: var(--color-red);
  font-size: 1.15em;
  line-height: 0.9;
  font-family: var(--font-serif);
}
.manifesto__body::before {
  content: "“";
  left: -0.45em;
  top: -0.15em;
}
.manifesto__body::after {
  content: "”";
  right: -0.45em;
  bottom: -0.4em;
}

.manifesto__attr {
  margin-top: var(--space-7);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: var(--color-slate);
}
.manifesto__attr-rule {
  width: 28px;
  height: 1px;
  background: var(--color-line);
}

/* ============================================================
   Closer (home final CTA)
   ============================================================ */

.closer {
  padding-block: clamp(2rem, 4vw, 3rem) clamp(4rem, 7vw, 6rem);
}
.closer__panel {
  position: relative;
  border-radius: var(--radius-xl);
  padding: clamp(3rem, 6vw, 5rem) clamp(2rem, 5vw, 4rem);
  background:
    radial-gradient(circle at 75% 25%, rgba(200, 16, 46, 0.20), transparent 55%),
    linear-gradient(165deg, var(--color-navy-deep), var(--color-navy));
  color: var(--color-white);
  text-align: center;
  isolation: isolate;
  overflow: hidden;
  box-shadow: var(--shadow-3);
}
.closer__bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255, 255, 255, 0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 30%, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 30%, black 30%, transparent 75%);
  pointer-events: none;
  z-index: 0;
}
.closer__panel > *:not(.closer__bg) { position: relative; z-index: 1; }

.closer__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: #FFB3BB;
}
.closer__eyebrow::before,
.closer__eyebrow::after {
  content: "";
  display: inline-block;
  width: 28px;
  height: 1px;
  background: currentColor;
}

.closer__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.6rem + 2.5vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-white);
  margin-block: var(--space-5) var(--space-5);
  max-width: 22ch;
  margin-inline: auto;
}
.closer__title em {
  font-style: italic;
  font-weight: 500;
  color: #FFB3BB;
}

.closer__lede {
  max-width: 56ch;
  margin: 0 auto var(--space-7);
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.82);
}

.closer__actions {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  flex-wrap: wrap;
}
.closer__actions .btn { flex-shrink: 0; }

/* ============================================================
   CTA banner
   ============================================================ */

.cta-banner {
  position: relative;
  padding: clamp(3rem, 6vw, 5rem) var(--gutter);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 80% 20%, rgba(200,16,46,0.18), transparent 50%),
    linear-gradient(135deg, var(--color-navy-deep), var(--color-navy));
  color: var(--color-white);
  overflow: hidden;
}
.cta-banner::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 56px 56px;
  pointer-events: none;
}
.cta-banner__inner { position: relative; max-width: var(--container); margin-inline: auto; display: grid; grid-template-columns: 1.6fr 1fr; gap: var(--space-7); align-items: center; }
@media (max-width: 800px) { .cta-banner__inner { grid-template-columns: 1fr; } }
.cta-banner h2 { font-family: var(--font-serif); font-size: var(--step-5); font-weight: 700; line-height: 1.05; letter-spacing: -0.022em; color: var(--color-white); }
.cta-banner h2 em { font-style: italic; color: #FFB3BB; font-weight: 500; }
.cta-banner p { color: rgba(255,255,255,0.78); font-size: var(--step-1); margin-top: var(--space-4); max-width: 50ch; }
.cta-banner__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; justify-content: flex-end; }
@media (max-width: 800px) { .cta-banner__actions { justify-content: flex-start; } }

/* ============================================================
   Footer
   ============================================================ */

.site-footer {
  background: var(--color-ink);
  color: rgba(255,255,255,0.78);
  padding-block: var(--space-8) var(--space-5);
}
.site-footer__top { display: grid; grid-template-columns: 1fr 2fr; gap: var(--space-9); padding-bottom: var(--space-7); border-bottom: 1px solid rgba(255,255,255,0.08); }
@media (max-width: 800px) { .site-footer__top { grid-template-columns: 1fr; gap: var(--space-7); } }
.site-footer__brand .brand { color: var(--color-white); margin-bottom: var(--space-4); }
.site-footer__tagline { font-family: var(--font-serif); font-style: italic; font-size: var(--step-1); color: rgba(255,255,255,0.85); }
.site-footer__period { font-size: var(--step--2); text-transform: uppercase; letter-spacing: 0.16em; color: rgba(255,255,255,0.5); margin-top: var(--space-3); font-weight: 600; }
.site-footer__columns { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
@media (max-width: 700px) { .site-footer__columns { grid-template-columns: repeat(2, 1fr); } }
.site-footer__heading { font-family: var(--font-sans); font-size: var(--step--2); text-transform: uppercase; letter-spacing: 0.16em; color: var(--color-red-soft); margin-bottom: var(--space-4); font-weight: 700; }
.site-footer__column ul { display: flex; flex-direction: column; gap: var(--space-2); }
.site-footer__column a { font-size: var(--step--1); color: rgba(255,255,255,0.7); transition: color var(--dur-1); }
.site-footer__column a:hover { color: var(--color-white); }
.site-footer__bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-3); padding-top: var(--space-5); font-size: var(--step--2); color: rgba(255,255,255,0.55); }
.site-footer__small { letter-spacing: 0.04em; }

/* ============================================================
   Form
   ============================================================ */

.form { display: flex; flex-direction: column; gap: var(--space-5); }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }
@media (max-width: 700px) { .form__row { grid-template-columns: 1fr; } }
.form__group { display: flex; flex-direction: column; gap: var(--space-2); }
.form__label { font-size: var(--step--1); font-weight: 600; color: var(--color-ink); }
.form__input, .form__textarea, .form__select {
  width: 100%;
  padding: 0.95rem 1.1rem;
  background: var(--color-white);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  font-size: var(--step-0);
  color: var(--color-ink);
  font-family: var(--font-sans);
  line-height: 1.4;
  transition: border-color var(--dur-1), box-shadow var(--dur-1);
}
.form__input:focus, .form__textarea:focus, .form__select:focus { outline: 0; border-color: var(--color-navy); box-shadow: 0 0 0 3px rgba(14,42,110,0.12); }
.form__textarea { resize: vertical; min-height: 160px; }

/* Custom select with SVG chevron */
.form__select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 2.75rem;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='8' viewBox='0 0 14 8' fill='none'><path d='M1 1l6 6 6-6' stroke='%230E2A6E' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 1.1rem center;
  background-size: 14px 8px;
  cursor: pointer;
}
.form__select:focus {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='8' viewBox='0 0 14 8' fill='none'><path d='M1 1l6 6 6-6' stroke='%23C8102E' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
}
.form__select:invalid,
.form__select option[disabled] { color: var(--color-mute); }
.form__select option { color: var(--color-ink); background: var(--color-white); padding: 0.5rem; }
/* Hide native arrow in IE/Edge legacy */
.form__select::-ms-expand { display: none; }
.form__hp { position: absolute; left: -9999px; top: -9999px; }
.form__success {
  padding: var(--space-5) var(--space-6);
  background: linear-gradient(135deg, rgba(14,42,110,0.06), rgba(200,16,46,0.06));
  border: 1px solid rgba(14,42,110,0.15);
  border-radius: var(--radius-lg);
  color: var(--color-ink);
}
.form__success strong { color: var(--color-navy); }

/* ============================================================
   Pull quote
   ============================================================ */

.pull-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--step-4);
  line-height: 1.25;
  letter-spacing: -0.012em;
  color: var(--color-ink);
  max-width: 28ch;
  position: relative;
  padding-left: var(--space-6);
}
.pull-quote::before {
  content: "“";
  position: absolute;
  left: -0.1em;
  top: -0.3em;
  font-size: 4em;
  color: var(--color-red);
  line-height: 1;
  font-style: normal;
  font-weight: 700;
}
.pull-quote__attr { display: block; font-style: normal; font-family: var(--font-sans); font-size: var(--step--1); color: var(--color-slate); margin-top: var(--space-4); text-transform: uppercase; letter-spacing: 0.14em; font-weight: 600; }

/* ============================================================
   Section heading helper
   ============================================================ */

.sect-heading { display: grid; grid-template-columns: 1fr auto; align-items: end; gap: var(--space-7); margin-bottom: var(--space-7); }
@media (max-width: 800px) { .sect-heading { grid-template-columns: 1fr; align-items: start; } }
.sect-heading__title { max-width: 26ch; }
.sect-heading__lede { max-width: 50ch; color: var(--color-graphite); font-size: var(--step-1); line-height: 1.5; }

/* ============================================================
   Pathways · home Continuum rail (between Targets & Framework)
   ============================================================ */

.pathways__feature {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
  margin-bottom: var(--space-9);
}
@media (max-width: 900px) {
  .pathways__feature { grid-template-columns: 1fr; gap: var(--space-7); }
}

.pathways__media {
  position: relative;
  aspect-ratio: 5 / 4;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-2);
  isolation: isolate;
}
.pathways__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--dur-3) var(--ease-out);
}
.pathways__feature:hover .pathways__media img { transform: scale(1.03); }
.pathways__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(11, 21, 48, 0.65) 100%);
  pointer-events: none;
  z-index: 1;
}
.pathways__media-caption {
  position: absolute;
  left: clamp(1.25rem, 2vw, 2rem);
  bottom: clamp(1.25rem, 2vw, 1.75rem);
  z-index: 2;
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-white);
}
.pathways__media-tag {
  position: absolute;
  top: clamp(1rem, 1.6vw, 1.5rem);
  right: clamp(1rem, 1.6vw, 1.5rem);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: 0.55rem 0.95rem;
  background: rgba(255, 255, 255, 0.92);
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 700;
  color: var(--color-ink);
  backdrop-filter: blur(6px);
}
.pathways__media-arrow { color: var(--color-red); font-weight: 700; }

.pathways__intro { display: flex; flex-direction: column; gap: var(--space-4); }
.pathways__intro-link { margin-top: var(--space-3); align-self: flex-start; }

.pathways__title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 1.4rem + 2.2vw, 3.25rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin: 0;
  max-width: 18ch;
}
.pathways__title em { font-style: italic; font-weight: 500; color: var(--color-red); }
.pathways__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 50ch;
  margin: 0;
}

.pathways__rail {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 1px;
  background: var(--color-line);
  border-block: 1px solid var(--color-line);
}
@media (max-width: 1100px) { .pathways__rail { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 700px)  { .pathways__rail { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px)  { .pathways__rail { grid-template-columns: 1fr; } }

.pathway {
  background: var(--color-paper);
  padding: clamp(1.5rem, 2.5vw, 2.25rem) clamp(1rem, 1.6vw, 1.5rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background var(--dur-2) var(--ease-out);
}
.pathway:hover { background: var(--color-white); }

.pathway__node {
  font-family: var(--font-serif);
  font-size: clamp(1.85rem, 1.4rem + 1.4vw, 2.6rem);
  line-height: 0.85;
  letter-spacing: -0.04em;
  font-weight: 700;
  color: var(--color-red);
}
.pathway__stage {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-3);
}
.pathway__age {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  letter-spacing: 0.04em;
  color: var(--color-mute);
}
.pathway__title {
  font-family: var(--font-serif);
  font-size: clamp(1rem, 0.9rem + 0.4vw, 1.18rem);
  font-weight: 600;
  line-height: 1.22;
  color: var(--color-ink);
  margin-top: var(--space-3);
}

.pathways__foot { margin-top: var(--space-7); text-align: center; }

/* ============================================================
   Governance & Quality · home pillars (between Global & Values)
   ============================================================ */

.govern__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) {
  .govern__head { grid-template-columns: 1fr; align-items: start; gap: var(--space-5); }
}
.govern__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.6rem + 2.5vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.govern__title em { font-style: italic; font-weight: 500; color: var(--color-red); }
.govern__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 50ch;
}

.govern__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 1px;
  background: var(--color-line);
  border-block: 1px solid var(--color-line);
}
@media (max-width: 1000px) { .govern__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .govern__grid { grid-template-columns: 1fr; } }

.pillar {
  background: var(--color-cream);
  padding: clamp(1.75rem, 3vw, 2.5rem) clamp(1.25rem, 2vw, 2rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: background var(--dur-2) var(--ease-out);
}
.pillar:hover { background: var(--color-paper); }
.pillar--feature {
  background: var(--color-navy);
  color: var(--color-white);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 22rem;
}
.pillar--feature:hover { background: var(--color-navy-deep); }

.pillar--feature > *:not(.pillar__media) { position: relative; z-index: 2; }

.pillar__media {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.pillar__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: 0.55;
  transition: transform var(--dur-3) var(--ease-out), opacity var(--dur-2) var(--ease-out);
}
.pillar__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8, 26, 71, 0.55) 0%, rgba(8, 26, 71, 0.85) 60%, rgba(8, 26, 71, 0.95) 100%),
    radial-gradient(circle at 80% 20%, rgba(200, 16, 46, 0.25), transparent 55%);
  z-index: 1;
}
.pillar--feature:hover .pillar__media img { transform: scale(1.04); opacity: 0.65; }

.pillar__tag {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-weight: 700;
  color: var(--color-mute);
}
.pillar--feature .pillar__tag { color: #FFB3BB; }

.pillar__title {
  font-family: var(--font-serif);
  font-size: clamp(1.15rem, 1rem + 0.5vw, 1.45rem);
  font-weight: 600;
  line-height: 1.22;
  color: var(--color-ink);
  margin-top: var(--space-2);
}
.pillar--feature .pillar__title { color: var(--color-white); }

.pillar__body {
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: 1.55;
  color: var(--color-graphite);
  max-width: 36ch;
  margin: 0;
}
.pillar--feature .pillar__body { color: rgba(255, 255, 255, 0.78); }

.govern__foot { margin-top: var(--space-7); text-align: center; }

/* ============================================================
   Coda · brand close after manifesto
   ============================================================ */

.coda {
  position: relative;
  padding-block: clamp(3rem, 6vw, 5rem);
  background:
    radial-gradient(circle at 78% 28%, rgba(200, 16, 46, 0.18), transparent 55%),
    linear-gradient(165deg, var(--color-navy-deep), var(--color-navy));
  color: var(--color-white);
  overflow: hidden;
  isolation: isolate;
}
.coda__bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255, 255, 255, 0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 75%);
  pointer-events: none;
  z-index: 0;
}
.coda__inner {
  position: relative;
  z-index: 1;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}

.coda__mark {
  font-family: var(--font-serif);
  font-size: var(--step--1);
  text-transform: uppercase;
  letter-spacing: 0.45em;
  font-weight: 700;
  color: #FFB3BB;
}

.coda__tagline {
  font-family: var(--font-serif);
  font-size: clamp(1.85rem, 1.3rem + 2vw, 3.25rem);
  line-height: 1.1;
  letter-spacing: -0.018em;
  font-weight: 700;
  color: var(--color-white);
  margin: 0;
  max-width: 22ch;
}
.coda__tagline em { font-style: italic; font-weight: 500; color: #FFB3BB; }
.coda__sep { display: inline-block; margin: 0 0.35em; color: var(--color-red); font-weight: 400; }

.coda__url {
  font-family: var(--font-sans);
  font-size: var(--step--1);
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  margin-top: var(--space-4);
  border-bottom: 1px solid transparent;
  transition: color var(--dur-1) var(--ease-out), border-color var(--dur-1) var(--ease-out);
}
.coda__url:hover { color: var(--color-white); border-bottom-color: rgba(255, 255, 255, 0.5); }

/* ============================================================
   About page · editorial sections (page-local only)
   AH = About Hero family, used only on /about
   ============================================================ */

/* ─── Editorial hero (left-aligned, typography-only) ─── */
.ah-hero {
  position: relative;
  padding-block: clamp(3.5rem, 6vw, 6rem) clamp(3rem, 5vw, 5rem);
  background:
    radial-gradient(900px 500px at 100% 0%, rgba(200, 16, 46, 0.06), transparent 60%),
    radial-gradient(700px 400px at 0% 100%, rgba(14, 42, 110, 0.04), transparent 60%),
    var(--color-paper);
  border-bottom: 1px solid var(--color-line);
  overflow: hidden;
}
.ah-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(14, 42, 110, 0.035) 1px, transparent 1px);
  background-size: 96px 100%;
  mask-image: radial-gradient(ellipse 75% 65% at 50% 50%, black 25%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 75% 65% at 50% 50%, black 25%, transparent 80%);
  pointer-events: none;
}
.ah-hero > .container-wide { position: relative; z-index: 1; }

.ah-hero__inner {
  max-width: 60rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: clamp(1.5rem, 2.5vw, 2rem);
}

.ah-hero__mark {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.32em;
  font-weight: 700;
  color: var(--color-navy);
}
.ah-hero__mark::before {
  content: "";
  display: inline-block;
  width: 36px;
  height: 1px;
  background: var(--color-red);
}

.ah-hero__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin: 0;
  max-width: 22ch;
  text-align: left;
}
.ah-hero__title em {
  font-style: italic;
  color: var(--color-red);
  font-weight: 500;
}

.ah-hero__lede {
  font-family: var(--font-serif);
  font-size: clamp(1.15rem, 1.02rem + 0.4vw, 1.4rem);
  line-height: 1.5;
  color: var(--color-graphite);
  max-width: 56ch;
  font-weight: 400;
  margin: 0;
}

.ah-hero__sig {
  margin-top: var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 600;
  color: var(--color-slate);
}
.ah-hero__sig::before {
  content: "";
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--color-line);
}
.ah-hero__sig em {
  font-style: normal;
  color: var(--color-red);
  font-weight: 700;
}

/* ─── Long-form intro (magazine spread: meta sidebar + dropcap body) ─── */
.ah-intro { padding-block: clamp(4rem, 7vw, 7rem); background: var(--color-paper); }
.ah-intro__grid {
  display: grid;
  grid-template-columns: 1fr 2.4fr;
  gap: clamp(2rem, 5vw, 6rem);
  align-items: start;
}
@media (max-width: 900px) { .ah-intro__grid { grid-template-columns: 1fr; gap: var(--space-6); } }

.ah-intro__meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding-top: var(--space-4);
  border-top: 2px solid var(--color-red);
  position: sticky;
  top: 110px;
}
@media (max-width: 900px) { .ah-intro__meta { position: static; } }

.ah-intro__chap {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 700;
  color: var(--color-navy);
}
.ah-intro__heading {
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 1.1rem + 1.4vw, 2.25rem);
  line-height: 1.15;
  letter-spacing: -0.018em;
  font-weight: 700;
  color: var(--color-ink);
  max-width: 18ch;
  margin: 0;
}
.ah-intro__heading em { font-style: italic; color: var(--color-red); font-weight: 500; }

.ah-intro__body p {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  line-height: 1.55;
  color: var(--color-graphite);
  max-width: 60ch;
  margin-top: var(--space-5);
  font-weight: 400;
}
.ah-intro__body p:first-child { margin-top: 0; }
.ah-intro__lead::first-letter {
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: 4.6em;
  float: left;
  line-height: 0.85;
  padding: 0.05em 0.16em 0 0;
  color: var(--color-red);
}
.ah-intro__quote {
  display: block;
  margin: var(--space-8) 0;
  padding: var(--space-5) 0 var(--space-5) var(--space-6);
  border-left: 3px solid var(--color-red);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.5rem, 1.05rem + 1.4vw, 2.15rem);
  line-height: 1.3;
  color: var(--color-ink);
  font-weight: 500;
  letter-spacing: -0.012em;
  max-width: 36ch;
}
.ah-intro__quote em { color: var(--color-red); font-style: italic; }

/* ─── We Are / We Are Not contrast ─── */
.ah-contrast {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-cream);
  border-block: 1px solid var(--color-line);
}
.ah-contrast__head { margin-bottom: var(--space-8); max-width: 56rem; }
.ah-contrast__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 22ch;
}
.ah-contrast__title em { font-style: italic; color: var(--color-red); font-weight: 500; }

.ah-contrast__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--color-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-1);
}
@media (max-width: 760px) { .ah-contrast__grid { grid-template-columns: 1fr; } }

.ah-contrast__col {
  position: relative;
  background: var(--color-paper);
  padding: clamp(2rem, 3.5vw, 3rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  overflow: hidden;
}
.ah-contrast__col--isnt { background: #FBFAF6; }
.ah-contrast__col::after {
  position: absolute;
  top: clamp(0.75rem, 1.5vw, 1.25rem);
  right: clamp(1.25rem, 2.5vw, 2rem);
  font-family: var(--font-serif);
  font-size: clamp(4rem, 8vw, 7rem);
  font-weight: 700;
  line-height: 0.85;
  letter-spacing: -0.04em;
  pointer-events: none;
  user-select: none;
}
.ah-contrast__col--is::after { content: "01"; color: rgba(200, 16, 46, 0.10); }
.ah-contrast__col--isnt::after { content: "02"; color: rgba(138, 146, 166, 0.20); }
.ah-contrast__label {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
}
.ah-contrast__col--is .ah-contrast__label { color: var(--color-red); }
.ah-contrast__col--isnt .ah-contrast__label { color: var(--color-mute); }

.ah-contrast__col h3 {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--color-ink);
  margin: 0;
}
.ah-contrast__col--isnt h3 { color: var(--color-slate); }

.ah-contrast__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  position: relative;
}
.ah-contrast__item {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.5;
  color: var(--color-graphite);
  align-items: start;
  padding: var(--space-4) 0;
  border-bottom: 1px solid rgba(11, 21, 48, 0.07);
  transition: transform var(--dur-2) var(--ease-out), color var(--dur-2) var(--ease-out);
}
.ah-contrast__item:last-child { border-bottom: 0; }
.ah-contrast__col--is .ah-contrast__item:hover { transform: translateX(6px); color: var(--color-ink); }
.ah-contrast__col--isnt .ah-contrast__item:hover { transform: translateX(6px); color: var(--color-graphite); }
.ah-contrast__item::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-top: 0.35em;
  border-radius: 50%;
}
.ah-contrast__col--is .ah-contrast__item::before {
  background: var(--color-red);
  box-shadow: 0 0 0 4px rgba(200, 16, 46, 0.12);
}
.ah-contrast__col--isnt .ah-contrast__item { color: var(--color-slate); }
.ah-contrast__col--isnt .ah-contrast__item::before {
  background: transparent;
  border: 1.5px solid var(--color-mute);
}

/* ─── Triptych (Origin / Purpose / Promise) ─── */
.ah-triptych { padding-block: clamp(4rem, 7vw, 7rem); background: var(--color-paper); }
.ah-triptych__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .ah-triptych__head { grid-template-columns: 1fr; align-items: start; } }
.ah-triptych__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.ah-triptych__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.ah-triptych__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
}

.ah-triptych__cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 900px) { .ah-triptych__cols { grid-template-columns: 1fr; } }

.ah-triptych__col {
  position: relative;
  padding: var(--space-7) var(--space-6);
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  overflow: hidden;
  transition: transform var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out),
              border-color var(--dur-2) var(--ease-out);
}
.ah-triptych__col:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  border-color: transparent;
}
.ah-triptych__col::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-navy), var(--color-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.ah-triptych__col:hover::before { transform: scaleX(1); }

/* Featured first card - navy (matches Home's feature treatment) */
.ah-triptych__col--feature {
  background: linear-gradient(165deg, var(--color-navy), var(--color-navy-deep));
  border-color: transparent;
  color: var(--color-white);
}
.ah-triptych__col--feature::before { background: var(--color-red); transform: scaleX(1); }
.ah-triptych__col--feature:hover { background: linear-gradient(165deg, var(--color-navy-soft), var(--color-navy)); }

.ah-triptych__numrow {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-3);
}
.ah-triptych__num {
  font-family: var(--font-serif);
  font-size: clamp(3.5rem, 2.5rem + 3vw, 5.5rem);
  font-weight: 600;
  line-height: 0.85;
  color: var(--color-red);
  letter-spacing: -0.02em;
}
.ah-triptych__col--feature .ah-triptych__num { color: #FFB3BB; }

.ah-triptych__index {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 600;
  color: var(--color-mute);
}
.ah-triptych__col--feature .ah-triptych__index { color: rgba(255, 255, 255, 0.45); }

.ah-triptych__cap {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-navy);
}
.ah-triptych__col--feature .ah-triptych__cap { color: #FFB3BB; }

.ah-triptych__col h3 {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--color-ink);
  margin: 0;
}
.ah-triptych__col--feature h3 { color: var(--color-white); }

.ah-triptych__col p {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.65;
  color: var(--color-graphite);
  max-width: none;
  margin: 0;
}
.ah-triptych__col--feature p { color: rgba(255, 255, 255, 0.82); }

/* Trailing arrow (subtle reading-flow nudge) */
.ah-triptych__col:not(:last-child)::after {
  content: "→";
  position: absolute;
  bottom: var(--space-5);
  right: var(--space-6);
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 400;
  color: var(--color-line);
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity var(--dur-2) var(--ease-out), transform var(--dur-2) var(--ease-out), color var(--dur-2);
}
.ah-triptych__col:not(:last-child):hover::after {
  opacity: 1;
  transform: translateX(0);
  color: var(--color-red);
}
.ah-triptych__col--feature:not(:last-child)::after { color: rgba(255, 255, 255, 0.25); }
.ah-triptych__col--feature:not(:last-child):hover::after { color: #FFB3BB; }
@media (max-width: 900px) {
  .ah-triptych__col:not(:last-child)::after { display: none; }
}

/* ─── Strategic horizon 2026 to 2030 ─── */
.ah-horizon {
  position: relative;
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-ink);
  color: var(--color-white);
  overflow: hidden;
}
.ah-horizon > .container-wide { position: relative; z-index: 1; }
.ah-horizon__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .ah-horizon__head { grid-template-columns: 1fr; align-items: start; } }
.ah-horizon__head .eyebrow { color: #FFB3BB; }
.ah-horizon__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-white);
  margin-top: var(--space-4);
  max-width: 20ch;
}
.ah-horizon__title em { font-style: italic; color: #FFB3BB; font-weight: 500; }
.ah-horizon__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  max-width: 46ch;
  margin: 0;
}

.ah-horizon__track {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-3);
  margin-top: var(--space-8);
  padding-top: 28px;
}
@media (max-width: 900px) { .ah-horizon__track { grid-template-columns: repeat(2, 1fr); padding-top: 22px; } }
@media (max-width: 520px) { .ah-horizon__track { grid-template-columns: 1fr; } }

/* Continuous red rail running through every dot */
.ah-horizon__track::before {
  content: "";
  position: absolute;
  top: 14px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    var(--color-red) 0%,
    rgba(200, 16, 46, 0.55) 65%,
    rgba(255, 255, 255, 0.15) 100%);
  z-index: 0;
}
@media (max-width: 900px) { .ah-horizon__track::before { display: none; } }

.ah-horizon__step {
  position: relative;
  padding: var(--space-6) var(--space-5);
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: transform var(--dur-2) var(--ease-out),
              background var(--dur-2) var(--ease-out),
              border-color var(--dur-2) var(--ease-out);
}
.ah-horizon__step:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.2);
}

/* Dot sits on the rail above each card */
.ah-horizon__step::before {
  content: "";
  position: absolute;
  top: -20px;
  left: var(--space-5);
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--color-red);
  box-shadow: 0 0 0 4px var(--color-ink), 0 0 0 5px rgba(200, 16, 46, 0.45);
  z-index: 1;
  transition: transform var(--dur-2) var(--ease-out);
}
.ah-horizon__step:hover::before { transform: scale(1.15); }
@media (max-width: 900px) { .ah-horizon__step::before { display: none; } }

/* Featured first step (2026 — begins here) */
.ah-horizon__step--feature {
  background: linear-gradient(165deg, rgba(200, 16, 46, 0.16), rgba(200, 16, 46, 0.04));
  border-color: rgba(200, 16, 46, 0.35);
}
.ah-horizon__step--feature::before {
  background: var(--color-white);
  box-shadow: 0 0 0 4px var(--color-ink), 0 0 0 6px var(--color-red);
}

.ah-horizon__tag {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px var(--space-3);
  background: var(--color-red);
  color: var(--color-white);
  border-radius: 99px;
  font-family: var(--font-sans);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-weight: 700;
  margin-bottom: var(--space-1);
}

.ah-horizon__year {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-white);
  line-height: 1;
}
.ah-horizon__cap {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 700;
  color: #FFB3BB;
}
.ah-horizon__step p {
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.78);
  max-width: none;
  margin: 0;
}

/* ─── Closing band (centered text-only) ─── */
.ah-end {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
  text-align: center;
}
.ah-end__inner {
  max-width: 48rem;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}
.ah-end__title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 1.45rem + 2vw, 3.25rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 700;
  color: var(--color-ink);
  max-width: 18ch;
}
.ah-end__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.ah-end__sub {
  font-family: var(--font-serif);
  font-size: var(--step-1);
  color: var(--color-graphite);
  max-width: 50ch;
  margin: 0;
}
.ah-end__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-5) var(--space-7);
  margin-top: var(--space-5);
}

/* ============================================================
   Framework page · editorial sections (page-local)
   FW = Framework family, used only on /framework
   ============================================================ */

/* ─── Composition formula (04 + 05 = 09) ─── */
.fw-composition {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
  text-align: center;
}
.fw-composition__head {
  max-width: 60rem;
  margin-inline: auto;
  margin-bottom: var(--space-8);
}
.fw-composition__head .eyebrow { justify-content: center; }
.fw-composition__title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 1.5rem + 2vw, 3.25rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 700;
  color: var(--color-ink);
  margin: var(--space-4) auto 0;
  max-width: 22ch;
}
.fw-composition__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.fw-composition__lede {
  font-family: var(--font-serif);
  font-size: var(--step-1);
  line-height: 1.55;
  color: var(--color-graphite);
  max-width: 52ch;
  margin: var(--space-4) auto 0;
}

.fw-composition__formula {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(1rem, 2.5vw, 2.5rem);
  flex-wrap: wrap;
}

.fw-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-7) var(--space-7);
  border-radius: var(--radius-lg);
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  min-width: 12rem;
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
}
.fw-tile:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); }
.fw-tile--sum {
  background: linear-gradient(165deg, var(--color-navy), var(--color-navy-deep));
  border-color: transparent;
  color: var(--color-white);
}
.fw-tile--sum:hover { background: linear-gradient(165deg, var(--color-navy-soft), var(--color-navy)); }

.fw-tile__num {
  font-family: var(--font-serif);
  font-size: clamp(3.5rem, 2.5rem + 2.5vw, 5.5rem);
  font-weight: 700;
  line-height: 1;
  color: var(--color-ink);
  letter-spacing: -0.03em;
}
.fw-tile--sum .fw-tile__num { color: var(--color-white); }
.fw-tile__label {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-mute);
  margin-top: var(--space-2);
  text-align: center;
}
.fw-tile--sum .fw-tile__label { color: #FFB3BB; }

.fw-op {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
  font-weight: 400;
  color: var(--color-red);
  line-height: 1;
}

/* ─── Core 4S deep dive (navy, 2x2 grid) ─── */
.fw-core {
  position: relative;
  padding-block: clamp(4rem, 7vw, 7rem);
  background: linear-gradient(165deg, var(--color-navy), var(--color-navy-deep));
  color: var(--color-white);
  overflow: hidden;
  isolation: isolate;
}
.fw-core::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 15%, rgba(200, 16, 46, 0.18), transparent 55%);
  pointer-events: none;
  z-index: 0;
}
.fw-core > .container-wide { position: relative; z-index: 1; }

.fw-core__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .fw-core__head { grid-template-columns: 1fr; align-items: start; } }
.fw-core__head .eyebrow { color: #FFB3BB; }
.fw-core__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-white);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.fw-core__title em { font-style: italic; color: #FFB3BB; font-weight: 500; }
.fw-core__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  max-width: 46ch;
  margin: 0;
}

.fw-core__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}
@media (max-width: 700px) { .fw-core__grid { grid-template-columns: 1fr; } }

.fw-stone {
  position: relative;
  padding: var(--space-7) var(--space-6);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--dur-2) var(--ease-out), background var(--dur-2), border-color var(--dur-2);
}
.fw-stone:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.22);
}
.fw-stone::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--color-red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.fw-stone:hover::before { transform: scaleX(1); }
.fw-stone--feature {
  background: rgba(200, 16, 46, 0.14);
  border-color: rgba(200, 16, 46, 0.4);
}
.fw-stone--feature::before { transform: scaleX(1); }

.fw-stone__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.fw-stone__sn {
  font-family: var(--font-serif);
  font-size: clamp(2.75rem, 2rem + 2vw, 4rem);
  font-weight: 700;
  line-height: 1;
  color: #FFB3BB;
  letter-spacing: -0.02em;
}
.fw-stone--feature .fw-stone__sn { color: var(--color-white); }
.fw-stone__tag {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.5);
}
.fw-stone__title {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--color-white);
  margin: 0 0 var(--space-3);
}
.fw-stone__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.82);
  max-width: none;
  margin: 0;
}

/* ─── Extended 5S (horizontal rails stacked) ─── */
.fw-ext {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
}
.fw-ext__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-7);
}
@media (max-width: 800px) { .fw-ext__head { grid-template-columns: 1fr; align-items: start; } }
.fw-ext__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.fw-ext__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.fw-ext__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.fw-ext__list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--color-line);
}

.fw-rail {
  position: relative;
  display: grid;
  grid-template-columns: 110px 1.1fr 2fr 28px;
  align-items: center;
  gap: clamp(1rem, 2.5vw, 2.5rem);
  padding: var(--space-6) var(--space-5);
  border-bottom: 1px solid var(--color-line);
  transition: background var(--dur-2) var(--ease-out);
}
.fw-rail:hover { background: var(--color-cream); }
.fw-rail::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--color-red);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform var(--dur-2) var(--ease-out);
}
.fw-rail:hover::before { transform: scaleY(1); }

@media (max-width: 800px) {
  .fw-rail { grid-template-columns: 70px 1fr; gap: var(--space-3); padding: var(--space-5) var(--space-4); }
  .fw-rail__body { grid-column: 1 / -1; padding-top: var(--space-2); }
  .fw-rail__arrow { display: none; }
}

.fw-rail__sn {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 2rem + 1.5vw, 3.75rem);
  font-weight: 600;
  line-height: 0.9;
  color: var(--color-red);
  letter-spacing: -0.02em;
  padding-left: var(--space-4);
}
.fw-rail__title {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-ink);
}
.fw-rail__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--color-graphite);
  margin: 0;
  max-width: 60ch;
}
.fw-rail__arrow {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  color: var(--color-line);
  text-align: right;
  transition: color var(--dur-2), transform var(--dur-2);
}
.fw-rail:hover .fw-rail__arrow { color: var(--color-red); transform: translateX(4px); }

/* ============================================================
   Learning Journey page · editorial sections (page-local)
   LJ = Learning Journey family, used only on /learning-journey
   ============================================================ */

/* ─── Continuity statement (image left, text right) ─── */
.lj-statement {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
  border-block: 1px solid var(--color-line);
}
.lj-statement__grid {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
@media (max-width: 800px) {
  .lj-statement__grid { grid-template-columns: 1fr; gap: var(--space-7); }
}

.lj-statement__media {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-3);
  isolation: isolate;
  margin: 0;
}
.lj-statement__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.6s var(--ease-out);
}
.lj-statement__media:hover img { transform: scale(1.04); }
.lj-statement__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(170deg, transparent 55%, rgba(11, 21, 48, 0.55) 100%);
  z-index: 1;
  pointer-events: none;
}
.lj-statement__cap {
  position: absolute;
  left: var(--space-6);
  right: var(--space-6);
  bottom: var(--space-6);
  z-index: 2;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--step-1);
  color: var(--color-white);
  line-height: 1.3;
  margin: 0;
  max-width: 26ch;
}
.lj-statement__cap strong {
  display: block;
  font-style: normal;
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: #FFB3BB;
  margin-bottom: var(--space-2);
}

.lj-statement__body-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-5);
  max-width: 38rem;
}
.lj-statement__quote {
  font-family: var(--font-serif);
  font-size: clamp(1.85rem, 1.3rem + 1.7vw, 2.85rem);
  line-height: 1.2;
  color: var(--color-ink);
  font-weight: 600;
  letter-spacing: -0.018em;
  margin: 0;
  max-width: 18ch;
}
.lj-statement__quote em { color: var(--color-red); font-style: italic; font-weight: 500; }
.lj-statement__body {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.65;
  color: var(--color-graphite);
  max-width: 56ch;
  margin: 0;
}
.lj-statement__attr {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 600;
  color: var(--color-slate);
}
.lj-statement__attr::before {
  content: "";
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--color-line);
}

/* ─── Pathway (zigzag timeline with central spine) ─── */
.lj-path {
  position: relative;
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-cream);
}
.lj-path__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: clamp(2.5rem, 5vw, 4.5rem);
}
@media (max-width: 800px) { .lj-path__head { grid-template-columns: 1fr; align-items: start; } }
.lj-path__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.lj-path__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.lj-path__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.lj-path__track {
  position: relative;
  max-width: 64rem;
  margin-inline: auto;
  padding-inline: var(--gutter);
}

/* Central red spine */
.lj-path__track::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  background: linear-gradient(to bottom,
    transparent 0%,
    var(--color-red) 4%,
    var(--color-red) 96%,
    transparent 100%);
  transform: translateX(-50%);
  z-index: 0;
}
@media (max-width: 800px) { .lj-path__track::before { left: 11px; } }

.lj-station {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 64px 1fr;
  gap: var(--space-4);
  align-items: center;
  padding-block: var(--space-5);
}

/* Spine dot */
.lj-station::before {
  content: "";
  grid-column: 2;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--color-red);
  box-shadow: 0 0 0 4px var(--color-cream), 0 0 0 5px rgba(200, 16, 46, 0.4);
  margin-inline: auto;
  z-index: 1;
  transition: transform var(--dur-2) var(--ease-out);
}
/* First and last get inverted dots (anchor and continuation) */
.lj-station:first-child::before,
.lj-station:last-child::before {
  background: var(--color-cream);
  box-shadow: 0 0 0 4px var(--color-cream), 0 0 0 6px var(--color-red);
}

.lj-station__card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out), border-color var(--dur-2);
  overflow: hidden;
}
.lj-station__card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-navy), var(--color-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.lj-station:hover .lj-station__card { transform: translateY(-3px); box-shadow: var(--shadow-2); border-color: transparent; }
.lj-station:hover .lj-station__card::before { transform: scaleX(1); }
.lj-station:hover::before { transform: scale(1.2); }

/* Alternating sides: odd children left, even children right */
.lj-station:nth-child(odd) .lj-station__card { grid-column: 1; text-align: right; align-items: flex-end; }
.lj-station:nth-child(even) .lj-station__card { grid-column: 3; text-align: left; align-items: flex-start; }

@media (max-width: 800px) {
  .lj-station {
    grid-template-columns: 22px 1fr;
    gap: var(--space-4);
  }
  .lj-station::before { grid-column: 1; margin-inline: 0; }
  .lj-station__card,
  .lj-station:nth-child(odd) .lj-station__card,
  .lj-station:nth-child(even) .lj-station__card {
    grid-column: 2;
    text-align: left;
    align-items: stretch;
  }
}

.lj-station__sn {
  font-family: var(--font-serif);
  font-size: clamp(1.65rem, 1.3rem + 0.8vw, 2.15rem);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.lj-station__age {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-mute);
}
.lj-station__stage {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 700;
  color: var(--color-navy);
}
.lj-station__title {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-ink);
  margin: var(--space-2) 0 0;
}
.lj-station__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--color-graphite);
  margin: var(--space-3) 0 0;
  max-width: 38ch;
}

/* ============================================================
   Innoverse page · editorial sections (page-local)
   IV = Innoverse family, used only on /innoverse
   ============================================================ */

/* ─── Idea-to-impact pipeline (horizontal flow with arrows) ─── */
.iv-pipeline {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
}
.iv-pipeline__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .iv-pipeline__head { grid-template-columns: 1fr; align-items: start; } }
.iv-pipeline__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.iv-pipeline__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.iv-pipeline__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.iv-pipeline__flow {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  gap: var(--space-3);
  align-items: stretch;
}
@media (max-width: 900px) {
  .iv-pipeline__flow {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

.iv-step {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-6) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  overflow: hidden;
  transition: transform var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out),
              border-color var(--dur-2) var(--ease-out);
}
.iv-step:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-2);
  border-color: transparent;
}
.iv-step::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--color-red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.iv-step:hover::before { transform: scaleX(1); }

/* Featured last card (the destination) */
.iv-step--feature {
  background: linear-gradient(165deg, var(--color-navy), var(--color-navy-deep));
  border-color: transparent;
  color: var(--color-white);
}
.iv-step--feature::before { background: var(--color-red); transform: scaleX(1); }
.iv-step--feature:hover { background: linear-gradient(165deg, var(--color-navy-soft), var(--color-navy)); }

.iv-step__num {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 2rem + 1.5vw, 3.5rem);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.iv-step--feature .iv-step__num { color: #FFB3BB; }

.iv-step__cap {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-navy);
  margin-top: var(--space-3);
}
.iv-step--feature .iv-step__cap { color: #FFB3BB; }

.iv-step__title {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-ink);
  margin: var(--space-2) 0 0;
}
.iv-step--feature .iv-step__title { color: var(--color-white); }

.iv-step__body {
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: 1.55;
  color: var(--color-graphite);
  margin: var(--space-3) 0 0;
}
.iv-step--feature .iv-step__body { color: rgba(255, 255, 255, 0.82); }

.iv-step__outcome {
  margin-top: auto;
  padding-top: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: var(--font-sans);
  font-size: var(--step--1);
  color: var(--color-ink);
  border-top: 1px solid var(--color-line);
  margin-top: var(--space-5);
}
.iv-step--feature .iv-step__outcome { color: var(--color-white); border-top-color: rgba(255, 255, 255, 0.14); }
.iv-step__outcome strong {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  font-size: 11px;
  color: var(--color-slate);
}
.iv-step--feature .iv-step__outcome strong { color: rgba(255, 255, 255, 0.6); }
.iv-step__outcome strong::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-red);
  flex-shrink: 0;
}

/* Pipeline arrows with trailing fade line */
.iv-pipeline__arrow {
  position: relative;
  display: grid;
  place-items: center;
  width: 44px;
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 1rem + 1vw, 2rem);
  color: var(--color-red);
  font-weight: 400;
  user-select: none;
}
.iv-pipeline__arrow::before {
  content: "";
  position: absolute;
  left: 0;
  right: 14px;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200, 16, 46, 0.5));
  transform: translateY(-50%);
}
@media (max-width: 900px) {
  .iv-pipeline__arrow {
    width: auto;
    transform: rotate(90deg);
    padding-block: var(--space-3);
  }
  .iv-pipeline__arrow::before { display: none; }
}

/* ─── Four Pillars (2x2 cream grid with KPI indicator) ─── */
.iv-pillars {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-cream);
}
.iv-pillars__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .iv-pillars__head { grid-template-columns: 1fr; align-items: start; } }
.iv-pillars__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.iv-pillars__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.iv-pillars__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.iv-pillars__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}
@media (max-width: 700px) { .iv-pillars__grid { grid-template-columns: 1fr; } }

.iv-pillar {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-6) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  overflow: hidden;
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out), border-color var(--dur-2);
}
.iv-pillar:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  border-color: transparent;
}
.iv-pillar::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-navy), var(--color-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.iv-pillar:hover::before { transform: scaleX(1); }

.iv-pillar__top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-3);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-line);
}
.iv-pillar__num {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 2rem + 1.5vw, 3.75rem);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.iv-pillar__cap {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-mute);
}
.iv-pillar__title {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--color-ink);
  margin: var(--space-2) 0 0;
}
.iv-pillar__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--color-graphite);
  margin: 0;
}
.iv-pillar__indicator {
  margin-top: auto;
  padding-top: var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  color: var(--color-slate);
}
.iv-pillar__indicator::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--color-red);
  flex-shrink: 0;
}
.iv-pillar__indicator-label {
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-navy);
}

/* ============================================================
   Contact page · editorial sections (page-local)
   CT = Contact family, used only on /contact
   ============================================================ */

.ct-form {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
}
.ct-form__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
@media (max-width: 900px) { .ct-form__grid { grid-template-columns: 1fr; } }

.ct-form__main {
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: clamp(2rem, 4vw, 3.5rem);
}
.ct-form__heading {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--color-ink);
  margin: 0 0 var(--space-2);
}
.ct-form__heading em { font-style: italic; color: var(--color-red); font-weight: 500; }
.ct-form__hint {
  font-family: var(--font-sans);
  font-size: var(--step--1);
  color: var(--color-graphite);
  margin: 0 0 var(--space-6);
  max-width: 50ch;
}

.ct-form__side {
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
@media (max-width: 900px) { .ct-form__side { position: static; } }

.ct-info-card {
  position: relative;
  background: linear-gradient(165deg, var(--color-navy), var(--color-navy-deep));
  color: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-7) var(--space-6);
  overflow: hidden;
  isolation: isolate;
}
.ct-info-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 20%, rgba(200, 16, 46, 0.2), transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.ct-info-card > * { position: relative; z-index: 1; }

.ct-info-card__label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 700;
  color: #FFB3BB;
}
.ct-info-card__label::before {
  content: "";
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--color-red);
}
.ct-info-card__heading {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-white);
  margin: var(--space-4) 0 var(--space-6);
  max-width: 18ch;
}
.ct-info-card__heading em { font-style: italic; color: #FFB3BB; font-weight: 500; }

.ct-info-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.ct-info-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.14);
}
.ct-info-row:first-child { border-top: 0; padding-top: 0; }
.ct-info-row__label {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.55);
}
.ct-info-row__value {
  font-family: var(--font-serif);
  font-size: var(--step-1);
  color: var(--color-white);
  font-weight: 500;
  line-height: 1.4;
  margin: 0;
}
.ct-info-row__value a {
  color: var(--color-white);
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  transition: border-color var(--dur-1) var(--ease-out);
}
.ct-info-row__value a:hover { border-bottom-color: var(--color-white); }

.ct-info-card__note {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.14);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.7);
}

/* Form success state polish (page-local override) */
.ct-form__main .form__success {
  background: var(--color-cream);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  padding: var(--space-7);
  text-align: center;
}
.ct-form__main .form__success strong {
  display: block;
  font-family: var(--font-serif);
  font-size: var(--step-3);
  color: var(--color-ink);
  margin-bottom: var(--space-3);
  font-weight: 700;
  letter-spacing: -0.018em;
}

/* ============================================================
   Targets page · editorial sections (page-local)
   TG = Targets family, used only on /targets
   ============================================================ */

.tg-section {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
}
.tg-section__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .tg-section__head { grid-template-columns: 1fr; align-items: start; } }
.tg-section__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.tg-section__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.tg-section__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.tg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 900px) { .tg-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .tg-grid { grid-template-columns: 1fr; } }

.tg-card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-7) var(--space-6) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out),
              border-color var(--dur-2) var(--ease-out);
}
.tg-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  border-color: transparent;
}

/* Decorative giant background numeral */
.tg-card__bg {
  position: absolute;
  top: -16px;
  right: -8px;
  font-family: var(--font-serif);
  font-size: clamp(6rem, 4.5rem + 3.5vw, 9rem);
  font-weight: 700;
  line-height: 0.85;
  color: rgba(200, 16, 46, 0.06);
  letter-spacing: -0.04em;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  transition: color var(--dur-2) var(--ease-out);
}
.tg-card:hover .tg-card__bg { color: rgba(200, 16, 46, 0.11); }

/* Top accent rule */
.tg-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-navy), var(--color-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
  z-index: 2;
}
.tg-card:hover::before { transform: scaleX(1); }

.tg-card > *:not(.tg-card__bg) { position: relative; z-index: 1; }

.tg-card__num {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.tg-card__title {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-ink);
  margin: var(--space-2) 0 0;
}
.tg-card__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--color-graphite);
  margin: var(--space-3) 0 0;
}
.tg-card__tag {
  margin-top: auto;
  padding-top: var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-mute);
}
.tg-card__tag::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--color-red);
  flex-shrink: 0;
}

/* ============================================================
   Objectives page · editorial sections (page-local)
   OB = Objectives family, used only on /objectives
   ============================================================ */

.ob-section {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
}
.ob-section__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-7);
}
@media (max-width: 800px) { .ob-section__head { grid-template-columns: 1fr; align-items: start; } }
.ob-section__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.ob-section__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.ob-section__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.ob-list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--color-line);
}

.ob-objective {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1.8fr;
  gap: clamp(2rem, 5vw, 5rem);
  padding: var(--space-7) var(--space-5);
  border-bottom: 1px solid var(--color-line);
  transition: background var(--dur-2) var(--ease-out);
}
.ob-objective:hover { background: var(--color-cream); }
.ob-objective::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--color-red);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform var(--dur-2) var(--ease-out);
}
.ob-objective:hover::before { transform: scaleY(1); }
@media (max-width: 800px) {
  .ob-objective { grid-template-columns: 1fr; gap: var(--space-5); padding: var(--space-6) var(--space-4); }
}

.ob-objective__head {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.ob-objective__num {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 2rem + 1.5vw, 3.75rem);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.ob-objective__title {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--color-ink);
  margin: var(--space-2) 0 0;
  max-width: 16ch;
}

.ob-objective__kpi {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-line);
}
.ob-objective:hover .ob-objective__kpi { border-top-color: rgba(11, 21, 48, 0.16); }

.ob-objective__kpi-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-weight: 700;
  color: var(--color-navy);
  margin-bottom: var(--space-3);
}
.ob-objective__kpi-label::before {
  content: "";
  width: 20px;
  height: 1px;
  background: var(--color-red);
}
.ob-objective__kpi-text {
  font-family: var(--font-serif);
  font-size: var(--step-1);
  line-height: 1.4;
  color: var(--color-ink);
  font-style: italic;
  font-weight: 500;
  margin: 0;
  max-width: 30ch;
}

.ob-goals {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.ob-goal {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.55;
  color: var(--color-graphite);
  align-items: start;
}
.ob-goal::before {
  content: "";
  width: 10px;
  height: 10px;
  margin-top: 0.5em;
  border-radius: 50%;
  background: var(--color-red);
  box-shadow: 0 0 0 4px rgba(200, 16, 46, 0.1);
}

/* ============================================================
   Values page · editorial sections (page-local)
   VL = Values family, used only on /values
   ============================================================ */

.vl-section {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-cream);
}
.vl-section__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .vl-section__head { grid-template-columns: 1fr; align-items: start; } }
.vl-section__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.vl-section__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.vl-section__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.vl-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 900px) { .vl-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .vl-grid { grid-template-columns: 1fr; } }

.vl-card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-6) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  overflow: hidden;
  transition: transform var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out),
              border-color var(--dur-2) var(--ease-out);
}
.vl-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  border-color: transparent;
}
.vl-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-navy), var(--color-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.vl-card:hover::before { transform: scaleX(1); }

.vl-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-line);
}
.vl-card__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-navy), var(--color-navy-soft));
  color: var(--color-white);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  transition: background var(--dur-2) var(--ease-out), transform var(--dur-2) var(--ease-out);
}
.vl-card:hover .vl-card__icon {
  background: linear-gradient(135deg, var(--color-red), var(--color-red-deep));
  transform: scale(1.06);
}
.vl-card__icon svg { width: 26px; height: 26px; }

.vl-card__num {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}

.vl-card__title {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-ink);
  margin: 0;
}
.vl-card__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--color-graphite);
  margin: 0;
}

/* ============================================================
   Governance page · editorial sections (page-local)
   GV = Governance family, used only on /governance
   ============================================================ */

/* ─── UK Anchor (image left, content right) ─── */
.gv-anchor {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
  border-bottom: 1px solid var(--color-line);
}
.gv-anchor__grid {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
@media (max-width: 800px) {
  .gv-anchor__grid { grid-template-columns: 1fr; gap: var(--space-7); }
}

.gv-anchor__media {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-3);
  isolation: isolate;
  margin: 0;
}
.gv-anchor__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.6s var(--ease-out);
}
.gv-anchor__media:hover img { transform: scale(1.04); }
.gv-anchor__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(170deg, transparent 55%, rgba(11, 21, 48, 0.55) 100%);
  z-index: 1;
  pointer-events: none;
}
.gv-anchor__cap {
  position: absolute;
  left: var(--space-6);
  right: var(--space-6);
  bottom: var(--space-6);
  z-index: 2;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--step-1);
  color: var(--color-white);
  line-height: 1.3;
  margin: 0;
  max-width: 26ch;
}
.gv-anchor__cap strong {
  display: block;
  font-style: normal;
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: #FFB3BB;
  margin-bottom: var(--space-2);
}

.gv-anchor__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 38rem;
}
.gv-anchor__label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 700;
  color: var(--color-navy);
}
.gv-anchor__label::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--color-red);
}
.gv-anchor__title {
  font-family: var(--font-serif);
  font-size: clamp(1.85rem, 1.4rem + 1.6vw, 2.85rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  font-weight: 700;
  color: var(--color-ink);
  margin: 0;
  max-width: 22ch;
}
.gv-anchor__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.gv-anchor__text {
  font-family: var(--font-serif);
  font-size: var(--step-1);
  line-height: 1.55;
  color: var(--color-graphite);
  margin: 0;
}

/* ─── Quality Stack (4 horizontal layers stacked together) ─── */
.gv-stack {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-cream);
}
.gv-stack__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-7);
}
@media (max-width: 800px) { .gv-stack__head { grid-template-columns: 1fr; align-items: start; } }
.gv-stack__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.gv-stack__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.gv-stack__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.gv-stack__list {
  display: flex;
  flex-direction: column;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-1);
  background: var(--bg-elevated);
}

.gv-layer {
  position: relative;
  display: grid;
  grid-template-columns: 90px 1fr 110px;
  align-items: center;
  gap: clamp(1rem, 2.5vw, 2.5rem);
  padding: var(--space-6) var(--space-7);
  border-bottom: 1px solid var(--color-line);
  transition: background var(--dur-2) var(--ease-out);
}
.gv-layer:last-child { border-bottom: 0; }
.gv-layer:hover { background: var(--color-cream); }
.gv-layer::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--color-red);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform var(--dur-2) var(--ease-out);
}
.gv-layer:hover::before { transform: scaleY(1); }

@media (max-width: 800px) {
  .gv-layer { grid-template-columns: 60px 1fr; gap: var(--space-3); padding: var(--space-5) var(--space-5); }
  .gv-layer__tag { display: none; }
}

.gv-layer__num {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 2rem + 1.5vw, 3.5rem);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.gv-layer__main {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.gv-layer__title {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-ink);
  margin: 0;
}
.gv-layer__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.55;
  color: var(--color-graphite);
  margin: 0;
  max-width: 62ch;
}
.gv-layer__tag {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-mute);
  text-align: right;
}

/* ============================================================
   Global page · editorial sections (page-local)
   GL = Global Reach family, used only on /global
   ============================================================ */

/* ─── Global statement (text left, image right) ─── */
.gl-statement {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
  border-bottom: 1px solid var(--color-line);
}
.gl-statement__grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
@media (max-width: 800px) {
  .gl-statement__grid { grid-template-columns: 1fr; gap: var(--space-7); }
}

.gl-statement__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-5);
  max-width: 38rem;
}
.gl-statement__title {
  font-family: var(--font-serif);
  font-size: clamp(1.85rem, 1.3rem + 1.7vw, 2.85rem);
  line-height: 1.2;
  color: var(--color-ink);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0;
  max-width: 18ch;
}
.gl-statement__title em { color: var(--color-red); font-style: italic; font-weight: 500; }
.gl-statement__text {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.65;
  color: var(--color-graphite);
  margin: 0;
  max-width: 56ch;
}
.gl-statement__attr {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 600;
  color: var(--color-slate);
}
.gl-statement__attr::before {
  content: "";
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--color-line);
}

.gl-statement__media {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-3);
  isolation: isolate;
  margin: 0;
}
.gl-statement__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.6s var(--ease-out);
}
.gl-statement__media:hover img { transform: scale(1.04); }
.gl-statement__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(170deg, transparent 55%, rgba(11, 21, 48, 0.55) 100%);
  z-index: 1;
  pointer-events: none;
}
.gl-statement__cap {
  position: absolute;
  left: var(--space-6);
  right: var(--space-6);
  bottom: var(--space-6);
  z-index: 2;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--step-1);
  color: var(--color-white);
  line-height: 1.3;
  margin: 0;
  max-width: 26ch;
}
.gl-statement__cap strong {
  display: block;
  font-style: normal;
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: #FFB3BB;
  margin-bottom: var(--space-2);
}

/* ─── Four Continents (2x2 grid, Europe featured) ─── */
.gl-continents {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-cream);
}
.gl-continents__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .gl-continents__head { grid-template-columns: 1fr; align-items: start; } }
.gl-continents__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.gl-continents__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.gl-continents__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.gl-continents__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}
@media (max-width: 700px) { .gl-continents__grid { grid-template-columns: 1fr; } }

.gl-continent {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-7) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  overflow: hidden;
  transition: transform var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out),
              border-color var(--dur-2) var(--ease-out);
}
.gl-continent:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  border-color: transparent;
}
.gl-continent::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-navy), var(--color-red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.gl-continent:hover::before { transform: scaleX(1); }

.gl-continent--feature {
  background: linear-gradient(165deg, var(--color-navy), var(--color-navy-deep));
  border-color: transparent;
  color: var(--color-white);
}
.gl-continent--feature::before { background: var(--color-red); transform: scaleX(1); }
.gl-continent--feature:hover { background: linear-gradient(165deg, var(--color-navy-soft), var(--color-navy)); }

.gl-continent__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-line);
}
.gl-continent--feature .gl-continent__top { border-bottom-color: rgba(255, 255, 255, 0.16); }

.gl-continent__icon {
  width: 68px;
  height: 44px;
  border-radius: 4px;
  overflow: hidden;
  background: var(--color-line);
  box-shadow: 0 1px 3px rgba(11, 21, 48, 0.18), inset 0 0 0 1px rgba(11, 21, 48, 0.06);
  flex-shrink: 0;
}
.gl-continent--feature .gl-continent__icon {
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4), inset 0 0 0 1px rgba(255, 255, 255, 0.18);
}
.gl-continent__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.gl-continent__role {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-mute);
}
.gl-continent--feature .gl-continent__role { color: #FFB3BB; }

.gl-continent__name {
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--color-ink);
  margin: var(--space-2) 0 0;
}
.gl-continent--feature .gl-continent__name { color: var(--color-white); }

.gl-continent__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--color-graphite);
  margin: 0;
}
.gl-continent--feature .gl-continent__body { color: rgba(255, 255, 255, 0.82); }

/* ─── Mobility section (dark ink with pathway cards + stats) ─── */
.gl-mobility {
  position: relative;
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-ink);
  color: var(--color-white);
  overflow: hidden;
  isolation: isolate;
}
.gl-mobility::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 85% 15%, rgba(200, 16, 46, 0.18), transparent 55%);
  pointer-events: none;
  z-index: 0;
}
.gl-mobility > .container-wide { position: relative; z-index: 1; }

.gl-mobility__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .gl-mobility__head { grid-template-columns: 1fr; align-items: start; } }
.gl-mobility__head .eyebrow { color: #FFB3BB; }
.gl-mobility__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-white);
  margin-top: var(--space-4);
  max-width: 20ch;
}
.gl-mobility__title em { font-style: italic; color: #FFB3BB; font-weight: 500; }
.gl-mobility__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  max-width: 46ch;
  margin: 0;
}

.gl-mobility__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-bottom: var(--space-8);
}
@media (max-width: 800px) { .gl-mobility__grid { grid-template-columns: 1fr; } }

.gl-pathway {
  position: relative;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-lg);
  padding: var(--space-7) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  overflow: hidden;
  transition: transform var(--dur-2) var(--ease-out), background var(--dur-2), border-color var(--dur-2);
}
.gl-pathway:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.22);
}
.gl-pathway::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--color-red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-3) var(--ease-out);
}
.gl-pathway:hover::before { transform: scaleX(1); }

.gl-pathway__num {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 2rem + 1.5vw, 3.5rem);
  font-weight: 700;
  color: #FFB3BB;
  line-height: 1;
  letter-spacing: -0.02em;
}
.gl-pathway__name {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-white);
  margin: var(--space-3) 0 0;
}
.gl-pathway__body {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  margin: var(--space-2) 0 0;
}

/* Stats strip beneath pathways */
.gl-mobility__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.16);
  padding-top: var(--space-6);
}
@media (max-width: 700px) { .gl-mobility__stats { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); } }

.gl-stat {
  padding: var(--space-3) var(--space-5) var(--space-3) 0;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.gl-stat:last-child { border-right: 0; }
@media (max-width: 700px) { .gl-stat { border-right: 0; padding-right: 0; } }
.gl-stat__num {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 1.5rem + 1.5vw, 3rem);
  font-weight: 700;
  line-height: 1;
  color: var(--color-white);
  letter-spacing: -0.02em;
}
.gl-stat__num em { color: #FFB3BB; font-style: italic; font-weight: 500; }
.gl-stat__label {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.65);
}

/* ============================================================
   Enquiries page · editorial sections (page-local)
   EQ = Enquiries family, used only on /enquiries
   ============================================================ */

.eq-channels {
  padding-block: clamp(4rem, 7vw, 7rem);
  background: var(--color-paper);
}
.eq-channels__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: var(--space-7);
}
@media (max-width: 800px) { .eq-channels__head { grid-template-columns: 1fr; align-items: start; } }
.eq-channels__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 1.55rem + 2.6vw, 3.85rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  font-weight: 700;
  color: var(--color-ink);
  margin-top: var(--space-4);
  max-width: 18ch;
}
.eq-channels__title em { font-style: italic; color: var(--color-red); font-weight: 500; }
.eq-channels__lede {
  font-family: var(--font-sans);
  font-size: var(--step-1);
  line-height: 1.6;
  color: var(--color-graphite);
  max-width: 46ch;
  margin: 0;
}

.eq-channels__list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--color-line);
}

.eq-channel {
  position: relative;
  display: grid;
  grid-template-columns: 90px 1.1fr 1.6fr 140px;
  align-items: center;
  gap: clamp(1rem, 2.5vw, 2.5rem);
  padding: var(--space-6) var(--space-5);
  border-bottom: 1px solid var(--color-line);
  text-decoration: none;
  color: inherit;
  transition: background var(--dur-2) var(--ease-out);
}
.eq-channel:hover { background: var(--color-cream); }
.eq-channel::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--color-red);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform var(--dur-2) var(--ease-out);
}
.eq-channel:hover::before { transform: scaleY(1); }

@media (max-width: 800px) {
  .eq-channel { grid-template-columns: 60px 1fr; gap: var(--space-3); padding: var(--space-5) var(--space-4); }
  .eq-channel__desc { grid-column: 1 / -1; padding-top: var(--space-2); }
  .eq-channel__cta { grid-column: 1 / -1; padding-top: var(--space-3); }
}

.eq-channel__num {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 2rem + 1.5vw, 3.5rem);
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
  letter-spacing: -0.02em;
}
.eq-channel__main {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.eq-channel__topic {
  font-family: var(--font-sans);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--color-navy);
}
.eq-channel__name {
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--color-ink);
  margin: 0;
}
.eq-channel__desc {
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.55;
  color: var(--color-graphite);
  margin: 0;
  max-width: 60ch;
}
.eq-channel__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  justify-self: end;
  font-family: var(--font-sans);
  font-size: var(--step--1);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 700;
  color: var(--color-navy);
  text-decoration: none;
  transition: color var(--dur-2);
}
.eq-channel__cta::after {
  content: "→";
  font-family: var(--font-serif);
  font-size: 1.25em;
  transition: transform var(--dur-2) var(--ease-out);
}
.eq-channel:hover .eq-channel__cta { color: var(--color-red); }
.eq-channel:hover .eq-channel__cta::after { transform: translateX(4px); }
