/* ============================================================
   RKH PARTNERS — EARTHY EDITORIAL
   palette: cream paper · terracotta · ochre · deep forest · umber
   ============================================================ */

:root{
  /* Page is now DEEP FOREST. Cream is ink. Gold for emphasis. */
  --cream:   #2a3a2a;   /* was page tint; now forest */
  --cream-2: #1f2c1f;   /* deeper forest */
  --paper:   #243223;   /* page background — deep forest */
  --ink:     #f4ecd6;   /* primary text — warm cream */
  --ink-2:   #ead9b3;   /* secondary text — softer cream */
  --umber:   #3f2d1e;
  --forest:  #1a2418;   /* even deeper forest for the dark "response" callout */
  --forest-deep: #0f1810;
  --terra:   #f4ecd6;   /* accent-as-cream */
  --terra-deep:#e6d3a8;
  /* Warm dark earth — used by the contact section */
  --terracotta:      #5a3a28;   /* dark cocoa-brown, slight warm cast */
  --terracotta-deep: #3a2418;   /* deeper espresso */
  --terracotta-soft: #7a5239;   /* highlight */
  --ochre:   #e0b04a;   /* gold — emphasis */
  --ochre-soft:#f0c878;
  --moss:    #6f7a43;
  --bone:    #15200f;   /* dark, used as contrast surface where cream chips sit on it */

  --serif: "Fraunces", "Times New Roman", serif;
  --sans:  "Inter Tight", system-ui, sans-serif;
  --mono:  "Fragment Mono", ui-monospace, monospace;

  --max: 1440px;
  --gutter: clamp(20px, 4vw, 64px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
em{font-style:italic}

::selection{background:var(--terra);color:var(--bone)}

/* ============ GRAIN ============ */
.grain{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 100;
  opacity: 0.35;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.25  0 0 0 0 0.18  0 0 0 0 0.10  0 0 0 0.45 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ============ NAV ============ */
.nav{
  position: fixed;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 50;
  width: calc(100% - clamp(20px, 4vw, 48px));
  max-width: 1400px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(16px, 4vw, 48px);
  padding: 12px 16px 12px 18px;
  border-radius: 999px;

  /* GLASS */
  background:
    linear-gradient(135deg, rgba(255,255,255,0.14), rgba(255,255,255,0.05) 40%, rgba(255,255,255,0.10) 100%);
  backdrop-filter: blur(18px) saturate(180%) brightness(1.05);
  -webkit-backdrop-filter: blur(18px) saturate(180%) brightness(1.05);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.25),
    inset 0 -1px 0 rgba(0,0,0,0.18),
    0 18px 40px -18px rgba(0,0,0,0.35);

  color: var(--ink);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;

  /* mix with content beneath to react to colors / imagery */
  isolation: isolate;
}
/* Subtle highlight curve along top of glass */
.nav::before{
  content:"";
  position:absolute;
  inset: 1px 1px auto 1px;
  height: 50%;
  border-radius: 999px 999px 200px 200px / 999px 999px 80px 80px;
  background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0) 100%);
  pointer-events:none;
  z-index:-1;
}
.nav-mark{display:flex;align-items:center;gap:10px}
.mark-svg{width:36px;height:36px;color:var(--terra)}
.nav-logo{
  width:auto;
  height:38px;
  display:block;
  object-fit:contain;
  flex-shrink:0;
  transform: scale(1.45);
  transform-origin: left center;
  margin-right: 14px;
}
.nav-wordmark{display:flex;flex-direction:column;line-height:1.1}
.nav-word{font-family:var(--serif);font-size:15px;font-weight:500;letter-spacing:0;text-transform:none;font-style:italic;color:var(--ink)}
.nav-sub{font-family:var(--mono);font-size:9px;letter-spacing:0.18em;color:var(--ink-2);opacity:.75}

.nav-links{display:flex;gap:clamp(12px, 2.5vw, 32px);justify-self:center}
.nav-links a{display:inline-flex;align-items:baseline;gap:6px;color:var(--ink-2);transition:color .25s}
.nav-links a span{font-size:9px;color:var(--terra);opacity:.7}
.nav-links a:hover{color:var(--terra-deep)}

.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px 10px 18px;
  border:1px solid rgba(244,236,214,0.55);
  border-radius:999px;
  color:var(--ink);
  background: rgba(255,255,255,0.06);
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;
  transition: background .3s, color .3s, transform .3s, border-color .3s;
  backdrop-filter: blur(6px);
}
.nav-cta svg{width:14px;height:14px;transition:transform .3s}
.nav-cta:hover{background:var(--ochre);color:var(--forest-deep);border-color:var(--ochre)}
.nav-cta:hover svg{transform:translateX(3px)}

@media (max-width: 900px){
  .nav-links{display:none}
}

/* ============ HERO ============ */
.hero{
  position: relative;
  min-height: 100vh;
  padding: 140px var(--gutter) 70px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  text-align: center;
  isolation: isolate;
}

/* ===== Full-bleed background image ===== */
.hero-bg{
  position: absolute;
  inset: 0;
  z-index: -2;
  overflow: hidden;
}
.hero-bg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.05) brightness(0.55) blur(14px);
  transform: scale(1.08);
  transition: filter 1.4s cubic-bezier(.2,.7,.2,1), transform 6s cubic-bezier(.2,.7,.2,1);
  will-change: filter, transform;
}
.hero.is-loaded .hero-bg img{
  filter: saturate(1.08) contrast(1.06) brightness(0.42) blur(0px);
  transform: scale(1.02);
}

.hero-bg-overlay{
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(0,0,0,0.0) 0%, rgba(15,24,16,0.55) 70%),
    linear-gradient(180deg, rgba(36,50,35,0.55) 0%, rgba(36,50,35,0.72) 60%, rgba(15,24,16,0.92) 100%);
  pointer-events: none;
}

/* paper background tint removed — keeping selector inert so cascade is safe */
.hero::before{ content: none }

/* ===== Centred inner column ===== */
.hero-inner{
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1200px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
}

.hero-meta{
  display:flex;
  gap: clamp(20px, 4vw, 48px);
  flex-wrap:wrap;
  justify-content: center;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color: var(--ink);
  opacity: .82;
}
.meta-row{display:flex;align-items:center;gap:10px}
.dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--ochre);
  box-shadow:0 0 0 4px rgba(224,176,74,.22);
  animation: heroDot 2.4s ease-in-out infinite;
}
@keyframes heroDot{
  0%,100%{box-shadow:0 0 0 4px rgba(224,176,74,.22)}
  50%{box-shadow:0 0 0 9px rgba(224,176,74,.04)}
}

.hero-eyebrow{
  display:flex; align-items:center; gap:18px;
  justify-content: center;
  font-family:var(--mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color: var(--ochre-soft);
}
.hero-eyebrow .line{
  display:inline-block;
  width: 60px;
  height:1px;
  background: var(--ochre);
  opacity: .55;
}

.hero-title{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(38px, 6.6vw, 116px);
  line-height: 0.98;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
  margin: 4px 0 12px;
  max-width: 22ch;
  text-align: center;
  text-wrap: balance;
  text-shadow: 0 2px 30px rgba(0,0,0,0.3);
}
.hero-title .word{
  display:inline-block;
  margin: 0 0.18em 0 0;
  white-space: nowrap;
}
.hero-title .word.break{
  display:block;
  width:100%;
  margin: 0;
  height: 0;
}
.hero-title .word em{
  color: var(--ochre);
  font-style: italic;
  font-weight: 400;
  font-variation-settings:"opsz" 144, "SOFT" 90;
  text-shadow: 0 1px 0 rgba(0,0,0,0.18), 0 2px 30px rgba(0,0,0,0.35);
}

/* ===== Per-letter typewriter-blur reveal ===== */
.hero-title .letter{
  display: inline-block;
  opacity: 0;
  filter: blur(14px);
  transform: translateY(8px);
  transition:
    opacity .7s cubic-bezier(.2,.7,.2,1),
    filter .8s cubic-bezier(.2,.7,.2,1),
    transform .9s cubic-bezier(.2,.7,.2,1);
}
.hero-title .letter.is-on{
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}
/* caret hint */
.hero-title .caret{
  display: inline-block;
  width: 0.06em;
  height: 0.85em;
  background: var(--ochre);
  vertical-align: -0.05em;
  margin-left: 0.04em;
  animation: heroCaret 0.85s steps(2) infinite;
}
.hero-title .caret.is-done{
  opacity: 0;
  animation: none;
  transition: opacity .4s ease;
}
@keyframes heroCaret{
  0%,49%{opacity: 1}
  50%,100%{opacity: 0}
}

.hero-body{
  max-width: 620px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  margin-top: 4px;
  text-align: center;
  opacity: .92;
}
.hero-body p{margin-bottom: 22px}
.hero-body p em{
  color:var(--ochre-soft);
  font-family:var(--serif);
  font-style:italic;
  font-size:1.04em;
}
.hero-body .link-arrow{
  border-bottom-color: var(--ink);
  color: var(--ink);
}
.hero-body .link-arrow:hover{
  color: var(--ochre);
  border-bottom-color: var(--ochre);
}

.link-arrow{
  display:inline-flex;
  align-items:center; gap:10px;
  padding-bottom: 4px;
  border-bottom:1px solid var(--ink);
  font-family:var(--mono);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink);
  transition: gap .3s, color .3s;
}
.link-arrow svg{width:14px;height:14px}
.link-arrow:hover{gap:18px;color:var(--terra-deep)}

/* hero media + orbit removed — replaced by full-bleed background image */

/* stats */
.hero-stats{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 4vw, 60px);
  width: 100%;
  max-width: 1000px;
  margin-top: 50px;
  padding-top: 30px;
  border-top: 1px solid rgba(244,236,214,.18);
  text-align: center;
}
.hero-stats > div{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items: center;
  justify-content: center;
}
.hero-stats .num{
  font-family:var(--serif);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 300;
  line-height: 1;
  color: var(--ink);
  font-variation-settings:"opsz" 144;
  display: inline-block;
  cursor: default;
  transition:
    color .4s cubic-bezier(.2,.7,.2,1),
    transform .5s cubic-bezier(.2,.7,.2,1),
    font-variation-settings .5s cubic-bezier(.2,.7,.2,1),
    text-shadow .4s ease;
}
.hero-stats > div:hover .num{
  color: var(--ochre);
  transform: translateY(-4px) scale(1.06);
  font-variation-settings:"opsz" 144, "SOFT" 100;
  text-shadow: 0 12px 30px rgba(224,176,74,0.45);
}
.hero-stats .lab{
  font-family:var(--mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  max-width: 260px;
  text-align: center;
  opacity: .8;
  transition: color .3s ease, opacity .3s ease;
}
.hero-stats > div:hover .lab{
  color: var(--ochre-soft);
  opacity: 1;
}

@media (max-width: 700px){
  .hero{padding: 120px var(--gutter) 60px}
  .hero-stats{grid-template-columns: 1fr; gap: 30px}
}

/* scroll cue */
.scroll-cue{
  position:absolute;
  bottom: 24px; left: var(--gutter);
  display:flex; align-items:center; gap:14px;
  font-family:var(--mono);
  font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color: var(--ink-2);
}
.scroll-line{
  width: 80px; height:1px;
  background: linear-gradient(90deg, var(--ink-2), transparent);
  position:relative;
  overflow:hidden;
}
.scroll-line::after{
  content:"";
  position:absolute;
  inset:0;
  background: var(--terra);
  transform: translateX(-100%);
  animation: scrollPulse 2.8s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%{transform:translateX(-100%)}
  60%{transform:translateX(100%)}
  100%{transform:translateX(100%)}
}

@media (max-width: 900px){
  .hero{grid-template-columns:1fr; padding-top: 110px}
  .hero-body{grid-column: 1 / -1; max-width: 100%}
  .hero-stats{grid-template-columns:1fr 1fr; gap: 24px}
}

/* ============ MARQUEE ============ */
.marquee{
  background: transparent;
  color: var(--ochre);
  padding: 28px 0;
  overflow: hidden;
  border: 0;
}
.marquee-track{
  display:flex;
  gap: 40px;
  width: max-content;
  font-family: var(--serif);
  font-size: clamp(22px, 3vw, 40px);
  font-weight: 300;
  font-style: italic;
  font-variation-settings:"opsz" 144, "SOFT" 90;
  animation: marquee 40s linear infinite;
  white-space:nowrap;
  color: var(--ochre);
}
.marquee-track span{color: var(--ochre)}
.marquee-track span:nth-child(even){
  color: var(--ochre-soft);
  font-style: normal;
  opacity: 0.85;
}
@keyframes marquee{
  to{transform:translateX(-50%)}
}

/* ============ SHARED SECTION HEAD ============ */
.section-head{
  max-width: 980px;
  margin-bottom: 70px;
}
.kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--terra-deep);
  margin-bottom: 28px;
}
.kicker span{
  display:inline-block;
  padding: 3px 8px;
  background: var(--terra);
  color: var(--bone);
  border-radius: 2px;
  letter-spacing: .12em;
}
.kicker.dark{color: var(--ochre)}
.kicker.dark span{background: var(--ochre); color: var(--forest-deep)}

.display{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(40px, 6.5vw, 96px);
  line-height: 0.95;
  letter-spacing: -0.025em;
  color: var(--ink);
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.display em{font-style:italic;color:var(--terra-deep);font-variation-settings:"opsz" 144, "SOFT" 80}

.display-sm{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(28px, 3.6vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
}

.dek{
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.4;
  color: var(--ink-2);
  max-width: 720px;
  margin-top: 28px;
}

/* ============ CHALLENGE ============ */
.challenge{
  padding: 140px var(--gutter) 100px;
  position: relative;
}
.challenge-grid{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(40px, 8vw, 120px);
  align-items: start;
}
.challenge-text{font-size: 18px; line-height: 1.65; color: var(--ink)}
.challenge-text .lead{
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.35;
  color: var(--ochre-soft);
  margin-bottom: 32px;
  font-variation-settings:"opsz" 144, "SOFT" 90;
}
.challenge-text p + p{margin-top: 22px}
.challenge-text em{color: var(--ochre)}

.challenge-fragments{
  position: relative;
  aspect-ratio: 1;
  width: 100%;
  max-width: 600px;
  justify-self: end;
}

/* connection lines — light cream, draw-in */
.frag-lines{
  position:absolute; inset:0;
  width:100%; height:100%;
  color: rgba(244,236,214,0.6);
  pointer-events:none;
}
.frag-lines line{
  stroke-dasharray: 150;
  stroke-dashoffset: 150;
  transition: stroke-dashoffset 1.1s cubic-bezier(.2,.7,.2,1);
}
.frag-lines line:nth-of-type(1){transition-delay: .15s}
.frag-lines line:nth-of-type(2){transition-delay: .25s}
.frag-lines line:nth-of-type(3){transition-delay: .35s}
.frag-lines line:nth-of-type(4){transition-delay: .45s}
.frag-lines line:nth-of-type(5){transition-delay: .55s}
.frag-lines line:nth-of-type(6){transition-delay: .65s}
.challenge-fragments.is-in .frag-lines line{stroke-dashoffset: 0}

.frag-lines circle{
  transition: r 0.6s cubic-bezier(.2,.7,.2,1), opacity .6s ease;
  opacity: 0;
}
.challenge-fragments.is-in .frag-lines circle{opacity: 1}

.frag{
  position:absolute;
  display:flex;
  flex-direction: column;
  align-items:center;
  justify-content:center;
  width: 110px; height: 110px;
  border-radius: 50%;
  background: var(--forest-deep);
  border: 1px solid rgba(244,236,214,0.18);
  font-family: var(--mono);
  text-align: center;
  box-shadow:
    0 12px 24px -16px rgba(0,0,0,.55),
    inset 0 0 0 1px rgba(244,236,214,0.04);

  /* start collapsed at center, opacity 0 */
  top: 50%; left: 50%;
  transform: translate(-50%, -50%) scale(0.2);
  opacity: 0;
  transition:
    top 1.1s cubic-bezier(.2,.85,.25,1),
    left 1.1s cubic-bezier(.2,.85,.25,1),
    right 1.1s cubic-bezier(.2,.85,.25,1),
    bottom 1.1s cubic-bezier(.2,.85,.25,1),
    transform 1.1s cubic-bezier(.2,.85,.25,1),
    opacity .7s ease,
    box-shadow .4s ease,
    background .4s ease;
}
.frag:hover{
  transform: translate(0,0) scale(1.08) rotate(-2deg);
  background: var(--forest);
  box-shadow:
    0 18px 30px -16px rgba(224,176,74,0.35),
    inset 0 0 0 1px rgba(224,176,74,0.4);
}
.frag-no{
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  color: var(--ochre);
  line-height:1;
}
.frag-label{
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink);
  margin-top: 4px;
}

/* exploded positions — applied when section reveals */
.challenge-fragments.is-in .frag{
  opacity: 1;
  transform: translate(0,0) scale(1);
}
.challenge-fragments.is-in .f1{top: 0%;    left: 5%}
.challenge-fragments.is-in .f2{top: 0%;    left: auto; right: 5%}
.challenge-fragments.is-in .f3{top: 42%;   left: -2%}
.challenge-fragments.is-in .f4{top: 42%;   left: auto; right: -2%}
.challenge-fragments.is-in .f5{top: auto;  bottom: 0%; left: 12%}
.challenge-fragments.is-in .f6{top: auto;  bottom: 0%; left: auto; right: 12%}

.challenge-fragments.is-in .f1{transition-delay: .15s}
.challenge-fragments.is-in .f2{transition-delay: .25s}
.challenge-fragments.is-in .f3{transition-delay: .35s}
.challenge-fragments.is-in .f4{transition-delay: .45s}
.challenge-fragments.is-in .f5{transition-delay: .55s}
.challenge-fragments.is-in .f6{transition-delay: .65s}

/* fallback positions (no JS) */
.f1{top: 0%; left: 5%}
.f2{top: 0%; right: 5%}
.f3{top: 42%; left: -2%}
.f4{top: 42%; right: -2%}
.f5{bottom: 0%; left: 12%}
.f6{bottom: 0%; right: 12%}
.frag-center{
  position:absolute;
  top:50%; left:50%;
  transform: translate(-50%, -50%);
  width: 160px; height: 160px;
  border-radius:50%;
  background: var(--forest-deep);
  color: var(--ochre-soft);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column;
  font-family: var(--serif);
  gap: 2px;
  box-shadow:
    inset 0 0 0 1px var(--moss),
    0 20px 40px -20px rgba(0,0,0,.5);
}
.frag-center span:first-child{font-size: 38px; font-style: italic}
.frag-center span:last-child{font-family: var(--mono); font-size: 10px; letter-spacing:.2em; text-transform:uppercase; opacity:.7}

.response{
  margin-top: 70px;
  padding: 44px 48px;
  background:
    radial-gradient(120% 160% at 0% 0%, rgba(224,176,74,0.06), transparent 55%),
    linear-gradient(135deg, var(--forest) 0%, var(--forest-deep) 100%);
  color: var(--ink);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 28px;
  align-items: start;
  border-radius: 14px;
  position: relative;
  overflow: hidden;
  border: 1px solid transparent;
  background-clip: padding-box;
  box-shadow:
    0 30px 60px -30px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(244,236,214,0.05);
}
/* gradient border that fades out at the edges */
.response::after{
  content:"";
  position:absolute;
  inset: 0;
  border-radius: 14px;
  padding: 1px;
  background: linear-gradient(135deg,
    rgba(224,176,74,0.55) 0%,
    rgba(244,236,214,0.18) 30%,
    rgba(244,236,214,0.04) 55%,
    rgba(224,176,74,0.35) 100%);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}
/* soft glow wash in the corner */
.response::before{
  content:"";
  position:absolute;
  top:-40%; right:-10%;
  width: 60%; height: 180%;
  background: radial-gradient(closest-side, rgba(224,176,74,0.18), transparent 70%);
  pointer-events: none;
}
.response-arrow{
  font-family: var(--serif);
  font-size: 56px;
  line-height: 1;
  color: var(--ochre);
  position: relative;
  z-index: 1;
}
.response p{
  font-family: var(--serif);
  font-size: clamp(18px, 1.8vw, 24px);
  line-height: 1.5;
  font-weight: 350;
  color: var(--ink);
  position: relative;
  z-index: 1;
}
.response em{color: var(--ochre); font-style: italic}

@media (max-width: 900px){
  .challenge-grid{grid-template-columns: 1fr}
  .challenge-fragments{margin: 0 auto}
}

/* ============ MANIFESTO ============ */
.manifesto{
  position: relative;
  padding: 0;
  background: var(--paper);
  border-top: 1px solid rgba(244,236,214,.08);
  border-bottom: 1px solid rgba(244,236,214,.08);
  overflow: hidden;
}
.m-stage{
  position: relative;
  width: 100%;
  height: clamp(560px, 80vh, 760px);
  overflow: hidden;
}

/* Each slide is full-bleed and crossfades */
.m-slide{
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 1.1s cubic-bezier(.4,0,.2,1), visibility 0s linear 1.1s;
}
.m-slide.is-active{
  opacity: 1;
  visibility: visible;
  transition: opacity 1.1s cubic-bezier(.4,0,.2,1), visibility 0s linear 0s;
  z-index: 1;
}
.m-img{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.04);
}
.m-overlay{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(15,24,16,0.55) 0%, rgba(15,24,16,0.35) 40%, rgba(15,24,16,0.7) 100%),
    radial-gradient(120% 80% at 50% 50%, transparent 0%, rgba(15,24,16,0.35) 100%);
}

/* Centered message on every image */
.m-message{
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: clamp(80px, 12vw, 140px) clamp(20px, 6vw, 80px) clamp(60px, 8vw, 100px);
  color: var(--ink);
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 1s ease .25s, transform 1.1s cubic-bezier(.2,.7,.2,1) .25s;
}
.m-slide.is-active .m-message{
  opacity: 1;
  transform: translateY(0);
}
.m-message-eyebrow{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 28px;
  padding: 6px 14px;
  border: 1px solid rgba(224,176,74,0.45);
  border-radius: 999px;
  background: rgba(15,24,16,0.25);
  backdrop-filter: blur(6px);
}
.m-message p{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(24px, 3.4vw, 48px);
  line-height: 1.2;
  letter-spacing: -0.01em;
  font-variation-settings:"opsz" 144, "SOFT" 60;
  max-width: 1100px;
  text-shadow: 0 2px 30px rgba(0,0,0,0.45);
}
.m-message em{
  color: var(--ochre);
  font-style: italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}

/* Tabs — top-left, small mono */
.m-tabs{
  position: absolute;
  top: clamp(28px, 4vw, 56px);
  left: clamp(24px, 4vw, 56px);
  z-index: 5;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.m-tab{
  appearance: none;
  background: transparent;
  border: 0;
  padding: 6px 0;
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(244,236,214,0.55);
  cursor: pointer;
  transition: color .35s ease, transform .35s ease, letter-spacing .35s ease;
  text-align: left;
}
.m-tab:hover{
  color: var(--ink);
  transform: translateX(2px);
}
.m-tab.is-active{
  color: var(--ochre);
  letter-spacing: .26em;
}
.m-tab-num{
  font-family: var(--serif);
  font-style: italic;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  min-width: 22px;
  color: inherit;
  opacity: .85;
}
.m-tab-label{ color: inherit }

/* Progress bar under tabs — shows cycle countdown */
.m-tab-progress{
  margin-top: 12px;
  width: 120px;
  height: 1px;
  background: rgba(244,236,214,0.18);
  position: relative;
  overflow: hidden;
}
.m-tab-progress-bar{
  position: absolute;
  inset: 0 100% 0 0;
  background: var(--ochre);
  transition: inset 0.1s linear;
}

@media (max-width: 800px){
  .m-stage{height: clamp(520px, 90vh, 680px)}
  .m-tabs{
    top: clamp(20px, 5vw, 28px);
    left: clamp(18px, 5vw, 24px);
  }
  .m-tab{font-size: 10px}
  .m-tab-progress{width: 80px}
  .m-message{padding: 100px 24px 60px}
}

/* ============ APPROACH ============ */
.approach{
  padding: 140px var(--gutter) 100px;
}
.path{
  list-style: none;
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
  margin-bottom: 120px;
}
.path::before{
  content:"";
  position:absolute;
  top: 28px;
  left: 5%; right: 5%;
  height: 1px;
  background: repeating-linear-gradient(90deg, var(--terra) 0 6px, transparent 6px 12px);
}
.path li{
  padding: 0 16px;
  position: relative;
}
.path-no{
  display:flex;
  align-items:center;
  justify-content:center;
  width: 56px; height: 56px;
  border-radius:50%;
  background: var(--paper);
  border:1px solid var(--ink);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .12em;
  color: var(--ink);
  margin-bottom: 24px;
  position: relative;
  z-index: 1;
}
.path li:nth-child(1) .path-no{background:var(--terra);color:var(--bone);border-color:var(--terra)}
.path li:nth-child(2) .path-no{background:var(--ochre);color:var(--ink);border-color:var(--ochre)}
.path li:nth-child(3) .path-no{background:var(--moss);color:var(--bone);border-color:var(--moss)}
.path li:nth-child(4) .path-no{background:var(--forest);color:var(--ink);border-color:var(--forest)}
.path li:nth-child(5) .path-no{background:var(--umber);color:var(--ink);border-color:var(--umber)}

.path h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 22px;
  margin-bottom: 12px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.path p{
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}

@media (max-width: 900px){
  .path{grid-template-columns: 1fr 1fr; gap: 40px 20px}
  .path::before{display:none}
}
@media (max-width: 540px){
  .path{grid-template-columns: 1fr}
}

/* logic */
.logic{
  margin-top: 60px;
  padding: 60px;
  background: var(--bone);
  border: 1px solid rgba(63,45,30,.15);
  position: relative;
}
.logic-head{margin-bottom: 50px; max-width: 700px}
.logic-flow{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
}
.logic-flow article{
  padding: 0 18px;
  border-left: 1px solid rgba(63,45,30,.18);
}
.logic-flow article:first-child{border-left:none;padding-left:0}
.lf-no{
  display:inline-block;
  font-family:var(--serif);
  font-size:32px;
  color: var(--terra);
  margin-bottom: 14px;
}
.logic-flow h4{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 17px;
  margin-bottom: 10px;
  line-height: 1.2;
}
.logic-flow p{
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--ink-2);
}

@media (max-width: 900px){
  .logic{padding: 32px}
  .logic-flow{grid-template-columns: 1fr 1fr; gap: 28px}
  .logic-flow article{border-left:none; padding: 0}
}

/* ============ PLATFORM ============ */
.platform{
  background: var(--forest-deep);
  color: var(--cream);
  padding: 140px var(--gutter);
  position: relative;
  overflow: hidden;
}
.platform::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(198,145,71,.15), transparent 50%),
    radial-gradient(ellipse at 10% 80%, rgba(184,90,50,.1), transparent 55%);
  pointer-events:none;
}
.platform .section-head .display{color: var(--ink)}
.platform .section-head .display em{color: var(--ochre)}

.platform-grid{
  position: relative;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 20px;
}
.card{
  background: var(--cream);
  color: var(--ink);
  border-radius: 2px;
  overflow: hidden;
  display:flex;
  flex-direction:column;
  position: relative;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.card:hover{transform: translateY(-6px)}
.card.big{grid-column: span 7}
.card:not(.big){grid-column: span 5}
.card .card-img{
  aspect-ratio: 16/9;
  overflow:hidden;
}
.card.big .card-img{aspect-ratio: 5/4}
.card .card-img img{
  width:100%; height:100%;
  object-fit:cover;
  filter: saturate(1.05) contrast(1.03);
  transition: transform .8s ease;
}
.card:hover .card-img img{transform: scale(1.05)}
.card-body{padding: 32px 32px 36px}
.card-body.only{padding: 40px 32px}
.card-tag{
  display:inline-block;
  font-family:var(--mono);
  font-size: 10px; letter-spacing:.2em; text-transform:uppercase;
  color: var(--terra-deep);
  margin-bottom: 14px;
}
.card-body h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.15;
  margin-bottom: 12px;
  letter-spacing: -0.015em;
}
.card:has(.card-img) .card-body h3,
.platform-grid .card-body.only h3{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(34px, 3.6vw, 52px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 144, "SOFT" 50;
  margin-bottom: 18px;
  color: #f4ecd6;
}
.card:has(.card-img) .card-body h3 em,
.platform-grid .card-body.only h3 em{
  color: var(--ochre);
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 90;
}
.card-body p{
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
.chips{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  margin-top: 18px;
}
.chips li{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 6px 10px;
  border: 1px solid var(--ink);
  border-radius: 999px;
  color: var(--ink);
}

@media (max-width: 900px){
  .card.big, .card:not(.big){grid-column: span 12}
}

/* ============ PILLARS ============ */
.pillars{
  padding: 140px var(--gutter) 120px;
}
.pillars-list{
  list-style:none;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
}
.pillars-list li{
  position: relative;
  padding: 40px 36px 56px;
  border-top: 1px solid rgba(63,45,30,.2);
  border-left: 1px solid rgba(63,45,30,.12);
  transition: background .5s;
}
.pillars-list li:nth-child(3n+1){border-left:none}
.pillars-list li:nth-last-child(-n+3){border-bottom: 1px solid rgba(63,45,30,.2)}
.pillars-list li:hover{background: var(--bone)}

.p-no{
  display:inline-block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  color: var(--terra);
  margin-bottom: 18px;
}
.pillars-list h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(22px, 1.8vw, 28px);
  line-height: 1.15;
  letter-spacing: -0.015em;
  margin-bottom: 14px;
  color: var(--ink);
  max-width: 90%;
}
.pillars-list p{
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 90%;
}
.p-glyph{
  position: absolute;
  right: 28px; top: 32px;
  font-family: var(--serif);
  font-size: 36px;
  color: var(--ochre);
  opacity: .55;
  line-height: 1;
}

@media (max-width: 900px){
  .pillars-list{grid-template-columns: 1fr 1fr}
  .pillars-list li:nth-child(3n+1){border-left:1px solid rgba(63,45,30,.12)}
  .pillars-list li:nth-child(2n+1){border-left:none}
}
@media (max-width: 560px){
  .pillars-list{grid-template-columns: 1fr}
  .pillars-list li{border-left:none !important}
}

/* ============ VALUE ============ */
.value{
  padding: 120px var(--gutter);
  background: var(--cream);
  border-top: 1px solid rgba(63,45,30,.2);
}
.value-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid rgba(63,45,30,.2);
}
.value-grid article{
  padding: 36px 32px 40px;
  border-bottom: 1px solid rgba(63,45,30,.15);
  border-right: 1px solid rgba(63,45,30,.1);
  position:relative;
}
.value-grid article:nth-child(3n){border-right:none}
.value-grid h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.15;
  margin-bottom: 14px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.value-grid p{
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
@media (max-width: 900px){
  .value-grid{grid-template-columns: 1fr 1fr}
  .value-grid article:nth-child(3n){border-right:1px solid rgba(63,45,30,.1)}
  .value-grid article:nth-child(2n){border-right:none}
}
@media (max-width: 560px){
  .value-grid{grid-template-columns: 1fr}
  .value-grid article{border-right:none !important}
}

/* ============ PARTNERS ============ */
.partners{
  position: relative;
  padding: 140px var(--gutter) 120px;
  overflow: hidden;
}
.partners-art{
  position:absolute;
  top: 0; right: 0;
  width: 38%;
  height: 100%;
  opacity: 0.18;
  pointer-events:none;
}
.partners-art img{
  width:100%; height:100%;
  object-fit: cover;
  filter: sepia(0.5) saturate(1.2) contrast(0.95);
  mask-image: linear-gradient(to left, black, transparent);
  -webkit-mask-image: linear-gradient(to left, black, transparent);
}
.partner-table{
  position: relative;
  width:100%;
  border-collapse: collapse;
  font-size: 15.5px;
}
.partner-table thead th{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  text-align: left;
  color: var(--terra-deep);
  padding: 14px 16px;
  border-bottom: 1px solid var(--ink);
}
.partner-table tbody tr{
  border-bottom: 1px solid rgba(63,45,30,.12);
  transition: background .3s;
}
.partner-table tbody tr:hover{background: var(--bone)}
.partner-table td{
  padding: 26px 16px;
  vertical-align: top;
  line-height: 1.55;
  color: var(--ink-2);
}
.partner-table td:first-child{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(18px, 1.6vw, 22px);
  color: var(--ink);
  width: 36%;
  letter-spacing: -0.01em;
}
.pt-no{
  display:inline-flex;
  align-items:center;justify-content:center;
  width: 30px;height: 30px;
  border:1px solid var(--terra);
  border-radius:50%;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--terra-deep);
  margin-right: 14px;
  vertical-align: middle;
}

@media (max-width: 700px){
  .partner-table, .partner-table tbody, .partner-table tr, .partner-table td{display:block;width:100%}
  .partner-table thead{display:none}
  .partner-table tr{padding: 20px 0}
  .partner-table td{padding: 6px 0}
  .partner-table td:first-child{width: 100%; margin-bottom: 6px}
}

/* ============ VALUES ============ */
.values{
  padding: 120px var(--gutter);
  background: var(--cream-2);
}
.values-grid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  border-top: 1px solid rgba(63,45,30,.2);
  border-bottom: 1px solid rgba(63,45,30,.2);
}
.values-grid > div{
  padding: 36px 24px;
  border-right: 1px solid rgba(63,45,30,.12);
  position:relative;
}
.values-grid > div:last-child{border-right:none}
.values-grid span{
  font-family: var(--serif);
  font-style: italic;
  font-size: 26px;
  color: var(--terra);
  display:block;
  margin-bottom: 16px;
}
.values-grid h4{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 20px;
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.values-grid p{
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
@media (max-width: 900px){
  .values-grid{grid-template-columns: 1fr 1fr}
  .values-grid > div{border-right:1px solid rgba(63,45,30,.12); border-bottom:1px solid rgba(63,45,30,.12)}
}

/* ============ CONTACT ============ */
.contact{
  background:
    radial-gradient(ellipse at 20% 0%, rgba(224,176,74,0.10), transparent 55%),
    radial-gradient(ellipse at 90% 100%, rgba(0,0,0,0.35), transparent 60%),
    linear-gradient(180deg, var(--terracotta) 0%, var(--terracotta-deep) 100%);
  color: #fff5e8;
  padding: 140px var(--gutter) 100px;
  position: relative;
  overflow: hidden;
}
.contact-inner{
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.contact-title{color: #fff5e8}
.contact-title em{
  color: var(--ochre-soft);
  font-style: italic;
}

/* lighten the section kicker inside the terracotta block */
.contact .kicker.dark{color: rgba(255,245,232,0.78)}
.contact .kicker.dark span{color: var(--ochre-soft); opacity: 1}

.contact-dek{
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.45;
  color: #fff5e8;
  opacity: 0.92;
  max-width: 720px;
  margin: 30px 0 60px;
}

.contact-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 48px;
  padding: 36px 0;
  border-top: 1px solid rgba(255,245,232,.28);
  border-bottom: 1px solid rgba(255,245,232,.28);
  margin-bottom: 48px;
  max-width: 720px;
}
.contact-grid > div{display:flex; flex-direction:column; gap:6px}
.c-lab{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ochre-soft);
  margin-bottom: 6px;
}
.c-val{
  font-family: var(--serif);
  font-size: clamp(17px, 1.6vw, 21px);
  line-height: 1.3;
  color: #fff5e8;
  transition: color .3s;
}
a.c-val:hover{color: var(--ochre-soft)}

.contact-cta{
  display:inline-flex;
  align-items:center;
  gap: 14px;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(28px, 4vw, 56px);
  font-weight: 350;
  color: var(--ochre-soft);
  border-bottom: 1px solid var(--ochre-soft);
  padding-bottom: 12px;
  transition: gap .4s, color .4s, border-color .4s;
}
.contact-cta svg{width: 28px; height: 28px}
.contact-cta:hover{
  gap: 28px;
  color: #fff5e8;
  border-bottom-color: #fff5e8;
}

/* === Contact form === */
.contact-form{
  display: grid;
  gap: 22px;
  max-width: 720px;
  margin-top: 8px;
}
.contact-form .cf-honeypot{
  position: absolute !important;
  left: -9999px !important;
  width: 1px; height: 1px;
  opacity: 0;
  pointer-events: none;
}
.contact-form .cf-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.contact-form .cf-field{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.contact-form .cf-lab{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ochre-soft);
}
.contact-form input,
.contact-form textarea{
  font-family: var(--serif);
  font-size: clamp(16px, 1.4vw, 19px);
  font-weight: 350;
  line-height: 1.4;
  color: #fff5e8;
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(255,245,232,.28);
  padding: 10px 2px 12px;
  outline: none;
  transition: border-color .3s ease, background .3s ease;
  width: 100%;
  resize: vertical;
}
.contact-form textarea{
  min-height: 120px;
  border: 1px solid rgba(255,245,232,.28);
  padding: 16px;
  border-radius: 2px;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{
  color: rgba(255,245,232,.35);
  font-style: italic;
}
.contact-form input:focus,
.contact-form textarea:focus{
  border-color: var(--ochre);
  background: rgba(255,245,232,.04);
}
button.contact-cta{
  appearance: none;
  background: transparent;
  cursor: pointer;
  border: 0;
  border-bottom: 1px solid var(--ochre-soft);
  border-radius: 0;
  padding: 12px 0;
  margin-top: 12px;
  justify-self: start;
  font-family: var(--serif);
  font-style: italic;
}
button.contact-cta:focus-visible{
  outline: 2px solid var(--ochre);
  outline-offset: 6px;
}

@media (max-width: 700px){
  .contact-form .cf-row{grid-template-columns: 1fr}
}

.seed-pattern{
  position:absolute;
  bottom: 0; left: 0; right: 0;
  width: 100%; height: 160px;
  color: #fff5e8;
  opacity: 0.16;
  pointer-events:none;
}

@media (max-width: 800px){
  .contact-grid{grid-template-columns: 1fr}
  .contact-grid > div:nth-child(2){display:none}
}

/* ============ FOOTER ============ */
.foot{
  background:
    radial-gradient(ellipse at 15% 0%, rgba(255,235,180,0.18), transparent 55%),
    radial-gradient(ellipse at 95% 100%, rgba(120,75,15,0.45), transparent 60%),
    linear-gradient(180deg, var(--ochre) 0%, #b88a2c 100%);
  color: var(--ink);
  padding: 50px var(--gutter);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.foot-row{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap: 24px;
  padding-bottom: 28px;
  border-bottom: 1px solid rgba(244,236,214,.32);
  margin-bottom: 24px;
}
.foot-row .foot-tag{
  margin-left: auto;
  text-align: right;
  white-space: nowrap;
}
.foot-mark{
  font-family: var(--serif);
  font-style: italic;
  font-size: 28px;
  color: var(--ink);
  letter-spacing: 0;
  display: inline-flex;
  align-items: center;
}
.foot-logo{
  width: auto;
  height: 32px;
  display: block;
  object-fit: contain;
  transform: scale(1.85);
  transform-origin: left center;
  margin-right: 8px;
}
.foot-name{
  font-family: var(--serif);
  font-size: 16px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--paper);
}
.foot-tag{
  margin-left: auto;
  max-width: 36ch;
  align-self: center;
  text-align: right;
  font-family: var(--serif);
  font-style: italic;
  font-size: 15px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--paper);
  opacity: 0.92;
}
.foot-meta{
  display:flex;
  flex-wrap:wrap;
  gap: 24px;
  color: var(--paper);
  opacity: .9;
}
.foot-meta span:not(:first-child)::before{
  content:"·";
  margin-right: 24px;
}
@media (max-width: 700px){
  .foot-tag{margin-left:0; width:100%}
  .foot-meta span:not(:first-child)::before{display:none}
}

/* ============ REVEAL ANIMATIONS ============ */
.reveal{
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 1s ease, transform 1.1s cubic-bezier(.2,.7,.2,1);
}
.reveal.is-in{opacity:1; transform:none}

/* ===== Hero choreography ===== */
/* Title letters animate via .is-on (set by JS).
   Surrounding chrome fades in after typewriter completes via .is-loaded on .hero */
.hero-meta,
.hero-eyebrow,
.hero-body,
.hero-stats{
  opacity: 0;
  transform: translateY(14px);
  filter: blur(6px);
  transition:
    opacity 1.1s cubic-bezier(.2,.7,.2,1),
    transform 1.1s cubic-bezier(.2,.7,.2,1),
    filter 1.1s cubic-bezier(.2,.7,.2,1);
}
.hero.is-loaded .hero-meta{transition-delay: .15s}
.hero.is-loaded .hero-eyebrow{transition-delay: .35s}
.hero.is-loaded .hero-body{transition-delay: .55s}
.hero.is-loaded .hero-stats{transition-delay: .75s}
.hero.is-loaded .hero-meta,
.hero.is-loaded .hero-eyebrow,
.hero.is-loaded .hero-body,
.hero.is-loaded .hero-stats{
  opacity: 1;
  transform: none;
  filter: blur(0);
}
@keyframes fadeIn{to{opacity:1}}

/* ============================================================
   SUBPAGES (platform.html, pillars.html, partnership.html, projects.html)
   ============================================================ */

/* Make platform cards clickable links retain card look */
a.card{
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  transition: transform .45s cubic-bezier(.2,.7,.2,1), box-shadow .45s ease;
}
a.card:hover{
  transform: translateY(-6px);
  box-shadow: 0 30px 60px -28px rgba(0,0,0,0.5);
}
.card-go{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  margin-top: 18px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ochre);
  transition: gap .3s ease, color .3s ease;
}
.card-go svg{width:14px;height:14px}
a.card:hover .card-go{gap:18px; color: var(--ochre-soft)}

/* current-page nav indicator */
.nav-links a.is-current{color: var(--ochre)}
.nav-links a.is-current span{color: var(--ochre); opacity: 1}

/* ============ SUB-HERO ============ */
.subpage main{padding-top: 0}
.sub-hero{
  position: relative;
  padding: 180px var(--gutter) 80px;
  text-align: center;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(224,176,74,0.10), transparent 55%),
    var(--paper);
}
.sub-hero-eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 28px;
}
.sub-hero-eyebrow .line{
  display: inline-block;
  width: 60px;
  height: 1px;
  background: var(--terra);
  opacity: .5;
}
.sub-hero-title{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(48px, 8vw, 120px);
  line-height: .95;
  letter-spacing: -0.025em;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
  margin: 0 auto 28px;
  max-width: 1100px;
}
.sub-hero-title .word{display: inline-block; margin-right: .18em}
.sub-hero-title em{
  color: var(--ochre);
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 90;
}
.sub-hero-dek{
  max-width: 720px;
  margin: 0 auto 36px;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.5;
  color: var(--ink-2);
  font-variation-settings:"opsz" 144, "SOFT" 80;
}
.sub-hero .link-arrow{
  justify-content: center;
}

/* ============ COMPONENT (platform.html) ============ */
.component{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
  padding: 100px var(--gutter);
  border-top: 1px solid rgba(244,236,214,0.08);
}
.component.reverse .component-media{order: 2}
.component.reverse .component-body{order: 1}

.component-media{
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border-radius: 18px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.06),
    0 40px 70px -32px rgba(0,0,0,0.6);
}
.component-media img{
  width:100%; height:100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.04) sepia(.04);
}
.component-cap{
  position: absolute;
  top: 18px; left: 18px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ochre);
  background: rgba(15,24,16,0.78);
  border: 1px solid rgba(224,176,74,0.4);
  padding: 6px 12px;
  border-radius: 999px;
  backdrop-filter: blur(6px);
}

.component-body .kicker{
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 22px;
}
.component-body .kicker span{color: var(--ochre); font-family: var(--serif); font-style: italic; font-size: 14px}
.component-title{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(32px, 4.4vw, 56px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
  margin-bottom: 24px;
}
.component-title em{
  color: var(--ochre);
  font-style: italic;
  font-variation-settings:"opsz" 144, "SOFT" 90;
}
.component-lead{
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.5;
  color: var(--ochre-soft);
  margin-bottom: 28px;
  font-variation-settings:"opsz" 144, "SOFT" 80;
}
.component-list{
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.component-list li{
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink);
  padding-left: 36px;
  position: relative;
}
.component-list li span{
  position: absolute;
  left: 0; top: 2px;
  font-family: var(--serif);
  font-style: italic;
  color: var(--ochre);
  font-size: 17px;
}
.component-chips{
  margin-bottom: 22px;
}
.component-foot{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .04em;
  color: var(--ink-2);
  opacity: .85;
  border-top: 1px solid rgba(244,236,214,0.1);
  padding-top: 16px;
}

@media (max-width: 900px){
  .component{
    grid-template-columns: 1fr;
    padding: 70px var(--gutter);
  }
  .component.reverse .component-media{order: 0}
  .component.reverse .component-body{order: 0}
}

/* ============ HOW WE WORK (partnership.html) ============ */
.how-we-work{
  padding: 120px var(--gutter);
  border-top: 1px solid rgba(244,236,214,0.08);
}
.how-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 3vw, 36px);
}
.how-grid article{
  padding: 32px 28px;
  background: linear-gradient(180deg, rgba(244,236,214,0.04), rgba(244,236,214,0.02));
  border: 1px solid rgba(244,236,214,0.08);
  border-radius: 16px;
  transition: transform .4s cubic-bezier(.2,.7,.2,1), border-color .4s ease, background .4s ease;
}
.how-grid article:hover{
  transform: translateY(-4px);
  border-color: rgba(224,176,74,0.35);
  background: linear-gradient(180deg, rgba(224,176,74,0.06), rgba(244,236,214,0.02));
}
.how-no{
  font-family: var(--serif);
  font-style: italic;
  font-size: 28px;
  color: var(--ochre);
  display: block;
  margin-bottom: 16px;
}
.how-grid h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 22px;
  color: var(--ink);
  margin-bottom: 10px;
  letter-spacing: -0.01em;
}
.how-grid p{
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-2);
}
@media (max-width: 900px){
  .how-grid{grid-template-columns: 1fr 1fr}
}
@media (max-width: 560px){
  .how-grid{grid-template-columns: 1fr}
}

/* ============ PROJECTS INDEX (projects.html) ============ */
.projects-index{
  padding: 120px var(--gutter);
}
.proj-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 3vw, 32px);
}
.proj{
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, rgba(244,236,214,0.04), rgba(244,236,214,0.02));
  border: 1px solid rgba(244,236,214,0.08);
  border-radius: 18px;
  overflow: hidden;
  transition: transform .45s cubic-bezier(.2,.7,.2,1), border-color .4s ease, box-shadow .4s ease;
}
.proj:hover{
  transform: translateY(-6px);
  border-color: rgba(224,176,74,0.4);
  box-shadow: 0 30px 60px -28px rgba(0,0,0,0.55);
}
.proj-media{
  aspect-ratio: 4/3;
  overflow: hidden;
}
.proj-media img{
  width:100%; height:100%;
  object-fit: cover;
  transition: transform 8s cubic-bezier(.2,.7,.2,1);
  filter: saturate(1.05) contrast(1.04) sepia(.04);
}
.proj:hover .proj-media img{transform: scale(1.06)}

.proj-body{
  padding: 28px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.proj-tag{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 12px;
}
.proj-body h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 26px;
  color: var(--ink);
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.proj-where{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .08em;
  color: var(--ink-2);
  opacity: .8;
  margin-bottom: 18px;
}
.proj-body p:not(.proj-where){
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink);
  margin-bottom: 18px;
}
.proj-chips{
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}
.proj-chips li{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-2);
  padding: 5px 11px;
  border: 1px solid rgba(244,236,214,0.18);
  border-radius: 999px;
}

@media (max-width: 1000px){
  .proj-grid{grid-template-columns: 1fr 1fr}
}
@media (max-width: 640px){
  .proj-grid{grid-template-columns: 1fr}
}

/* ============ PROJECT NUMBERS ============ */
.proj-numbers{
  padding: 120px var(--gutter);
  border-top: 1px solid rgba(244,236,214,0.08);
}
.numbers-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 4vw, 60px);
  border-top: 1px solid rgba(244,236,214,0.16);
  padding-top: 40px;
}
.numbers-grid > div{
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  text-align: center;
}
.numbers-grid .num{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1;
  color: var(--ochre);
  font-variation-settings:"opsz" 144, "SOFT" 60;
}
.numbers-grid .lab{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  max-width: 240px;
}
@media (max-width: 900px){
  .numbers-grid{grid-template-columns: 1fr 1fr; gap: 30px}
}

/* ============ SUB CTA (all subpages) ============ */
.sub-cta{
  padding: 100px var(--gutter) 140px;
  border-top: 1px solid rgba(244,236,214,0.08);
  text-align: center;
}
.sub-cta h3{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(28px, 3.4vw, 40px);
  line-height: 1.1;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin-bottom: 36px;
  font-variation-settings:"opsz" 144, "SOFT" 60;
}
.sub-cta-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 980px;
  margin: 0 auto;
}
.sub-cta-grid a{
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 12px;
  padding: 22px 24px;
  border: 1px solid rgba(244,236,214,0.18);
  border-radius: 14px;
  background: rgba(244,236,214,0.03);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .35s ease, border-color .35s ease, transform .35s ease, color .35s ease;
}
.sub-cta-grid a span{
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ochre);
  opacity: .9;
}
.sub-cta-grid a:hover{
  background: rgba(224,176,74,0.08);
  border-color: rgba(224,176,74,0.45);
  color: var(--ochre-soft);
  transform: translateY(-3px);
}
@media (max-width: 800px){
  .sub-cta-grid{grid-template-columns: 1fr}
}

/* ============================================================
   NAV DROPDOWN — "The Hub"
   ============================================================ */
.nav-drop{
  position: relative;
  display: inline-block;
}
.nav-drop-trigger{
  /* match .nav-links a exactly */
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  /* inherit the .nav mono · 11px, then enforce uppercase to match links */
  font: inherit;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-2);
  transition: color .25s ease;
}
.nav-drop-trigger:hover,
.nav-drop-trigger[aria-expanded="true"]{
  color: var(--terra-deep);
}
.nav-drop-trigger.is-current{
  color: var(--ochre);
}
.nav-drop-trigger svg{
  width: 10px;
  height: 10px;
  transition: transform .25s ease;
  opacity: .7;
  align-self: center;
  transform: translateY(-1px);
}
.nav-drop-trigger:hover svg,
.nav-drop-trigger[aria-expanded="true"] svg{
  opacity: 1;
}
.nav-drop-trigger[aria-expanded="true"] svg{
  transform: rotate(180deg);
}
.nav-drop-menu{
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  min-width: 220px;
  padding: 10px;
  background: rgba(36, 50, 35, 0.96);
  border: 1px solid rgba(244, 236, 214, 0.12);
  border-radius: 14px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  gap: 2px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease, visibility 0s linear .25s;
  box-shadow: 0 24px 60px -28px rgba(0,0,0,0.6), 0 8px 24px -16px rgba(0,0,0,0.45);
}
.nav-drop.is-open .nav-drop-menu{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
  transition: opacity .25s ease, transform .25s ease, visibility 0s linear 0s;
}
.nav-drop-menu a{
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: var(--ink-2);
  transition: background .2s ease, color .2s ease;
}
.nav-drop-menu a span{
  font-family: var(--serif);
  font-style: italic;
  font-size: 12px;
  color: var(--ochre);
  opacity: .85;
}
.nav-drop-menu a:hover{
  background: rgba(224, 176, 74, 0.08);
  color: var(--ochre-soft);
}
.nav-drop-menu a.is-current{
  background: rgba(224, 176, 74, 0.12);
  color: var(--ochre);
}


/* ============================================================
   ABOUT SUMMARY (homepage — replaces old Challenge)
   Matches the editorial system used by .sub-hero / .sub-hero-title
   ============================================================ */
.about-summary{
  position: relative;
  padding: clamp(110px, 14vw, 180px) var(--gutter) clamp(80px, 10vw, 140px);
  text-align: center;
  border-bottom: 1px solid rgba(244,236,214,.08);
  background:
    radial-gradient(120% 70% at 50% 0%, rgba(224,176,74,0.06), transparent 60%),
    var(--paper);
}

/* Eyebrow — same rhythm as .sub-hero-eyebrow */
.about-summary-eyebrow{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin: 0 0 32px;
}
.about-summary-eyebrow .line{
  display: inline-block;
  width: 60px;
  height: 1px;
  background: var(--terra, var(--ochre));
  opacity: .5;
}

/* Title — matches .sub-hero-title scale & variation settings */
.about-summary-title{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(40px, 6vw, 88px);
  line-height: 1.02;
  letter-spacing: -0.022em;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
  max-width: 1100px;
  margin: 0 auto 36px;
}
.about-summary-title em{
  color: var(--ochre);
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 90;
}

/* Lead — same italic editorial dek as .sub-hero-dek */
.about-summary-lead{
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(18px, 1.7vw, 22px);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 760px;
  margin: 0 auto 64px;
  font-variation-settings: "opsz" 144, "SOFT" 80;
}
.about-summary-lead em{
  font-style: italic;
  color: var(--ochre);
}

/* Three-column meta strip */
.about-summary-meta{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  max-width: 980px;
  margin: 0 auto 56px;
  text-align: left;
  border-top: 1px solid rgba(244,236,214,.12);
  border-bottom: 1px solid rgba(244,236,214,.12);
}
.about-summary-meta > div{
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: 14px;
  row-gap: 6px;
  align-items: baseline;
  padding: 28px 28px;
  border-right: 1px solid rgba(244,236,214,.08);
}
.about-summary-meta > div:last-child{ border-right: none; }
.asm-no{
  grid-row: 1 / span 2;
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  color: var(--ochre);
  font-variation-settings: "opsz" 144, "SOFT" 90;
  line-height: 1;
}
.asm-lab{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
  opacity: .85;
}
.asm-val{
  font-family: var(--serif);
  font-weight: 350;
  font-size: 17px;
  line-height: 1.4;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
}

/* CTA inherits .link-arrow but centred & spaced */
.about-summary-cta{
  justify-content: center;
  margin-top: 8px;
}

@media (max-width: 900px){
  .about-summary-meta{
    grid-template-columns: 1fr;
  }
  .about-summary-meta > div{
    border-right: none;
    border-bottom: 1px solid rgba(244,236,214,.08);
    padding: 22px 4px;
  }
  .about-summary-meta > div:last-child{ border-bottom: none; }
}
@media (max-width: 600px){
  .about-summary{
    padding: clamp(70px, 14vw, 110px) var(--gutter) clamp(60px, 10vw, 90px);
  }
  .about-summary-title{
    font-size: clamp(34px, 9vw, 52px);
  }
  .about-summary-title br{ display: none; }
  .about-summary-lead{
    margin-bottom: 48px;
  }
}

/* ============================================================
   PROJECTS CAROUSEL (homepage)
   ============================================================ */
.proj-carousel{
  padding: clamp(80px, 12vw, 140px) 6vw clamp(60px, 9vw, 120px);
  border-bottom: 1px solid rgba(244,236,214,.10);
}
.proj-carousel .section-head{
  max-width: 1200px;
  margin: 0 auto 56px;
}
.pc-stage{
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
}
.pc-track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(320px, 380px);
  gap: 24px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 8px 4px 24px;
  scrollbar-width: none;
}
.pc-track::-webkit-scrollbar{ display: none; }
.pc-card{
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  background: rgba(244,236,214,.03);
  border: 1px solid rgba(244,236,214,.10);
  text-decoration: none;
  color: var(--ink);
  transition: transform .35s ease, border-color .35s ease, background .35s ease;
}
.pc-card:hover{
  transform: translateY(-4px);
  border-color: var(--ochre);
  background: rgba(244,236,214,.06);
}
.pc-img{
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.pc-img img{
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(.85) brightness(.95);
  transition: transform .6s ease;
}
.pc-card:hover .pc-img img{ transform: scale(1.05); }
.pc-body{ padding: 22px 22px 26px; }
.pc-tag{
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 12px;
}
.pc-body h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 24px;
  line-height: 1.2;
  margin: 0 0 8px;
}
.pc-body p{
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.55;
  margin: 0 0 16px;
}
.pc-go{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink);
  border-top: 1px solid rgba(244,236,214,.10);
  padding-top: 14px;
}
.pc-go svg{ width: 14px; height: 14px; }
.pc-arrow{
  position: absolute;
  top: 38%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(244,236,214,.25);
  background: rgba(36,50,35,.85);
  backdrop-filter: blur(6px);
  color: var(--ink);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: border-color .2s, background .2s, color .2s;
  z-index: 3;
}
.pc-arrow svg{ width: 18px; height: 18px; }
.pc-arrow:hover{
  border-color: var(--ochre);
  color: var(--ochre);
  background: rgba(36,50,35,.95);
}
.pc-prev{ left: -8px; }
.pc-next{ right: -8px; }
.pc-foot{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  max-width: 1280px;
  margin: 32px auto 0;
  padding: 0 4px;
}
.pc-dots{
  display: flex;
  gap: 10px;
}
.pc-dot{
  width: 28px;
  height: 2px;
  background: rgba(244,236,214,.18);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background .25s;
}
.pc-dot.is-on{ background: var(--ochre); }
.pc-all{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--ochre);
  padding-bottom: 4px;
}
.pc-all:hover{ color: var(--ochre); }
@media (max-width: 760px){
  .pc-arrow{ display: none; }
  .pc-track{ grid-auto-columns: 84%; }
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials{
  padding: clamp(80px, 12vw, 140px) 6vw clamp(60px, 9vw, 120px);
  border-bottom: 1px solid rgba(244,236,214,.10);
}
.testimonials .section-head{
  max-width: 1200px;
  margin: 0 auto 56px;
}
.testi-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  max-width: 1280px;
  margin: 0 auto;
}
.testi{
  margin: 0;
  padding: 36px 32px 32px;
  background: rgba(244,236,214,.03);
  border: 1px solid rgba(244,236,214,.10);
  display: flex;
  flex-direction: column;
  gap: 22px;
  position: relative;
}
.testi-mark{
  font-family: var(--serif);
  font-style: italic;
  font-size: 64px;
  line-height: .6;
  color: var(--ochre);
  opacity: .55;
}
.testi blockquote{
  margin: 0;
  font-family: var(--serif);
  font-weight: 300;
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink);
  text-align: center;
}
.testi figcaption{
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid rgba(244,236,214,.10);
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  text-align: center;
}
.testi-name{
  font-family: var(--serif);
  font-size: 16px;
  color: var(--ink);
}
.testi-role{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ochre);
}
@media (max-width: 900px){
  .testi-grid{ grid-template-columns: 1fr; }
}

/* ============================================================
   HUB LIST (blog / reports / research)
   ============================================================ */
.hub-list{
  padding: clamp(60px, 9vw, 110px) 6vw;
  max-width: 1100px;
  margin: 0 auto;
}
.hub-list .section-head{ margin-bottom: 48px; }
.hub-posts{
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid rgba(244,236,214,.10);
}
.hub-posts > li{
  border-bottom: 1px solid rgba(244,236,214,.10);
}
.hub-post{
  display: grid;
  grid-template-columns: 160px 1fr 140px;
  gap: 32px;
  align-items: baseline;
  padding: 28px 0;
  text-decoration: none;
  color: var(--ink);
  transition: background .25s, padding .25s;
}
.hub-post:hover{
  background: rgba(244,236,214,.025);
  padding-left: 16px;
  padding-right: 16px;
}
.hp-date{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  color: var(--ochre);
  text-transform: uppercase;
}
.hub-post h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.25;
  margin: 0 0 8px;
}
.hub-post p{
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.55;
  margin: 0;
  max-width: 600px;
}
.hp-tag{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-2);
  text-align: right;
  white-space: nowrap;
}
@media (max-width: 800px){
  .hub-post{
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .hp-tag{ text-align: left; }
}

/* ============================================================
   CASE STUDY PAGES (projects/*.html)
   ============================================================ */
.case-hero{
  padding: clamp(80px, 12vw, 150px) 6vw clamp(40px, 6vw, 80px);
  max-width: 1280px;
  margin: 0 auto;
}
.case-hero-meta{
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 32px;
}
.case-hero-title{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(48px, 8vw, 120px);
  line-height: .96;
  letter-spacing: -.02em;
  margin: 0 0 28px;
  font-variation-settings: "opsz" 144, "SOFT" 50;
}
.case-hero-title em{ font-style: italic; color: var(--ochre); }
.case-hero-dek{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(18px, 1.7vw, 22px);
  line-height: 1.5;
  color: var(--ink-2);
  max-width: 720px;
  margin: 0 0 48px;
}
.case-hero-img{
  width: 100%;
  aspect-ratio: 21 / 9;
  overflow: hidden;
  border: 1px solid rgba(244,236,214,.10);
}
.case-hero-img img{
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(.9);
}

.case-meta{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 36px 6vw;
  border-top: 1px solid rgba(244,236,214,.10);
  border-bottom: 1px solid rgba(244,236,214,.10);
}
.case-meta > div{
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cm-lab{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ochre);
}
.cm-val{
  font-family: var(--serif);
  font-size: 16px;
  color: var(--ink);
  line-height: 1.35;
}
@media (max-width: 900px){
  .case-meta{ grid-template-columns: repeat(2, 1fr); }
}

.case-body{
  padding: clamp(60px, 9vw, 120px) 6vw;
  max-width: 1100px;
  margin: 0 auto;
}
.case-prose{
  max-width: 760px;
  margin: 0 auto;
}
.case-prose .lead{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(19px, 1.8vw, 24px);
  line-height: 1.5;
  color: var(--ink);
  margin: 0 0 28px;
}
.case-prose p{
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-2);
  margin: 0 0 20px;
}

.case-pillars{
  padding: clamp(60px, 9vw, 120px) 6vw;
  max-width: 1280px;
  margin: 0 auto;
  border-top: 1px solid rgba(244,236,214,.10);
}
.case-pillars .section-head{ margin-bottom: 48px; }

.case-numbers{
  padding: clamp(60px, 9vw, 120px) 6vw;
  max-width: 1280px;
  margin: 0 auto;
  border-top: 1px solid rgba(244,236,214,.10);
}
.case-numbers .section-head{ margin-bottom: 48px; }

.case-quote{
  padding: clamp(60px, 9vw, 120px) 6vw;
  max-width: 900px;
  margin: 0 auto;
  border-top: 1px solid rgba(244,236,214,.10);
  text-align: center;
}
.case-quote blockquote{
  font-family: var(--serif);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(22px, 3vw, 34px);
  line-height: 1.35;
  color: var(--ink);
  margin: 0 0 24px;
}
.case-quote figcaption{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ochre);
}

/* ============================================================
   PROJECT CARD HOVER (projects.html as anchors)
   ============================================================ */
a.proj{
  text-decoration: none;
  color: var(--ink);
}
a.proj .proj-go{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink);
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(244,236,214,.10);
  transition: color .2s, gap .2s;
}
a.proj .proj-go svg{ width: 14px; height: 14px; }
a.proj:hover .proj-go{ color: var(--ochre); gap: 12px; }


/* ============================================================
   BLOG POST ARTICLE (blog/*.html)
   Built for online readability — short measure, generous leading,
   scannable hierarchy, pull-quote, callout, author + project link.
   ============================================================ */

.post{
  max-width: 1080px;
  margin: 0 auto;
  padding: clamp(80px, 11vw, 140px) var(--gutter) 0;
}

/* -- Article head -- */
.post-head{
  max-width: 760px;
  margin: 0 auto clamp(48px, 6vw, 80px);
}
.post-crumbs{
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin: 0 0 32px;
  opacity: .85;
}
.post-crumbs a{
  color: var(--ink-2);
  text-decoration: none;
  border-bottom: 1px solid rgba(244,236,214,.25);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
}
.post-crumbs a:hover{ color: var(--ochre); border-color: var(--ochre); }
.post-crumbs > span[aria-hidden]{ color: var(--ochre); opacity: .7; }

.post-title{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(38px, 5.4vw, 64px);
  line-height: 1.04;
  letter-spacing: -.02em;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
  margin: 0 0 24px;
}
.post-title em{
  font-style: italic;
  color: var(--ochre);
  font-variation-settings: "opsz" 144, "SOFT" 90;
}
.post-dek{
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(19px, 1.8vw, 23px);
  line-height: 1.5;
  color: var(--ink-2);
  margin: 0 0 36px;
  font-variation-settings: "opsz" 144, "SOFT" 80;
}
.post-dek em{ color: var(--ochre); font-style: italic; }

.post-meta{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 20px 0;
  border-top: 1px solid rgba(244,236,214,.12);
  border-bottom: 1px solid rgba(244,236,214,.12);
  margin: 0 0 40px;
}
.pm-row{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.pm-author{ color: var(--ink); }
.pm-sep{ color: var(--ochre); opacity: .7; }
.pm-tags{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.pm-tags span{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ochre);
  padding: 5px 10px;
  border: 1px solid rgba(224,176,74,.35);
  border-radius: 999px;
}

.post-hero{
  margin: 0;
}
.post-hero img{
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border: 1px solid rgba(244,236,214,.10);
  filter: saturate(.92);
}
.post-hero figcaption{
  margin-top: 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  color: var(--ink-2);
  opacity: .8;
  line-height: 1.5;
}

/* -- Body — narrow editorial measure for online readability -- */
.post-body{
  max-width: 680px;
  margin: 0 auto;
}
.post-lead{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(20px, 1.7vw, 23px);
  line-height: 1.55;
  color: var(--ink);
  margin: 0 0 36px;
  font-variation-settings: "opsz" 144, "SOFT" 50;
}
.post-lead em{ color: var(--ochre); font-style: italic; }

.post-body h2{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(26px, 2.6vw, 34px);
  line-height: 1.18;
  letter-spacing: -.012em;
  color: var(--ink);
  margin: 56px 0 18px;
  font-variation-settings: "opsz" 144, "SOFT" 60;
}
.post-body h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(19px, 1.7vw, 22px);
  line-height: 1.3;
  color: var(--ink);
  margin: 36px 0 12px;
}
.post-body p{
  font-family: var(--sans);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.75;
  color: var(--ink);
  margin: 0 0 22px;
}
.post-body p em{
  font-family: var(--serif);
  font-style: italic;
  color: var(--ochre);
}
.post-body p strong{
  font-weight: 600;
  color: var(--ink);
}
.post-body a{
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--ochre);
  padding-bottom: 1px;
  transition: color .2s, background .2s;
}
.post-body a:hover{
  color: var(--ochre);
  background: rgba(224,176,74,.08);
}

.post-list{
  margin: 0 0 28px;
  padding: 0 0 0 24px;
  list-style: none;
  counter-reset: postlist;
}
.post-list > li{
  position: relative;
  padding-left: 14px;
  margin: 0 0 18px;
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink);
  counter-increment: postlist;
}
.post-list > li::before{
  content: counter(postlist, decimal-leading-zero);
  position: absolute;
  left: -22px;
  top: 2px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  color: var(--ochre);
  font-variation-settings: "opsz" 144, "SOFT" 80;
}

/* -- Pull quote -- */
.post-pullquote{
  margin: 48px -40px;
  padding: 32px 40px 28px;
  border-left: 2px solid var(--ochre);
  background: rgba(224,176,74,.04);
}
.post-pullquote p{
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.4;
  color: var(--ink);
  margin: 0 0 12px;
  font-variation-settings: "opsz" 144, "SOFT" 80;
}
.post-pullquote cite{
  font-family: var(--mono);
  font-style: normal;
  font-size: 10.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ochre);
}
@media (max-width: 760px){
  .post-pullquote{ margin: 40px 0; }
}

/* -- Callout / takeaways -- */
.post-callout{
  margin: 56px 0;
  padding: 32px 32px 28px;
  background: rgba(244,236,214,.04);
  border: 1px solid rgba(244,236,214,.14);
  border-radius: 8px;
  position: relative;
}
.post-callout::before{
  content: "✶";
  position: absolute;
  top: 22px;
  right: 26px;
  color: var(--ochre);
  font-size: 14px;
  opacity: .7;
}
.post-callout h4{
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 400;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ochre);
  margin: 0 0 18px;
}
.post-callout ul{
  margin: 0;
  padding: 0 0 0 18px;
  list-style: none;
}
.post-callout ul li{
  position: relative;
  padding-left: 14px;
  margin: 0 0 12px;
  font-family: var(--sans);
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--ink);
}
.post-callout ul li::before{
  content: "—";
  position: absolute;
  left: -8px;
  color: var(--ochre);
  opacity: .8;
}
.post-callout ul li:last-child{ margin-bottom: 0; }

/* -- Author block -- */
.post-author{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 22px;
  align-items: flex-start;
  margin: 64px 0 0;
  padding: 32px 0 0;
  border-top: 1px solid rgba(244,236,214,.12);
}
.pa-mark{
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid var(--ochre);
  color: var(--ochre);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  background: rgba(224,176,74,.05);
}
.pa-by{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
  opacity: .8;
}
.pa-body h4{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 20px;
  color: var(--ink);
  margin: 4px 0 8px;
}
.pa-body p{
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-2);
  margin: 0;
}

/* -- The project link card under the article -- */
.post-project-link{
  max-width: 980px;
  margin: clamp(64px, 9vw, 110px) auto;
  padding: 0 var(--gutter);
}
.ppl-eyebrow{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin: 0 0 28px;
}
.ppl-eyebrow .line{
  display: inline-block;
  width: 50px;
  height: 1px;
  background: var(--ochre);
  opacity: .5;
}
.ppl-card{
  display: grid;
  grid-template-columns: minmax(0, 38%) 1fr;
  gap: 0;
  text-decoration: none;
  color: var(--ink);
  background: rgba(244,236,214,.03);
  border: 1px solid rgba(244,236,214,.12);
  transition: border-color .3s, transform .3s, background .3s;
  overflow: hidden;
}
.ppl-card:hover{
  border-color: var(--ochre);
  background: rgba(224,176,74,.05);
  transform: translateY(-3px);
}
.ppl-media{
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.ppl-media img{
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(.9);
  transition: transform .6s ease;
}
.ppl-card:hover .ppl-media img{ transform: scale(1.04); }
.ppl-body{
  padding: 32px 32px 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.ppl-tag{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 10px;
}
.ppl-body h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.18;
  margin: 0 0 10px;
}
.ppl-body p{
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-2);
  margin: 0 0 18px;
}
.ppl-go{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink);
  transition: gap .2s, color .2s;
}
.ppl-go svg{ width: 14px; height: 14px; }
.ppl-card:hover .ppl-go{ color: var(--ochre); gap: 12px; }
@media (max-width: 760px){
  .ppl-card{ grid-template-columns: 1fr; }
  .ppl-media{ aspect-ratio: 16 / 9; }
}

/* -- Related posts inside an article -- */
.post-related{
  max-width: 1080px;
  margin: clamp(64px, 9vw, 110px) auto 0;
  padding: 0 var(--gutter) clamp(40px, 6vw, 80px);
}
.post-related .section-head{ margin-bottom: 36px; }

/* -- Mobile tightening for the article -- */
@media (max-width: 720px){
  .post-body{ font-size: 16.5px; }
  .post-body h2{ margin-top: 44px; }
  .post-meta{
    flex-direction: column;
    align-items: flex-start;
  }
}


/* ============================================================
   HERO CTA — primary Contact us button (homepage hero)
   Same family as .nav-cta but larger and ochre-filled
   so it reads as the primary action on the page.
   ============================================================ */
.hero-cta{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
  padding: 14px 22px 14px 26px;
  border: 1px solid var(--ochre);
  border-radius: 999px;
  background: var(--ochre);
  color: var(--forest-deep, #1a2419);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .3s ease, color .3s ease, border-color .3s ease,
              transform .3s ease, box-shadow .3s ease;
  box-shadow: 0 14px 28px -16px rgba(224,176,74,.55);
}
.hero-cta svg{
  width: 16px;
  height: 16px;
  transition: transform .3s ease;
}
.hero-cta:hover{
  background: transparent;
  color: var(--ochre);
  border-color: var(--ochre);
  transform: translateY(-2px);
  box-shadow: 0 18px 36px -20px rgba(224,176,74,.6);
}
.hero-cta:hover svg{
  transform: translateX(4px);
}
.hero-cta:focus-visible{
  outline: 2px solid var(--ochre-soft, var(--ochre));
  outline-offset: 4px;
}


/* ============================================================
   MOBILE OPTIMISATION — navbar, hero title/subtext, stats
   Layered after all earlier @media rules to take precedence.
   ============================================================ */

/* ---------- NAVBAR (≤ 640px) ---------- */
@media (max-width: 640px){
  .nav{
    /* shrink the glass pill, tighten padding */
    grid-template-columns: auto 1fr auto;
    gap: 10px;
    padding: 8px 10px 8px 12px;
    font-size: 10px;
    letter-spacing: 0.10em;
    /* sit a touch closer to the edges */
    top: 12px;
    width: calc(100% - 24px);
  }

  /* tighten the brand mark */
  .nav-mark{ gap: 8px; }
  .mark-svg{ width: 28px; height: 28px; }
  .nav-logo{ height: 30px; transform: scale(1.35); margin-right: 10px; }
  /* hide the wordmark text on phones — the mark alone is enough */
  .nav-wordmark{ display: none; }

  /* nav-links already hidden by 900px rule — keep that */

  /* compact Contact us pill — same family, smaller */
  .nav-cta{
    gap: 6px;
    padding: 8px 12px 8px 14px;
    font-size: 9.5px;
    letter-spacing: 0.14em;
  }
  .nav-cta svg{ width: 12px; height: 12px; }
}

/* even tighter on very small phones */
@media (max-width: 380px){
  .nav{
    padding: 7px 8px 7px 10px;
    gap: 8px;
  }
  .mark-svg{ width: 26px; height: 26px; }
  .nav-logo{ height: 26px; transform: scale(1.3); margin-right: 8px; }
  .nav-cta{
    padding: 7px 10px 7px 12px;
    font-size: 9px;
    letter-spacing: 0.12em;
  }
}

/* ---------- HERO TITLE — bigger on mobile ---------- */
@media (max-width: 640px){
  .hero{
    padding-top: 100px;
    padding-bottom: 80px;
    text-align: center;
  }

  .hero-eyebrow{
    font-size: 9.5px;
    letter-spacing: 0.20em;
    gap: 10px;
  }
  .hero-eyebrow .line{ width: 36px; }

  .hero-title{
    /* push the title significantly larger than the 38px clamp floor */
    font-size: clamp(48px, 12vw, 62px);
    line-height: 0.96;
    letter-spacing: -0.025em;
    max-width: 14ch;
    margin: 8px auto 16px;
  }
}

/* ---------- HERO BODY (subtext) — smaller on mobile ---------- */
@media (max-width: 640px){
  .hero-body{
    max-width: 92%;
    font-size: 14.5px;
    line-height: 1.55;
    margin: 4px auto 0;
    opacity: .88;
  }
  .hero-body p{ margin-bottom: 20px; }
  .hero-body p em{ font-size: 1em; }

  /* CTA stays prominent but trimmed proportionally */
  .hero-cta{
    padding: 12px 18px 12px 22px;
    font-size: 10px;
    letter-spacing: .18em;
  }
  .hero-cta svg{ width: 14px; height: 14px; }
}

/* ---------- HERO STATS — centred single column on mobile ---------- */
@media (max-width: 700px){
  .hero-stats{
    grid-template-columns: 1fr;
    gap: 28px;
    margin-top: 56px;
    padding-top: 32px;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
    justify-items: center;
    text-align: center;
  }
  .hero-stats > div{
    align-items: center;
    text-align: center;
    width: 100%;
  }
  .hero-stats .num{
    font-size: clamp(42px, 11vw, 56px);
  }
  .hero-stats .lab{
    font-size: 10px;
    letter-spacing: .18em;
    max-width: 280px;
    margin: 0 auto;
  }
}

/* hide the scroll cue on phones — saves space and avoids overlap */
@media (max-width: 640px){
  .scroll-cue{ display: none; }
}


/* ============================================================
   MOBILE NAVBAR REWRITE
   - keep the wordmark visible
   - swap Contact CTA for a hamburger that opens a slide-down panel
   ============================================================ */

/* Burger button — hidden on desktop */
.nav-burger{
  display: none;
  background: transparent;
  border: 1px solid rgba(244,236,214,0.55);
  border-radius: 999px;
  width: 40px;
  height: 40px;
  padding: 0;
  cursor: pointer;
  color: var(--ink);
  align-items: center;
  justify-content: center;
  transition: background .25s, border-color .25s, color .25s;
  backdrop-filter: blur(6px);
}
.nav-burger:hover{ background: rgba(255,255,255,0.08); }
.burger-bars{
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  width: 16px;
}
.burger-bars span{
  display: block;
  height: 1.5px;
  width: 100%;
  background: currentColor;
  border-radius: 1px;
  transition: transform .3s ease, opacity .25s ease;
  transform-origin: center;
}
/* X state when the panel is open */
.nav-burger[aria-expanded="true"] .burger-bars span:nth-child(1){
  transform: translateY(5.5px) rotate(45deg);
}
.nav-burger[aria-expanded="true"] .burger-bars span:nth-child(2){
  opacity: 0;
}
.nav-burger[aria-expanded="true"] .burger-bars span:nth-child(3){
  transform: translateY(-5.5px) rotate(-45deg);
}

/* Mobile menu panel — hidden on desktop */
.mobile-menu{
  display: none;
}

@media (max-width: 900px){
  /* show burger, hide nav-cta on phones/tablets */
  .nav-burger{
    display: inline-flex;
    margin-left: auto;
    justify-self: end;
  }
  .nav-cta{ display: none; }
  /* nav-links is also hidden (existing rule) — collapse middle column so burger sits hard-right */
  .nav{
    grid-template-columns: auto 1fr auto;
  }
}

/* Restore the wordmark on phones (was hidden earlier) */
@media (max-width: 640px){
  .nav-wordmark{ display: flex; }
  .nav-word{ font-size: 13px; }
  .nav-sub{ font-size: 8.5px; }
  .mark-svg{ width: 28px; height: 28px; }
  .nav-logo{ height: 28px; transform: scale(1.35); margin-right: 10px; }

  /* slightly more padding to fit the wordmark cleanly */
  .nav{
    padding: 8px 10px 8px 14px;
    gap: 12px;
  }
}

/* On the tiniest screens, drop the sub-line to save room */
@media (max-width: 380px){
  .nav-sub{ display: none; }
  .nav-word{ font-size: 12px; }
}

/* ============================================================
   MOBILE MENU PANEL
   ============================================================ */
@media (max-width: 900px){
  .mobile-menu{
    display: block;
    position: fixed;
    top: 0; left: 0;
    width: 100%;
    height: 100vh;
    height: 100dvh;
    background:
      radial-gradient(120% 70% at 50% 0%, rgba(224,176,74,0.10), transparent 55%),
      rgba(20, 28, 20, 0.96);
    backdrop-filter: blur(20px) saturate(160%);
    -webkit-backdrop-filter: blur(20px) saturate(160%);
    z-index: 90;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-12px);
    transition: opacity .3s ease, transform .35s ease, visibility 0s linear .35s;
    overflow-y: auto;
  }
  .mobile-menu.is-open{
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    transition: opacity .3s ease, transform .35s ease, visibility 0s linear 0s;
  }
  .mobile-menu-inner{
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 110px 28px 40px;
  }

  .mm-links{
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  .mm-links > a{
    display: flex;
    align-items: baseline;
    gap: 14px;
    padding: 16px 0;
    font-family: var(--serif);
    font-weight: 350;
    font-size: clamp(28px, 6.4vw, 38px);
    line-height: 1.1;
    color: var(--ink);
    text-decoration: none;
    border-bottom: 1px solid rgba(244,236,214,0.10);
    font-variation-settings: "opsz" 144, "SOFT" 50;
    transition: color .25s ease, padding-left .25s ease;
  }
  .mm-links > a:hover,
  .mm-links > a:focus-visible{
    color: var(--ochre);
    padding-left: 6px;
  }
  .mm-no{
    font-family: var(--serif);
    font-style: italic;
    font-size: 14px;
    color: var(--ochre);
    opacity: .85;
    font-variation-settings: "opsz" 144, "SOFT" 90;
    min-width: 22px;
  }

  /* The Hub collapsible dropdown */
  .mm-group{
    border-bottom: 1px solid rgba(244,236,214,0.10);
  }
  .mm-group-trigger{
    display: flex;
    align-items: baseline;
    gap: 14px;
    width: 100%;
    padding: 16px 0;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--ink);
    font-family: var(--serif);
    font-weight: 350;
    font-size: clamp(28px, 6.4vw, 38px);
    line-height: 1.1;
    text-align: left;
    font-variation-settings: "opsz" 144, "SOFT" 50;
    transition: color .25s ease, padding-left .25s ease;
  }
  .mm-group-trigger:hover,
  .mm-group-trigger:focus-visible{
    color: var(--ochre);
    padding-left: 6px;
  }
  .mm-group-label{ flex: 1; }
  .mm-chevron{
    width: 18px;
    height: 18px;
    color: var(--ochre);
    opacity: .9;
    transition: transform .3s ease;
    flex-shrink: 0;
    align-self: center;
  }
  .mm-group-trigger[aria-expanded="true"] .mm-chevron{
    transform: rotate(180deg);
  }
  .mm-group-panel{
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transition: max-height .35s ease, opacity .25s ease, padding .25s ease;
    padding: 0 0 0 28px;
  }
  .mm-group-trigger[aria-expanded="true"] + .mm-group-panel{
    max-height: 320px;
    opacity: 1;
    padding: 4px 0 14px 28px;
  }
  .mm-group-panel a{
    display: flex;
    align-items: baseline;
    gap: 12px;
    padding: 10px 0;
    font-family: var(--sans);
    font-weight: 400;
    font-size: 15px;
    letter-spacing: .01em;
    color: var(--ink-2);
    text-decoration: none;
    transition: color .25s ease, padding-left .25s ease;
  }
  .mm-group-panel a:hover,
  .mm-group-panel a:focus-visible{
    color: var(--ochre);
    padding-left: 4px;
  }
  .mm-sub-no{
    font-family: var(--mono);
    font-size: 10px;
    color: var(--ochre);
    opacity: .7;
    min-width: 10px;
  }

  /* Contact pill — properly sized, not stretched */
  .mm-cta-wrap{
    display: flex;
    margin-top: 32px;
  }
  .mm-cta{
    display: inline-flex;
    align-items: center;
    gap: 10px;
    width: auto;
    max-width: max-content;
    padding: 11px 18px 11px 20px;
    border: 1px solid var(--ochre);
    border-radius: 999px;
    background: var(--ochre);
    color: var(--forest-deep, #1a2419);
    font-family: var(--mono);
    font-size: 10.5px;
    letter-spacing: .18em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background .25s, color .25s, transform .25s;
  }
  .mm-cta svg{ width: 14px; height: 14px; }
  .mm-cta:hover{
    background: transparent;
    color: var(--ochre);
  }

  /* X close button — top-right inside the panel */
  .mm-close{
    position: absolute;
    top: 18px;
    right: 18px;
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid rgba(244,236,214,0.35);
    border-radius: 999px;
    color: var(--ink);
    cursor: pointer;
    z-index: 2;
    transition: background .25s, border-color .25s, transform .25s;
  }
  .mm-close svg{ width: 18px; height: 18px; }
  .mm-close:hover{
    background: rgba(255,255,255,0.08);
    border-color: var(--ochre);
    color: var(--ochre);
    transform: rotate(90deg);
  }

  .mm-foot{
    padding-top: 32px;
    border-top: 1px solid rgba(244,236,214,0.10);
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--ink-2);
    opacity: .7;
  }

  /* Body lock when the panel is open */
  body.menu-open{
    overflow: hidden;
  }
}

/* ============================================================
   TESTIMONIALS CAROUSEL
   ============================================================ */
.testi-stage{
  position: relative;
  max-width: 920px;
  margin: 0 auto;
  padding: 0 60px;
}
.testi-track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 100%;
  gap: 24px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding: 8px 4px 24px;
}
.testi-track::-webkit-scrollbar{ display: none; }

.testi-track .testi{
  scroll-snap-align: center;
  width: 100%;
  margin: 0;
  padding: 44px 44px 40px;
  min-height: 320px;
}

/* Arrow buttons — mirror .pc-arrow but pinned to the stage edges */
.tc-arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(244,236,214,.25);
  background: rgba(36,50,35,.85);
  backdrop-filter: blur(6px);
  color: var(--ink);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: border-color .2s, color .2s, background .2s;
  z-index: 3;
}
.tc-arrow svg{ width: 16px; height: 16px; }
.tc-arrow:hover{
  border-color: var(--ochre);
  color: var(--ochre);
  background: rgba(36,50,35,.95);
}
.tc-prev{ left: 0; }
.tc-next{ right: 0; }

.testi-dots{
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 24px;
}
.tc-dot{
  width: 28px;
  height: 2px;
  border: none;
  padding: 0;
  background: rgba(244,236,214,.18);
  cursor: pointer;
  transition: background .25s;
}
.tc-dot.is-on{ background: var(--ochre); }

@media (max-width: 720px){
  .testi-stage{
    padding: 0;
  }
  .tc-arrow{
    /* tuck arrows just outside the card visually on mobile */
    width: 36px;
    height: 36px;
  }
  .tc-prev{ left: -4px; }
  .tc-next{ right: -4px; }
  .testi-track .testi{
    padding: 32px 52px 28px;
    min-height: 280px;
  }
}


/* ============ ABOUT PAGE (pillars.html) ============ */

/* ---- About hero ---- */
.about-hero{
  position: relative;
  padding: 180px var(--gutter) 90px;
  text-align: center;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(224,176,74,0.12), transparent 55%),
    radial-gradient(80% 60% at 50% 100%, rgba(102,68,38,0.06), transparent 60%),
    var(--paper);
  border-bottom: 1px solid rgba(63,45,30,.10);
}
.about-hero-eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 28px;
}
.about-hero-eyebrow .line{
  display: inline-block;
  width: 60px;
  height: 1px;
  background: var(--terra);
  opacity: .5;
}
.about-hero-title{
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(44px, 7.6vw, 110px);
  line-height: .98;
  letter-spacing: -0.025em;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
  margin: 0 auto 28px;
  max-width: 1100px;
}
.about-hero-title em{
  color: var(--ochre);
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 90;
}
.about-hero-dek{
  max-width: 720px;
  margin: 0 auto 32px;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.55;
  color: var(--ink-2);
  font-variation-settings: "opsz" 144, "SOFT" 80;
}
.about-hero-meta{
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 14px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
}

/* ---- About "Why we exist" section ---- */
.about-why{
  padding: 110px var(--gutter) 100px;
  background: var(--paper);
}
.about-prose{
  max-width: 760px;
  margin: 0 auto;
  font-family: var(--serif);
  font-weight: 350;
  font-size: 19px;
  line-height: 1.75;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
}
.about-prose .lead{
  font-size: clamp(22px, 2.3vw, 28px);
  line-height: 1.5;
  font-style: italic;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 80;
  margin: 0 0 36px;
}
.about-prose p{
  margin: 0 0 22px;
}
.about-prose p strong{
  font-weight: 500;
  color: var(--terra-deep);
}
.about-prose em{
  font-style: italic;
  color: var(--terra-deep);
}
.about-figure{
  margin: 40px 0 44px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid rgba(63,45,30,.10);
  background: var(--bone);
}
.about-figure img{
  display: block;
  width: 100%;
  height: clamp(280px, 42vw, 480px);
  object-fit: cover;
}
.about-figure figcaption{
  padding: 14px 18px;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-2);
  background: var(--bone);
  border-top: 1px solid rgba(63,45,30,.10);
}
.about-pullquote{
  max-width: 820px;
  margin: 60px auto 0;
  padding: 40px clamp(20px, 5vw, 56px);
  border-left: 3px solid var(--ochre);
  background: rgba(224,176,74,.06);
  border-radius: 0 4px 4px 0;
}
.about-pullquote p{
  margin: 0 0 14px;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 350;
  font-size: clamp(22px, 2.6vw, 32px);
  line-height: 1.35;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 90;
}
.about-pullquote cite{
  display: inline-block;
  font-family: var(--mono);
  font-style: normal;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
}

/* ---- Purpose · Mission · Vision ---- */
.about-pmv{
  padding: 100px var(--gutter);
  background: var(--bone);
  border-top: 1px solid rgba(63,45,30,.10);
  border-bottom: 1px solid rgba(63,45,30,.10);
}
.pmv-grid{
  margin-top: 60px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.pmv-card{
  background: var(--paper);
  border: 1px solid rgba(63,45,30,.12);
  border-radius: 4px;
  padding: 36px 32px 40px;
  position: relative;
  transition: transform .35s ease, box-shadow .35s ease;
}
.pmv-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 48px -28px rgba(63,45,30,.32);
}
.pmv-card::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 3px;
  background: var(--ochre);
}
.pmv-card:nth-child(2)::before{ background: var(--terra); }
.pmv-card:nth-child(3)::before{ background: var(--forest); }
.pmv-label{
  display: inline-block;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 18px;
}
.pmv-card p{
  margin: 0;
  font-family: var(--serif);
  font-weight: 350;
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
}

/* ---- Founders ---- */
.founders{
  padding: 110px var(--gutter) 100px;
  background: var(--paper);
}
/* Stage wraps the grid/track + mobile arrows */
.founders-stage{
  position: relative;
}
.founders-grid{
  margin-top: 60px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  justify-content: center;
  gap: 36px;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.founder-card{
  background: var(--bone);
  border: 1px solid rgba(63,45,30,.12);
  border-radius: 6px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .4s ease, box-shadow .4s ease;
}
.founder-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 60px -32px rgba(63,45,30,.32);
}
.founder-portrait{
  position: relative;
  overflow: hidden;
  background: var(--paper);
}
.founder-portrait img{
  display: block;
  width: 100%;
  height: clamp(240px, 26vw, 320px);
  object-fit: cover;
  filter: grayscale(.08) saturate(.95);
  transition: transform .8s ease, filter .6s ease;
}
.founder-card:hover .founder-portrait img{
  transform: scale(1.03);
  filter: grayscale(0) saturate(1);
}
.founder-body{
  padding: 22px clamp(20px, 2.4vw, 28px) 26px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.founder-eyebrow{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ochre);
}
.founder-name{
  margin: 0;
  font-family: var(--serif);
  font-weight: 350;
  font-size: clamp(22px, 2.2vw, 28px);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
}
.founder-role{
  margin: 0;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink-2);
}

/* Carousel controls — hidden on desktop, shown on mobile */
.fc-arrow,
.founders-dots{
  display: none;
}
.fc-arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 38px;
  height: 38px;
  border-radius: 0;
  border: none;
  background: transparent;
  color: var(--ink);
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: opacity .25s ease, color .25s ease;
}
.fc-arrow svg{ width: 22px; height: 22px; stroke-width: 1.25; }
.fc-arrow.fc-prev{ left: 6px; }
.fc-arrow.fc-next{ right: 6px; }
.fc-arrow:hover{ opacity: .65; }
.founders-dots{
  margin-top: 22px;
  justify-content: center;
  gap: 10px;
}
.fc-dot{
  width: 8px;
  height: 8px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(63,45,30,.25);
  cursor: pointer;
  transition: background .25s ease, transform .25s ease;
}
.fc-dot.is-on{
  background: var(--ochre);
  transform: scale(1.25);
}
.founders-note{
  margin: 50px auto 0;
  max-width: 620px;
  text-align: center;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.55;
  color: var(--ink-2);
  font-variation-settings: "opsz" 144, "SOFT" 80;
}

/* ---- Responsive: About page ---- */
@media (max-width: 960px){
  .pmv-grid{
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .founders-grid{
    gap: 24px;
    max-width: 620px;
  }
}
@media (max-width: 700px){
  .about-hero{ padding: 140px var(--gutter) 70px; }
  .about-why{ padding: 80px var(--gutter) 72px; }
  .about-pmv{ padding: 72px var(--gutter); }
  .founders{ padding: 80px var(--gutter) 72px; }
  .about-prose{ font-size: 17px; line-height: 1.7; }
  .about-pullquote{
    padding: 28px 22px;
    margin-top: 44px;
  }
  .about-pullquote p{
    font-size: clamp(20px, 5.4vw, 26px);
  }
  .founder-body{
    padding: 22px 22px 26px;
  }
  .founder-portrait img{
    height: clamp(260px, 60vw, 360px);
  }
  .about-hero-meta{
    font-size: 10px;
    letter-spacing: .18em;
  }
  /* ---- Founders: stacked vertical on mobile ---- */
  .founders-stage{
    margin-top: 44px;
  }
  .founders-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 28px;
    max-width: 420px;
    margin: 0 auto;
  }
  /* No carousel controls on mobile */
  .fc-arrow,
  .founders-dots{ display: none !important; }
}


/* ============================================================
   PLATFORM PAGE (platform.html)
   Editorial blog-style: hero → pitch → signal flow →
   components → audience pitch grid → contact CTA
   ============================================================ */

/* ---------- Platform hero ---------- */
.platform-hero{
  padding: 96px var(--gutter) 64px;
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  gap: 28px;
}
.platform-hero-eyebrow{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.platform-hero-eyebrow::before{
  content: "";
  width: 28px;
  height: 1px;
  background: var(--terra);
}
.platform-hero-title{
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "SOFT" 80;
  font-weight: 360;
  font-size: clamp(44px, 7.4vw, 96px);
  line-height: 1.02;
  letter-spacing: -0.022em;
  color: var(--ink);
  margin: 0;
  max-width: 14ch;
}
.platform-hero-title em{
  font-style: italic;
  color: var(--ochre);
  font-variation-settings: "opsz" 144, "SOFT" 90;
}
.platform-hero-dek{
  font-family: var(--serif);
  font-size: clamp(18px, 2.1vw, 22px);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 56ch;
  margin: 0;
  font-weight: 380;
}
.platform-hero-meta{
  display: flex;
  flex-wrap: wrap;
  gap: 14px 22px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-2);
  padding-top: 18px;
  border-top: 1px solid rgba(28,28,28,.12);
  margin-top: 6px;
}
.platform-hero-meta span:not(:last-child)::after{
  content: "·";
  margin-left: 22px;
  opacity: .5;
}


/* ---------- Platform pitch (reuses .about-prose, .about-figure, .about-pullquote) ---------- */
.platform-pitch{
  padding: 64px var(--gutter) 88px;
  max-width: 1240px;
  margin: 0 auto;
  border-top: 1px solid rgba(28,28,28,.10);
}

/* ---------- Signal flow ---------- */
.platform-signal{
  padding: 88px var(--gutter) 96px;
  max-width: 1240px;
  margin: 0 auto;
  background: linear-gradient(180deg, var(--bone) 0%, var(--paper) 100%);
  border-radius: 18px;
}
.signal-flow{
  list-style: none;
  margin: 36px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 22px;
  counter-reset: signalstep;
}
.signal-flow li{
  position: relative;
  padding: 26px 22px 28px;
  background: var(--paper);
  border: 1px solid rgba(28,28,28,.12);
  border-radius: 12px;
  display: grid;
  gap: 10px;
  align-content: start;
}
.signal-flow li::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 36px;
  height: 3px;
  background: var(--terra);
  border-radius: 12px 0 12px 0;
}
.signal-flow li:nth-child(2)::before{ background: var(--ochre); }
.signal-flow li:nth-child(3)::before{ background: var(--forest); }
.signal-flow li:nth-child(4)::before{ background: var(--terra-deep, var(--terra)); }
.signal-flow li:nth-child(5)::before{ background: var(--ink); }
.sf-no{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.signal-flow h3,
.signal-flow h4{
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "SOFT" 50;
  font-weight: 460;
  font-size: 21px;
  line-height: 1.2;
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.signal-flow p{
  font-family: var(--serif);
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0;
}


/* ---------- Audience pitch grid ---------- */
.platform-audience{
  padding: 96px var(--gutter) 80px;
  max-width: 1240px;
  margin: 0 auto;
}
.pitch-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
  margin-top: 36px;
}
.pitch-card{
  position: relative;
  padding: 34px 30px 32px;
  background: var(--paper);
  border: 1px solid rgba(28,28,28,.12);
  border-radius: 14px;
  display: grid;
  gap: 14px;
  transition: transform .35s ease, box-shadow .35s ease;
}
.pitch-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 36px -22px rgba(28,28,28,.22);
}
.pitch-card::before{
  content: "";
  position: absolute;
  top: 0;
  left: 30px;
  width: 44px;
  height: 3px;
  background: var(--ochre);
}
.pitch-card:nth-child(2)::before{ background: var(--terra); }
.pitch-card:nth-child(3)::before{ background: var(--forest); }
.pitch-card:nth-child(4)::before{ background: var(--ink); }
.pitch-no{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.pitch-card h3{
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "SOFT" 60;
  font-weight: 440;
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.2;
  color: var(--ink);
  margin: 0;
  letter-spacing: -0.012em;
}
.pitch-card > p{
  font-family: var(--serif);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-2);
  margin: 0;
}
.pitch-bullets{
  list-style: none;
  padding: 0;
  margin: 6px 0 0;
  display: grid;
  gap: 8px;
}
.pitch-bullets li{
  font-family: var(--sans, "Inter Tight", sans-serif);
  font-size: 14px;
  line-height: 1.5;
  color: var(--ink);
  padding-left: 18px;
  position: relative;
}
.pitch-bullets li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 8px;
  height: 1px;
  background: var(--terra);
}


/* ---------- Platform CTA (big contact section) ---------- */
.platform-cta{
  margin: 64px var(--gutter) 96px;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  background: linear-gradient(155deg, var(--umber) 0%, #2b1d12 60%, #1a1109 100%);
  color: var(--ink);
  border-radius: 20px;
  overflow: hidden;
  position: relative;
}
.platform-cta::before{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  background: radial-gradient(circle at 80% 20%, rgba(224,176,74,.18) 0%, transparent 60%);
  pointer-events: none;
}
.platform-cta-inner{
  position: relative;
  padding: 80px clamp(28px, 6vw, 80px) 72px;
  display: grid;
  gap: 22px;
  max-width: 980px;
}
.platform-cta-eyebrow{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(244,236,214,.7);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.platform-cta-eyebrow::before{
  content: "";
  width: 28px;
  height: 1px;
  background: var(--ochre);
}
.platform-cta-title{
  font-family: var(--serif);
  font-variation-settings: "opsz" 144, "SOFT" 80;
  font-weight: 360;
  font-size: clamp(34px, 5.8vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
  max-width: 16ch;
}
.platform-cta-title em{
  font-style: italic;
  color: var(--ochre);
  font-variation-settings: "opsz" 144, "SOFT" 90;
}
.platform-cta-dek{
  font-family: var(--serif);
  font-size: clamp(17px, 1.8vw, 20px);
  line-height: 1.6;
  color: rgba(244,236,214,.85);
  max-width: 58ch;
  margin: 0;
  font-weight: 380;
}
.platform-cta-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 14px;
}
.cta-btn{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 26px;
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-decoration: none;
  transition: transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.cta-btn svg{
  width: 18px;
  height: 18px;
  transition: transform .25s ease;
}
.cta-btn:hover svg{
  transform: translateX(4px);
}
.cta-btn-primary{
  background: var(--ochre);
  color: var(--umber);
  border: 1px solid var(--ochre);
}
.cta-btn-primary:hover{
  background: #ecc266;
  border-color: #ecc266;
}
.cta-btn-ghost{
  background: transparent;
  color: var(--ink);
  border: 1px solid rgba(244,236,214,.4);
}
.cta-btn-ghost:hover{
  background: rgba(244,236,214,.08);
  border-color: rgba(244,236,214,.7);
}
.platform-cta-meta{
  list-style: none;
  padding: 26px 0 0;
  margin: 22px 0 0;
  border-top: 1px solid rgba(244,236,214,.18);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.platform-cta-meta li{
  display: grid;
  gap: 6px;
}
.platform-cta-meta span{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(244,236,214,.55);
}
.platform-cta-meta strong{
  font-family: var(--serif);
  font-weight: 440;
  font-size: 16px;
  color: var(--ink);
  letter-spacing: -0.005em;
}


/* ---------- Platform page responsive ---------- */
@media (max-width: 960px){
  .platform-hero{ padding: 72px var(--gutter) 48px; }
  .signal-flow{
    grid-template-columns: repeat(2, 1fr);
  }
  .signal-flow li:nth-child(5){
    grid-column: 1 / -1;
  }
  .pitch-grid{
    grid-template-columns: 1fr;
  }
  .platform-cta-inner{
    padding: 64px clamp(24px, 6vw, 56px) 56px;
  }
  .platform-cta-meta{
    grid-template-columns: 1fr;
    gap: 18px;
  }
}
@media (max-width: 700px){
  .platform-hero{ padding: 60px var(--gutter) 40px; }
  .platform-signal{ padding: 64px var(--gutter) 72px; }
  .platform-audience{ padding: 72px var(--gutter) 64px; }
  .platform-pitch{ padding: 48px var(--gutter) 64px; }
  .signal-flow{
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .signal-flow li:nth-child(5){ grid-column: auto; }
  .signal-flow li{
    padding: 22px 20px 24px;
  }
  .pitch-card{
    padding: 28px 24px 28px;
  }
  .platform-cta{
    margin-left: 16px;
    margin-right: 16px;
    border-radius: 16px;
  }
  .platform-cta-inner{
    padding: 48px 24px 44px;
  }
  .platform-cta-actions{
    flex-direction: column;
    align-items: stretch;
  }
  .cta-btn{
    justify-content: center;
    padding: 16px 22px;
  }
  .platform-hero-meta{
    font-size: 10px;
    letter-spacing: .18em;
  }
}


/* ============ FOOTER LINKS + SOCIALS ============ */
.foot-links{
  display: grid;
  grid-template-columns: 1.2fr 2fr;
  gap: 56px;
  padding: 36px 0 32px;
  border-bottom: 1px solid rgba(244,236,214,.32);
  margin-bottom: 24px;
  align-items: start;
}
.foot-brand{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
}
.foot-socials{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin: 0;
  justify-content: flex-start;
}
.foot-socials a{
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(36,50,35,.15);
  border: 1px solid rgba(36,50,35,.28);
  color: var(--paper);
  transition: background .25s ease, border-color .25s ease, transform .25s ease, color .25s ease;
}
.foot-socials a:hover{
  background: var(--paper);
  border-color: var(--paper);
  color: var(--ochre);
  transform: translateY(-2px);
}
.foot-socials svg{
  width: 16px;
  height: 16px;
  fill: currentColor;
}
.foot-nav{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.foot-col{
  display: grid;
  gap: 12px;
  align-content: start;
}
.foot-col-title{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(36,50,35,.65);
  margin: 0 0 4px;
}
.foot-col a{
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 440;
  letter-spacing: 0;
  text-transform: none;
  color: var(--paper);
  text-decoration: none;
  transition: color .25s ease, transform .25s ease;
  display: inline-block;
}
.foot-col a:hover{
  color: var(--ink);
  transform: translateX(3px);
}
@media (max-width: 900px){
  .foot-row{
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    row-gap: 14px;
  }
  .foot-row .foot-tag,
  .foot-tag{
    flex-basis: 100%;
    margin-left: 0;
    text-align: left;
    white-space: normal;
  }
  .foot-links{
    grid-template-columns: 1fr;
    gap: 36px;
  }
}
@media (max-width: 640px){
  .foot-nav{
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
}
@media (max-width: 420px){
  .foot-nav{
    grid-template-columns: 1fr;
    gap: 18px;
  }
}
