/* ============================================================
   main.css — page layout + homepage section styles.
   Import order matters: tokens -> base -> components -> main.
   (index.html links them in this order.)
   ============================================================ */

/* ---- Scroll-reveal ------------------------------------- */
[data-reveal] { opacity: 0; transform: translateY(24px); transition: opacity 600ms var(--ease), transform 600ms var(--ease); }
[data-reveal].is-visible { opacity: 1; transform: none; }

/* ---- HERO ----------------------------------------------- */
.hero { background: var(--c-blue); position: relative; overflow: hidden; isolation: isolate; }
/* Lime abstract pattern layer — full composition mapped across the whole panel
   (stretched to show all squiggles at their designed edge positions). */
.hero__bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  /* Lime squiggle artwork extracted from the comp, framed to the blue panel so the
     curls land at the panel's left/right edges (stretch-to-fit keeps edges anchored). */
  background: url("../patterns/PNG/home-hero-squiggle.png") center top / 100% 100% no-repeat;
}
.hero__inner {
  position: relative; z-index: 1; max-width: 1500px;   /* wider than default so copy + a wide photo both fit */
  display: grid; grid-template-columns: 1fr 0.86fr; gap: var(--space-lg);  /* photo narrower again per review */
  align-items: end;                          /* image bottom aligns to hero bottom */
  padding-top: clamp(2.5rem, 5vw, 4.5rem); padding-bottom: 0;  /* image sits flush to the marquee */
}
.hero__copy { align-self: center; padding-bottom: clamp(2.5rem, 6vw, 4.5rem); }
/* Scales toward the 72px design spec on wide screens; scales down on smaller so the forced
   3-line wrap never overflows into a 4th line. */
.hero__title { font-size: clamp(2.1rem, 3.7vw, 3.6rem); line-height: 1.04; color: var(--c-olive); }
.hero__lead { font-size: var(--fs-300); max-width: 44ch; margin-top: var(--space-md); color: var(--c-olive); }
.hero__lead strong { display: block; font-size: var(--fs-400); margin-bottom: .25em; white-space: nowrap; }
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin-top: var(--space-lg); }
/* CTA scales like the rest of the hero: 17px at the ~1900 design width, smaller here so it
   stays proportional (and no wider than the bold lead line above it). */
.hero__actions .btn { font-size: clamp(0.8125rem, 0.9vw, 1.0625rem); } /* padding inherited from base .btn */
/* Arch-clipped photo (rounded dome top, straight sides/bottom) — mirrors the brand arch logo.
   Taller frame, bottom-flush so it connects to the marquee bar below. */
.hero__media {
  position: relative; align-self: end; overflow: hidden;
  height: clamp(440px, 47vw, 640px);
  border-radius: 50% 50% 0 0 / 40% 40% 0 0;
}
.hero__media img { width: 100%; height: 100%; object-fit: cover; object-position: center 28%; transform: translateY(26px) scale(1.12); }
@media (max-width: 860px) {
  .hero__inner { grid-template-columns: 1fr; gap: var(--space-lg); padding-bottom: 0; }
  .hero__copy { padding-bottom: 0; }
  .hero__lead strong { white-space: normal; }   /* allow the bold line to wrap on small screens */
  .hero__media { height: clamp(360px, 70vw, 480px); border-radius: 42% 42% 0 0 / 18% 18% 0 0; }
}

/* ---- Intro / "Since 2014" band -------------------------- */
.intro-band { text-align: center; padding-block: clamp(5rem, 3.5rem + 6vw, 9.5rem); position: relative; overflow: hidden; } /* taller than default section */
/* Subtle topographic pattern behind the section (lighter olive on the olive bg) */
.intro-band::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: 0.5;
  background: url("../logos/SVG/background-pattern-header-green-abstract-2.svg") center center / cover no-repeat;
}
.intro-band .container { display: grid; gap: var(--space-md); justify-items: center; position: relative; z-index: 1; }
.intro-band__title { font-size: var(--fs-700); line-height: 1.08; }
.intro-band__sub { max-width: 52ch; color: var(--color-on-dark); font-size: var(--fs-400); }
.intro-band__sub strong { font-weight: var(--fw-bold); }
.callout-pill {
  display: inline-block; background: var(--c-cream-warm); color: var(--c-olive);
  border-radius: var(--radius-lg); padding: var(--space-md) var(--space-lg);
  font-size: var(--fs-400); max-width: 60ch; box-shadow: var(--shadow-sm);
}
/* Full-width blue callout (hero blue), sits beneath both columns */
.callout-pill--blue {
  display: block; max-width: none; background: var(--c-blue); box-shadow: none;
  padding: clamp(1.75rem, 1rem + 3vw, 3.25rem) clamp(1.75rem, 1rem + 3vw, 3.5rem);
  font-size: clamp(1.35rem, 1rem + 1.5vw, 2.15rem); line-height: 1.35;
}
.callout-pill--blue strong { font-weight: var(--fw-bold); }

/* ---- Two-column "doubt" section ------------------------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-xl); align-items: start; }
@media (max-width: 800px) { .split { grid-template-columns: 1fr; gap: var(--space-lg); } }
.doubt .callout-pill { margin-top: var(--space-3xl); }

/* ---- "Safe Place" orange section ------------------------ */
.feature-orange { position: relative; overflow: hidden; }
/* Faint blue-gray squiggle pattern behind the orange (same family as hero/intro patterns) */
.feature-orange__pattern {
  position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: 1;
  /* Blue-gray squiggle waves extracted from the comp, framed to the section
     (waves sit across the top + a curl bottom-left). */
  background: url("../patterns/PNG/home-orange-squiggle.png") center top / 100% 100% no-repeat;
}
.feature-orange .container { position: relative; z-index: 1; }
/* Image card with the heading overlaid on top-left. The rounded corners AND the
   bottom-center dome cut are baked into the transparent .webp, so the card is just a
   transparent holder — the orange band shows through the cut. Natural aspect ratio
   (no object-fit/fixed height) keeps the baked dome undistorted at every width. */
.feature-orange__card {
  position: relative; max-width: 1240px; margin-inline: auto;
}
.feature-orange__img { display: block; width: 100%; height: auto; }
.feature-orange__heading {
  position: absolute; z-index: 2; margin: 0;
  top: clamp(1.5rem, 1rem + 2.4vw, 3rem); left: clamp(1.5rem, 1rem + 2.4vw, 3rem);
  max-width: 13ch; color: var(--c-white);
  font-size: clamp(1.9rem, 1rem + 2.7vw, 3.5rem); line-height: 1.05;
  text-shadow: 0 1px 16px rgba(0, 0, 0, 0.22);
}
/* Centered intro paragraph beneath the image */
.feature-orange__intro {
  max-width: 70ch; margin: clamp(1.75rem, 1rem + 2.5vw, 3rem) auto 0;
  text-align: center; color: var(--c-white);
  font-size: 1rem; line-height: 1.7;
}
.feature-orange__intro strong { font-weight: var(--fw-semibold); }
.feature-orange__intro em { font-style: italic; }

/* ---- "We don't pretend" blue follow-up band ------------- */
.feature-followup { background: var(--c-blue); position: relative; overflow: hidden; }
/* Orange squiggle ribbons seated in the corners over the blue */
.feature-followup__pattern {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  /* Orange brush squiggles extracted from the comp, framed to the blue band
     (curl top-left, ribbon bottom-right). */
  background: url("../patterns/PNG/home-followup-squiggle.png") center center / 100% 100% no-repeat;
}
.feature-followup .container { position: relative; z-index: 1; }
.feature-followup__statement {
  max-width: 41ch; margin-inline: auto; text-align: center;
  font-family: var(--font-display); color: var(--c-white);
  font-size: clamp(1.35rem, 1rem + 1.6vw, 2.3rem); line-height: 1.22;
}
@media (max-width: 640px) {
  .feature-orange__heading { max-width: 11ch; }
}

/* ---- How We Come Alongside You — section head ----------- */
/* No max-width on the head so the title sits on ONE line (wraps only on narrow mobile). */
.alongside__head { margin-bottom: var(--space-xl); }
.alongside__title { font-size: var(--fs-600); text-wrap: nowrap; }
/* Subtitle: line breaks are pinned with <br> in the markup (matches the comp wrap). */
.alongside__sub {
  margin-inline: auto; margin-top: var(--space-md);
  color: var(--c-olive); font-size: var(--fs-450); line-height: 1.3;
}
@media (max-width: 600px) { .alongside__title { text-wrap: balance; } }
/* "View All Services" button uses the shared .btn--sm modifier (small caps pill). */

/* ---- Stat band ------------------------------------------ */
/* Extra vertical breathing room to match the comp's generous band padding. */
.stat-band { position: relative; overflow: hidden; padding-block: clamp(4.5rem, 3rem + 6vw, 8rem); }
/* Lime corner blobs extracted from the comp (top-left + bottom-right), framed to the band. */
.stat-band__pattern {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: url(../patterns/PNG/home-stat-blobs.png) center / 100% 100% no-repeat;
}
.stat-band > .container { position: relative; z-index: 1; }
.stat-band__head { text-align: center; margin-inline: auto; margin-bottom: var(--space-2xl); }
/* Title wraps to two lines (pinned with <br>); highlight bar behind "experience to guide you." */
.stat-band__title { font-size: var(--fs-600); }
/* ---- Meet the Ambassadors (two-column intro on white) --- */
.meet-band__cols {
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem);
  max-width: 920px; margin-inline: auto;
  font-size: var(--fs-200); line-height: 1.65;
}
@media (max-width: 760px) { .meet-band__cols { grid-template-columns: 1fr; gap: var(--space-md); } }

/* ---- "Join the Movement" steps -------------------------- */
.movement-band { position: relative; overflow: hidden; }
/* Cream brushstroke texture (raster from the comp) covering the whole band. */
.movement-band__pattern {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: url(../patterns/PNG/home-movement-bg.png) center / cover no-repeat;
}
.movement-band > .container { position: relative; z-index: 1; }
.movement { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: var(--space-xl); align-items: center; }
.movement__title { font-size: var(--fs-700); text-transform: uppercase; line-height: 1.04; }
/* Bands behind "Join" / "Movement" use the shared .hl-mark--lime-soft (same as the stat-band title). */
@media (max-width: 800px) { .movement { grid-template-columns: 1fr; gap: var(--space-lg); align-items: start; } }

/* ---- Assessment band ------------------------------------ */
.assess-band { position: relative; overflow: hidden; }
/* Colorful angular blobs extracted from the comp (slate/brown top-left, lime bottom-right). */
.assess-band__pattern {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: url(../patterns/PNG/home-assess-blobs.png) center / 100% 100% no-repeat;
}
.assess-band > .container { position: relative; z-index: 1; }
.assess { display: grid; grid-template-columns: 1fr 0.92fr; gap: var(--space-xl); align-items: center; }
.assess__lead { max-width: 42ch; margin-top: var(--space-md); }
/* Arch clip: rounded dome top, straight sides + flat bottom (same motif as the hero photo). */
.assess__media { border-radius: 50% 50% 0 0 / 40% 40% 0 0; overflow: hidden; aspect-ratio: 4/4.4; }
.assess__media img { width: 100%; height: 100%; object-fit: cover; object-position: center 28%; }
@media (max-width: 800px) {
  .assess { grid-template-columns: 1fr; }
  .assess__media { order: -1; aspect-ratio: 4/3.4; max-width: 420px; margin-inline: auto; }
}

/* ---- Testimonials ("What Leaders Are Saying") ----------- */
/* The lime quote-mark SVG sits centered behind the text as a frame; its
   clusters flank far-left/far-right, the rotating quote lives in the gap. */
.testimonials__frame {
  position: relative;
  max-width: 960px;
  margin-inline: auto;
  display: grid;
  place-items: center;
  padding-block: var(--space-lg);
  background: url(../patterns/SVG/quote-style.svg) center / contain no-repeat;
}
/* Static fallback: a lone testimonial (no JS rotation, e.g. About page) stays visible;
   also a graceful no-JS fallback for the rotating homepage set (slide 0 shows). */
.testimonial.is-active { opacity: 1; visibility: visible; }
.testimonial {
  grid-area: 1 / 1;            /* stack all slides in one cell for cross-fade */
  max-width: 42rem;            /* wider lines, still clear of the flanking quote clusters */
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2.5rem);
  text-align: center;
  opacity: 0;                  /* fade is driven by JS (Web Animations API) */
  will-change: opacity, transform;
}
.testimonial__text { font-family: var(--font-body); font-size: var(--fs-425); color: var(--c-ink); line-height: 1.55; }
.testimonial__cite {
  display: block;
  margin-top: var(--space-md);
  font-style: normal;
  font-weight: var(--fw-bold);
  font-size: var(--fs-75);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-olive);
}

/* ---- Newsletter ----------------------------------------- */
.newsletter { background: var(--c-blue-pale); }
.newsletter__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
/* SVG wordmark replaces the rendered heading; alt text keeps it an accessible <h2>. */
.newsletter__title { margin: 0; line-height: 0; }
.newsletter__title img { width: min(100%, 560px); height: auto; }
/* max-width in ch fixes the line wrap (line 1 ends "…practical answers", line 2 begins "to real…"). */
.newsletter__body { margin-top: var(--space-md); max-width: 46ch; color: var(--c-ink); font-size: var(--fs-425); line-height: 1.55; }
.newsletter__body--strong { font-weight: var(--fw-bold); }
/* Right column — large lead with a bold emphasis clause, then the stacked form. */
.newsletter__lead { font-size: var(--fs-450); font-weight: var(--fw-regular); line-height: 1.3; color: var(--c-olive); max-width: 21ch; }
.newsletter__lead strong { font-weight: var(--fw-bold); }
.newsletter__form { margin-top: var(--space-lg); gap: var(--space-lg); max-width: 36rem; }
.newsletter__form input {
  border: none;
  background: var(--c-white);
  border-radius: 0;                 /* square fields (per comp) */
  padding: 1.4em 1.4em;
  font-size: var(--fs-300);
  color: var(--c-ink);
}
.newsletter__form input::placeholder { text-transform: uppercase; letter-spacing: 0.12em; color: rgba(54, 68, 31, 0.5); }
/* Larger, more confident join button (overrides the small-pill .btn--sm size for this form). */
.newsletter__form .btn { justify-self: start; margin-top: var(--space-md); font-size: var(--fs-200); padding: 1.4em 2.6em; letter-spacing: 0.14em; }
@media (max-width: 800px) { .newsletter__inner { grid-template-columns: 1fr; gap: var(--space-xl); } }

/* ---- CTA banner ----------------------------------------- */
/* Photo fills the section; an orange panel with a rounded top slots in at the
   bottom so the (duotone-tinted) image floats behind it. */
.cta-banner { position: relative; overflow: hidden; color: var(--c-white); }
/* Grayscale the photo so the orange multiply tint reads as an EVEN orange duotone — over a
   colour photo, multiply turns cool (blue-sky) regions muddy green instead of orange. */
.cta-banner__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 38%; filter: saturate(0) brightness(1.08) contrast(1.02); z-index: 0; }
.cta-banner__tint { position: absolute; inset: 0; z-index: 1; background: var(--c-orange); mix-blend-mode: multiply; opacity: 0.85; pointer-events: none; }
.cta-banner__panel {
  position: relative;
  z-index: 2;
  margin-top: clamp(380px, 47vw, 580px);
  background: var(--c-orange);
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  padding-block: clamp(2rem, 4vw, 3.25rem);
}
.cta-banner__title { color: var(--c-white); font-size: var(--fs-700); max-width: 38ch; text-wrap: pretty; }
.cta-banner__row {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: var(--space-lg); margin-top: var(--space-md);
}
.cta-banner__sub { color: rgba(255, 255, 255, 0.92); white-space: nowrap; }
.cta-banner__row .btn { flex: none; }
@media (max-width: 900px) {
  .cta-banner__row { flex-direction: column; align-items: flex-start; }
  .cta-banner__sub { white-space: normal; }
}

/* ---- Contact form (Contact page, Section 2) ------------- */
/* Olive band with the orange squiggle layered behind (background-pattern recipe:
   absolute __pattern at z0, .container at z1). Form is a 2-col grid: left = stacked
   short fields + "*Required" note; right = tall message + submit. Stacks ≤640px. */
.contact-section { position: relative; overflow: hidden; }
.contact-section__pattern {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: url(../patterns/SVG/squiggle-bg-orange.svg) center / cover no-repeat;
}
.contact-section > .container { position: relative; z-index: 1; }
.contact-form {
  display: grid; grid-template-columns: 1fr 1fr;
  column-gap: clamp(2rem, 5vw, 4rem); row-gap: var(--space-md); align-items: start;
}
.contact-form__fields { grid-column: 1; display: flex; flex-direction: column; gap: var(--space-sm); }
.contact-form__message { grid-column: 2; grid-row: 1; }
.contact-form__note { grid-column: 1; align-self: center; margin: 0; font-size: var(--fs-100); color: var(--c-cream); }
.contact-form__actions { grid-column: 2; display: flex; justify-content: flex-end; align-items: center; }
/* Borderless white fields — same treatment as .newsletter__form (uppercase placeholder). */
.contact-form .field input, .contact-form .field textarea {
  border: none; background: var(--c-white); border-radius: 0;   /* square fields — match comp + adjacent newsletter inputs */
  padding: 1.15em 1.25em; font-size: var(--fs-200); color: var(--c-ink);
}
.contact-form .field input::placeholder, .contact-form .field textarea::placeholder {
  text-transform: uppercase; letter-spacing: 0.12em; color: rgba(54, 68, 31, 0.5);
}
@media (max-width: 640px) {
  .contact-form { grid-template-columns: 1fr; }
  .contact-form__fields, .contact-form__message, .contact-form__note, .contact-form__actions { grid-column: 1; }
  .contact-form__message { grid-row: auto; }
  .contact-form__actions { justify-content: flex-start; }
}

/* ---- Footer styles -------------------------------------- */
.site-footer { padding-block: clamp(2.5rem, 5vw, 4rem); }
.site-footer__inner { display: flex; align-items: center; gap: clamp(1.75rem, 5vw, 5rem); }
.site-footer__logo { height: clamp(54px, 5vw, 72px); width: auto; }
/* Nav: same item set + text size as the header's primary nav, recoloured for the dark panel. */
/* Two columns (fills top→bottom, then wraps): 9 links → 5 + 4, keeps the footer short. */
.site-footer__nav ul { list-style: none; display: grid; grid-auto-flow: column; grid-template-rows: repeat(5, auto); gap: 0.55em clamp(1.5rem, 4vw, 3rem); }
.site-footer__nav a {
  font-family: var(--font-body); font-weight: var(--fw-light); font-size: var(--fs-150);
  letter-spacing: 0.05em; line-height: 1.15; color: var(--c-cream);
  display: inline-flex; align-items: center; gap: 0.4em;
}
.site-footer__nav a:hover { color: var(--c-lime); }
.site-footer__actions { margin-left: auto; display: flex; align-items: center; gap: var(--space-lg); }
/* Header hides .social-icons into the mobile drawer; keep them visible in the footer. */
.site-footer .social-icons { display: flex; }
@media (max-width: 760px) {
  .site-footer__inner { flex-direction: column; align-items: flex-start; gap: var(--space-lg); }
  .site-footer__actions { margin-left: 0; }
}

/* ============================================================
   ABOUT PAGE  (/about)
   Page-specific section styles. Reuses .page-hero, .split, .testimonials,
   .newsletter, .cta-banner. NEW components documented in design-system.md.
   ============================================================ */

/* 1. Hero — the orange highlight is a near-full-coverage BLOCK behind line 2
   (comp measured: orange ≈ 1.6× cap height, covers cap-top through descenders),
   fuller than the site-wide inner-page hero bar. Rotating keyword fades on swap. */
.page-hero--about { min-height: clamp(460px, 56vw, 760px); }
/* Group photo's heads sit high in the frame — bias the crop toward the top so they aren't cut off. */
.page-hero--about .page-hero__bg { object-position: 50% 24%; }
.page-hero--about .page-hero__title .hl-mark { --hl-height: 0.92em; --hl-pos: 90%; }
.page-hero--about [data-hero-rotate] { transition: opacity 0.28s ease; }

/* 2. Video band — centered title + responsive 16:9 placeholder player (real embed dropped in later). */
.video-band { text-align: center; }
.video-band__title { font-size: var(--fs-700); color: var(--c-olive); }
.video-band__frame {
  position: relative; max-width: 880px; margin: var(--space-lg) auto 0;
  aspect-ratio: 16 / 9; border-radius: var(--radius-md); overflow: hidden; background: var(--c-ink);
}
.video-band__frame iframe, .video-band__frame video, .video-band__frame img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; border: 0;
}
.video-band__play {
  position: absolute; inset: 0; margin: auto; width: 84px; height: 84px; border: 0; cursor: pointer;
  border-radius: var(--radius-pill); background: rgba(255, 255, 255, 0.82);
}
.video-band__play::after {
  content: ""; position: absolute; inset: 0; margin: auto; width: 0; height: 0;
  border-style: solid; border-width: 16px 0 16px 26px; border-color: transparent transparent transparent var(--c-ink);
  transform: translateX(3px);
}
.video-band__play:hover { background: var(--c-white); }

/* 3. Mission statement over photo — slate/blue duotone (NOT olive). Sibling of .feature-followup
   (same statement-band idea on a flat blue panel); here the panel is a tinted photo. */
.mission-band { position: relative; overflow: hidden; text-align: center; color: var(--c-white); padding-block: clamp(5rem, 8vw, 9rem); }
/* Even, LIGHT --c-blue (#A8B8C7) wash (NOT the multiply duotone used elsewhere — multiply darkens the
   photo's shadows; here we want a flat lightened blue tint). Heavily desaturate + brighten the photo,
   then a translucent --c-blue overlay (normal blend) so the whole scene reads uniform blue-gray and the
   olive lead stays legible over the lower photo. */
.mission-band__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; z-index: 0; filter: saturate(0.28) brightness(1.1); }
.mission-band__tint { position: absolute; inset: 0; z-index: 1; background: var(--c-blue); opacity: 0.74; pointer-events: none; }
.mission-band > .container { position: relative; z-index: 2; }
/* Label sized up to ~match the width of the statement's first line (per comp). */
.mission-band__label { font-family: var(--font-display); font-size: var(--fs-700); color: var(--c-olive); line-height: var(--lh-snug); }
.mission-band__statement {
  font-family: var(--font-accent); text-transform: uppercase; font-size: var(--fs-700);
  color: var(--c-white); line-height: var(--lh-snug); max-width: min(100%, 1080px); margin: var(--space-md) auto 0;
}
.mission-band__statement .hl-mark { --hl-height: 0.88em; --hl-pos: 88%; }
.mission-band__lead { font-size: var(--fs-425); }
.mission-band__lead { max-width: 56ch; margin: var(--space-lg) auto 0; color: var(--c-olive); }

/* 4. Values bar — orange full-bleed row of icon columns. ICONS are pending client assets:
   .values-bar__icon is a labeled placeholder slot until the 5 line-icons arrive. */
.values-bar { background: var(--c-orange); color: var(--c-cream); }
.values-bar__grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: clamp(1.5rem, 3.5vw, 3rem); align-items: start; text-align: center; }
.values-bar__item { display: flex; flex-direction: column; align-items: center; }
/* Icons have different intrinsic aspect ratios (heart 1.13 · book 0.75 · head 0.90 · bible 1.56 ·
   hands 1.07). Normalize by HEIGHT (width:auto) so they read at one consistent scale — a square box
   with object-fit:contain would shrink the wide icons (bible) and break the visual rhythm. */
.values-bar__icon { height: clamp(64px, 6.4vw, 92px); display: flex; align-items: center; justify-content: center; margin-bottom: clamp(1.5rem, 2.8vw, 2.25rem); }
.values-bar__icon img, .values-bar__icon svg { height: 100%; width: auto; max-width: 100%; }
/* Title = Hello Imperfect (hand-drawn accent); sub = Inter caps, tighter to its title than to the icon. */
.values-bar .values-bar__title { font-family: var(--font-accent); text-transform: uppercase; font-size: var(--fs-450); line-height: var(--lh-snug); color: var(--c-cream); margin: 0; }
.values-bar__sub { font-family: var(--font-body); font-size: var(--fs-425); text-transform: uppercase; letter-spacing: 0.03em; color: rgba(250, 243, 233, 0.92); line-height: var(--lh-snug); margin-top: var(--space-2xs); }
@media (max-width: 900px) { .values-bar__grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-xl) var(--space-lg); } }
@media (max-width: 560px) { .values-bar__grid { grid-template-columns: 1fr; } }

/* 5–7. Belief rows — alternating text+image (ADAPT of .split): rounded media vertically
   centered to the text. Soft pale-lime marker (--lime-soft) behind the key word, fuller than the
   site default bar. .belief-row--media-left reverses columns. */
.belief-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: center; }
.belief-row + .belief-row { margin-top: clamp(4.5rem, 8vw, 8rem); }   /* generous space between rows */
.belief-row__media { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 3 / 2; }
.belief-row__media img { width: 100%; height: 100%; object-fit: cover; }
.belief-row__title { font-size: var(--fs-700); color: var(--c-olive); line-height: var(--lh-snug); }
.belief-row__title .hl-mark { --hl-height: 0.5em; --hl-pos: 82%; }
.belief-row__body { margin-top: var(--space-md); max-width: 58ch; color: var(--c-ink); font-size: var(--fs-400); line-height: 1.6; }
.belief-row--media-left .belief-row__media { order: -1; }
@media (max-width: 800px) {
  .belief-row { grid-template-columns: 1fr; gap: var(--space-md); }
  .belief-row__media { order: -1; }                 /* photo above text when stacked */
  .belief-row__body { max-width: none; }
}

/* 9. Nation map — centered caps title + centered US map graphic (map is a PENDING client asset:
   .nation-band__map renders a placeholder box until the artwork is dropped in). */
.nation-band { text-align: center; }
.nation-band__title { font-family: var(--font-display); text-transform: uppercase; font-size: var(--fs-700); color: var(--c-olive); line-height: var(--lh-snug); }
.nation-band__map { max-width: 1000px; margin: var(--space-xl) auto 0; }
.nation-band__map img { width: 100%; height: auto; }
.nation-band__map--placeholder {
  aspect-ratio: 16 / 10; display: grid; place-items: center; border-radius: var(--radius-md);
  border: 2px dashed var(--c-blue-deep); color: var(--c-blue-deep);
  font-size: var(--fs-100); text-transform: uppercase; letter-spacing: 0.12em;
}

/* 10. Arch cards — two arch-topped solid-color cards (dome top via percentage radius, like
   .assess__media), centered heading + body + a pill button. */
.arch-cards { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: stretch; }
.arch-card {
  position: relative;
  border-radius: 50% 50% var(--radius-lg) var(--radius-lg) / 46% 46% 0 0;
  min-height: clamp(460px, 44vw, 580px);
  padding: clamp(3.25rem, 6vw, 5rem) clamp(1.75rem, 3vw, 2.75rem) clamp(3rem, 5vw, 4rem);
  text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--space-md);
}
.arch-card--blue { background: var(--c-blue); }
.arch-card--lime { background: var(--c-lime-acid); }
.arch-card__title { font-family: var(--font-display); font-size: var(--fs-600); color: var(--c-olive); line-height: var(--lh-snug); }
.arch-card__body { color: var(--c-ink); max-width: 34ch; font-size: var(--fs-425); line-height: 1.55; }
/* Button STRADDLES the card's bottom edge (same idiom as .related-card__btn): centered, half-overhang.
   Slightly more padding than the default --sm pill; keep the transform on hover so it doesn't unseat. */
.arch-card .btn { position: absolute; left: 50%; bottom: 0; transform: translate(-50%, 50%); margin-top: auto; font-size: var(--fs-300); padding: 1.15em 2.6em; letter-spacing: 0.08em; white-space: nowrap; }
.arch-card .btn:hover, .arch-card .btn:active { transform: translate(-50%, 50%); }
/* Pull the arch-cards band up toward the map (tighten the inter-section gap). */
.nation-band { padding-bottom: var(--space-md); }
.about-arches { padding-top: var(--space-lg); }
/* Stack earlier (≤840px): the enlarged one-line buttons crowd the cards in a narrow 2-col. */
@media (max-width: 840px) { .arch-cards { grid-template-columns: 1fr; gap: clamp(2.5rem, 8vw, 3.5rem); max-width: 520px; margin-inline: auto; } }

/* 11. Invitation statement — centered caps statement in the hand-drawn Hello Imperfect font
   (--font-accent), accent phrases in orange (.hl-orange). ~4 lines like the comp. */
.invite-band { text-align: center; }
.invite-band__statement {
  font-family: var(--font-accent); text-transform: uppercase; font-size: var(--fs-600);
  color: var(--c-olive); line-height: var(--lh-snug); max-width: 46ch; margin-inline: auto;
}

/* 12. Audience circles — 3 soft-tinted discs with centered labels (watercolor texture pending). */
.audience-circles { display: flex; justify-content: center; flex-wrap: wrap; gap: clamp(1.5rem, 4vw, 3.5rem); margin-top: var(--space-2xl); }
.audience-circle {
  width: clamp(180px, 22vw, 235px); aspect-ratio: 1; border-radius: var(--radius-pill);
  display: grid; place-items: center; text-align: center; padding: var(--space-md);
}
.audience-circle p { font-weight: var(--fw-bold); color: var(--c-ink); font-size: var(--fs-400); line-height: var(--lh-snug); margin: 0; }
/* Watercolor texture discs extracted from the comp (.ai clip groups) — already circular with
   transparent corners, so cover fills the round element. Tint token kept as a fallback behind. */
.audience-circle--1 { background: var(--c-tint-peach)  url("../patterns/PNG/about-circle-1.png") center / cover no-repeat; }
.audience-circle--2 { background: var(--c-tint-lime)   url("../patterns/PNG/about-circle-2.png") center / cover no-repeat; }
.audience-circle--3 { background: var(--c-tint-salmon) url("../patterns/PNG/about-circle-3.png") center / cover no-repeat; }

/* ============================================================
   SERVICES PAGE  (/services)
   Reuses .page-hero, .split, .video-band, .belief-row, .newsletter, .cta-banner.
   NEW: .statements, .service-card(s), .note-band, .steps. Documented in design-system.md.
   ============================================================ */

/* 1. Hero — LEFT-aligned page-hero variant, lime Biennale caps title + white subhead. */
.page-hero--services { min-height: clamp(500px, 54vw, 720px); }
.page-hero--services > .container { text-align: left; max-width: var(--container-max); }
.page-hero--services .page-hero__title { font-family: var(--font-accent); color: var(--c-lime); text-transform: uppercase; font-size: clamp(2.3rem, 4.2vw, 3.55rem); max-width: 30ch; line-height: 1.05; }
.page-hero__subhead { font-family: var(--font-display); color: var(--c-white); font-size: var(--fs-450); line-height: var(--lh-snug); margin-top: var(--space-md); }
.page-hero--services .page-hero__lead { margin-inline: 0; max-width: 60ch; }
.page-hero--services .hero-cta { margin-top: var(--space-lg); }

/* Shared centered section heading for Services bands (statements / 3-ways / note / steps). */
.svc-head { text-align: center; font-size: var(--fs-700); color: var(--c-olive); line-height: var(--lh-snug); }

/* 2. Statements — 3-col quote grid; lime quote-mark SVG frames the group; rotating title phrase. */
.statements { text-align: center; }
/* Comp quote marks: large lime open-quote top-left + close-quote bottom-right, framing the whole
   block. Painted on a correctly-proportioned layer (aspect = the SVG's) over the container so the
   marks keep their natural size instead of being squashed into the short grid box. */
.statements > .container { position: relative; }
.statements > .container::before {
  content: ""; position: absolute; z-index: 0; pointer-events: none;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: min(1340px, 106%); height: clamp(360px, 34vw, 520px);
  background: url(../patterns/SVG/services-quote.svg) center / contain no-repeat;
}
.statements > .container > * { position: relative; z-index: 1; }
.statements__grid {
  position: relative; max-width: 1040px; margin: var(--space-2xl) auto 0;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 3rem);
  padding-block: var(--space-lg);
}
.statement { padding-inline: var(--space-sm); }
.statement__text { font-size: var(--fs-400); color: var(--c-ink); line-height: 1.55; }
.statement__cite { display: block; margin-top: var(--space-md); font-weight: var(--fw-bold); font-size: var(--fs-75); letter-spacing: 0.12em; text-transform: uppercase; color: var(--c-olive); }
@media (max-width: 700px) { .statements__grid { grid-template-columns: 1fr; gap: var(--space-xl); } .statements > .container::before { display: none; } }

/* 3. "Most people are wrestling" — reuses .split; heading column narrower so the body runs wider/shorter. */
.split--wrestle { grid-template-columns: 0.85fr 1.15fr; }
@media (max-width: 800px) { .split--wrestle { grid-template-columns: 1fr; } }
.wrestle__title { font-size: var(--fs-700); color: var(--c-olive); line-height: var(--lh-snug); }
.wrestle__body > * + * { margin-top: var(--space-md); }
.wrestle__body { color: var(--c-ink); font-size: var(--fs-400); line-height: 1.6; }

/* 4. Video — pale placeholder variant of .video-band (blue-pale frame, no title). Pulled up
   tight under the white "Most people" section above (both white → drop the doubled gap). */
/* Pull the panel up tight under the white "Most people" text (both white). The frame's own
   40px margin-top would collapse out of the zero-padding section and reveal the cream body
   ("tan bar"); zero it, then lift the whole band into the section above's bottom padding. */
.video-band--pale { padding-top: 0; margin-top: calc(var(--section-y) * -0.55); }
.video-band--pale .video-band__frame { background: var(--c-blue-pale); margin-top: 0; }
.video-band--pale .video-band__frame::after { content: "video"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--c-olive); font-size: var(--fs-300); }

/* 5. "Welcome to TAF" — reuses .belief-row(--media-left) + a button slot.
   --tall: media cell stretches to the (long) text column height instead of a fixed 3:2 crop. */
.belief-row__actions { margin-top: var(--space-lg); }
.belief-row__actions .btn { padding-inline: 3.2em; }
/* Services "About TAF" — a touch more padding than the shared belief-row button. */
.belief-row--tall .belief-row__actions .btn { padding: 1.55em 4.4em 1.4em; }
/* Comp/AI: orange belief-row buttons use near-black label text (not cream). */
.belief-row__actions .btn--orange { color: var(--c-ink); }
.belief-row__actions .btn--orange:hover { color: var(--c-ink); }
.belief-row--tall { align-items: stretch; }
.belief-row--tall .belief-row__media { aspect-ratio: auto; min-height: clamp(360px, 38vw, 520px); }

/* 6. Service cards — number label + Hello Imperfect title + body + full-width lime button. */
.service-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.25rem, 2.5vw, 1.75rem); margin-top: var(--space-2xl); margin-bottom: var(--space-lg); align-items: stretch; }
.service-card {
  position: relative;                                  /* anchor for the straddling button */
  background: var(--c-mist); border-radius: var(--radius-lg); overflow: visible;
  display: flex; flex-direction: column; padding: clamp(1.5rem, 2.5vw, 2.25rem) clamp(1.5rem, 2.5vw, 2.25rem) clamp(2.5rem, 4vw, 3.25rem);
}
.service-card__label { font-family: var(--font-accent); text-transform: uppercase; color: var(--c-orange); font-size: var(--fs-300); letter-spacing: 0.04em; }
.service-card__title { font-family: var(--font-accent); text-transform: uppercase; color: var(--c-olive); font-size: var(--fs-500); line-height: var(--lh-snug); margin-top: var(--space-sm); }
.service-card__body { color: var(--c-ink); font-size: var(--fs-200); line-height: 1.6; margin-top: var(--space-md); }
.service-card__body + .service-card__body { margin-top: var(--space-sm); }
/* Lime pill straddling the card's bottom edge (same idiom as the About arch cards). Text wraps:
   the long card-1 label runs 2 lines; the shorter card-2/3 labels stay on one. */
.service-card__btn {
  position: absolute; left: 50%; bottom: 0; transform: translate(-50%, 50%);
  white-space: normal; text-align: center; justify-content: center;
  width: max-content; max-width: min(94%, 290px); font-size: var(--fs-75); letter-spacing: 0.03em; line-height: 1.25;
  padding: 1.05em 1.5em;
}
/* Keep the straddle transform on hover/active — the base .btn lift would otherwise yank the
   pinned button off the card edge. */
.service-card__btn:hover, .service-card__btn:active { transform: translate(-50%, 50%); }
/* Stacked single column: widen the row gap so each card's straddling button (which hangs
   ~30px below its card) clears the next card instead of overlapping it. */
@media (max-width: 860px) { .service-cards { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; gap: 3.5rem; } }

/* 7. Note band — centered statement + taped handwritten-note placeholder + orange squiggle corners. */
.note-band { position: relative; overflow: hidden; text-align: center; }
.note-band__pattern { position: absolute; inset: 0; background: url(../patterns/SVG/squiggle-bg-orange.svg) center / cover no-repeat; z-index: 0; opacity: 0.9; pointer-events: none; }
.note-band > .container { position: relative; z-index: 1; }
.note-band .svc-head { max-width: 22ch; margin-inline: auto; }
/* Taped handwritten note — extracted from TAF_Services.ai (paper + torn orange tape + handwriting
   + drop shadow are baked into the transparent PNG). */
.note-band__note {
  display: block; width: clamp(240px, 33vw, 392px); height: auto;
  margin: var(--space-2xl) auto 0;
}

/* 8. Steps — 3-col numbered steps (orange numeral) + centered CTA. */
.steps { text-align: center; }
.steps__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 3rem); margin: var(--space-2xl) auto var(--space-xl); text-align: left; }
.step-item { display: grid; grid-template-columns: auto 1fr; column-gap: var(--space-sm); align-items: start; }
.step-item__num { font-family: var(--font-accent); color: var(--c-orange); font-size: var(--fs-800); line-height: 0.8; }
.step-item__title { font-family: var(--font-body); font-weight: var(--fw-bold); color: var(--c-olive); font-size: var(--fs-300); }
.step-item__body { color: var(--c-ink); font-size: var(--fs-200); line-height: 1.6; margin-top: var(--space-2xs); }
.step-item__num { grid-row: span 2; }
@media (max-width: 700px) { .steps__grid { grid-template-columns: 1fr; max-width: 440px; margin-inline: auto; } }

/* Brand divider — olive band carrying a pale-blue abstract pattern, between the steps CTA and
   the newsletter. Pattern SVG is a PENDING client asset; __pattern is a ready hook (empty now). */
.brand-divider { position: relative; overflow: hidden; background: var(--c-olive); min-height: clamp(96px, 13vw, 168px); }
.brand-divider__pattern { position: absolute; inset: 0; background: var(--c-olive) url("../patterns/PNG/speaking-divider-band.png") center / cover no-repeat; pointer-events: none; }
/* Services has its own divider artwork (olive band + blue waves), extracted from TAF_Services.ai. */
.brand-divider--services .brand-divider__pattern { background-image: url("../patterns/PNG/services-divider-pattern.png"); }

/* ============================================================
   SPEAKING AT CHURCHES PAGE  (/speaking)
   Reuses .page-hero, .statements__grid, .belief-row, .values-bar, .brand-divider, .newsletter.
   NEW: .faith-cards, .topic-list (accordion), .menu-band, .speakers, .invite-steps,
   .events-table/.materials, .separation, .values-bar--olive. Documented in design-system.md.
   ============================================================ */

/* 1. Hero — centered (default .page-hero), white Biennale title + light centered subhead. */
.page-hero--speaking { min-height: clamp(480px, 52vw, 700px); }
/* Comp fades the photo into a dusty-rose wash (normal blend lightens; the default olive multiply darkens). */
.page-hero--speaking .page-hero__tint { background: var(--c-blush); mix-blend-mode: normal; opacity: 0.72; }
.page-hero--speaking .page-hero__title { font-size: clamp(2rem, 4.2vw, 3.2rem); max-width: 40ch; margin-inline: auto; }
.page-hero--speaking .page-hero__subhead { font-family: var(--font-body); font-weight: var(--fw-semibold); font-size: var(--fs-300); color: var(--c-cream); margin-top: var(--space-sm); }
.page-hero__subhead--center { text-align: center; margin-inline: auto; }
.page-hero--speaking .hero-cta { margin-top: var(--space-lg); }

/* 2. "Trying to raise kids…" — centered text + 3 quote-glyph questions (reuses .statements__grid). */
.raise { text-align: center; }
.raise__title { font-size: var(--fs-700); color: var(--c-olive); max-width: 24ch; margin-inline: auto; line-height: var(--lh-snug); }
.raise__lead { font-size: var(--fs-450); color: var(--c-ink); max-width: 46ch; margin: var(--space-md) auto 0; }
.raise__sub { font-weight: var(--fw-bold); color: var(--c-olive); font-size: var(--fs-400); margin-top: var(--space-xl); }
.raise__questions { background: none; max-width: 920px; margin-inline: auto; margin-top: var(--space-sm); }
.raise__questions .statement { position: relative; padding: var(--space-md) var(--space-md); display: flex; align-items: center; justify-content: center; }
/* Faint blue-gray "?" glyph behind each quote (extracted from comp). */
.raise__questions .statement::before { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 3.6rem; height: 7rem; background: url("../patterns/SVG/speaking-q-mark.svg") center / contain no-repeat; z-index: 0; pointer-events: none; }
.raise__questions .statement__text { position: relative; z-index: 1; font-size: var(--fs-400); color: var(--c-ink); }
.raise__body { max-width: 72ch; margin: var(--space-lg) auto 0; color: var(--c-ink); font-size: var(--fs-300); line-height: 1.7; }
.raise__body > p + p { margin-top: var(--space-md); }
.raise__actions { margin-top: var(--space-xl); }

/* 3. "What growing faith looks like…" — blue band + 3 placeholder white cards (content pending). */
.faith-band { position: relative; overflow: hidden; }
.faith-band__pattern { position: absolute; inset: 0; background: var(--c-blue) url("../patterns/PNG/speaking-faith-band.png") center / cover no-repeat; pointer-events: none; }
.faith-band > .container { position: relative; z-index: 1; }
.faith-band__title { color: var(--c-olive); max-width: 22ch; margin-inline: auto; }
.faith-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.25rem, 3vw, 2rem); margin-top: var(--space-2xl); }
.faith-card { background: var(--c-white); border-radius: var(--radius-lg); min-height: clamp(320px, 30vw, 430px); box-shadow: 0 18px 40px rgba(40, 40, 40, 0.10); }
@media (max-width: 800px) { .faith-cards { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; } }

/* 4. "Speaker Set List" — accordion: numeral + Hello Imperfect orange title + lime pill + chevron. */
.topics__title { font-size: var(--fs-700); color: var(--c-olive); }
.topics__sub { color: var(--c-ink); font-size: var(--fs-400); margin-top: var(--space-2xs); }
.topic-list { margin-top: var(--space-xl); border-top: 1px solid rgba(54, 68, 31, 0.18); }
.topic { border-bottom: 1px solid rgba(54, 68, 31, 0.18); }
.topic__head { display: grid; grid-template-columns: auto 1fr auto auto; align-items: center; gap: clamp(0.85rem, 2.5vw, 2rem); width: 100%; text-align: left; padding: clamp(1.4rem, 3vw, 2.1rem) 0; }
.topic__num { font-family: var(--font-accent); color: var(--c-olive); font-size: var(--fs-600); line-height: 1; }
.topic__title { font-family: var(--font-accent); text-transform: uppercase; color: var(--c-orange); font-size: var(--fs-600); line-height: var(--lh-snug); }
.topic__pill { justify-self: end; background: var(--c-lime); color: var(--c-olive); font-family: var(--font-body); font-weight: var(--fw-bold); font-size: var(--fs-75); text-transform: uppercase; letter-spacing: 0.05em; line-height: 1.15; text-align: center; padding: 0.7em 1em; border-radius: var(--radius-pill); max-width: 7em; }
.topic__chevron { width: 2.4rem; height: 2.4rem; border-radius: 50%; background: var(--c-olive); position: relative; flex: none; }
.topic__chevron::after { content: ""; position: absolute; inset: 0; margin: auto; width: 0.66rem; height: 0.66rem; border-right: 2.5px solid var(--c-cream); border-bottom: 2.5px solid var(--c-cream); transform: translateY(-25%) rotate(45deg); transition: transform var(--dur) var(--ease); }
.topic__head[aria-expanded="true"] .topic__chevron::after { transform: translateY(20%) rotate(225deg); }
.topic__panel { overflow: hidden; max-height: 0; transition: max-height 0.34s var(--ease); }
.topic__head[aria-expanded="true"] + .topic__panel { max-height: 64rem; }
.topic__lede { color: var(--c-ink); font-size: var(--fs-300); padding-bottom: var(--space-md); max-width: 70ch; }
.topic__label { font-weight: var(--fw-bold); color: var(--c-olive); }
.topic__body { color: var(--c-ink); font-size: var(--fs-200); line-height: 1.7; padding: var(--space-2xs) 0 clamp(1.4rem, 3vw, 2.1rem); max-width: 76ch; }
@media (max-width: 680px) {
  .topic__head { grid-template-columns: auto 1fr auto; gap: var(--space-sm) var(--space-md); }
  .topic__pill { grid-column: 2 / 3; grid-row: 2; justify-self: start; margin-top: var(--space-2xs); }
}

/* 5. "Lots of questions / speaking topics" — Hello Imperfect orange title + menu CTA + art hook. */
.menu-band > .container { display: grid; grid-template-columns: 1.55fr 1fr; gap: clamp(1.5rem, 3.5vw, 3rem); align-items: center; }
.menu-band__title { font-family: var(--font-accent); text-transform: uppercase; color: var(--c-orange); font-size: clamp(1.55rem, 2.7vw, 2.3rem); line-height: var(--lh-snug); max-width: 34ch; }
.menu-band__text > p { margin-top: var(--space-md); color: var(--c-ink); font-size: var(--fs-400); max-width: 56ch; }
.menu-band__text .btn { margin-top: var(--space-lg); }
.menu-band__art { min-height: clamp(280px, 27vw, 420px); background: url("../patterns/PNG/speaking-question-bubbles.png") center / contain no-repeat; }
@media (max-width: 800px) { .menu-band > .container { grid-template-columns: 1fr; } .menu-band__art { display: none; } }

/* 7. "Meet Your Speakers" — heading + lead + client polaroid composite (transparent PNG). */
.speakers { text-align: center; position: relative; overflow: hidden; padding-bottom: clamp(1.5rem, 3vw, 3rem); }
.speakers > .container { position: relative; z-index: 1; }
.speakers__title { color: var(--c-olive); }
.speakers__lead { max-width: 64ch; margin: var(--space-md) auto 0; color: var(--c-ink); font-size: var(--fs-400); }
.speakers__art { margin-top: var(--space-xl); }
.speakers__art img { width: 100%; max-width: 1340px; margin-inline: auto; }
/* Blue brush-squiggle in the lower-right background (extracted from comp; right-anchored). */
.speakers__squiggle { position: absolute; right: 0; bottom: 0; width: min(1180px, 82%); aspect-ratio: 1828 / 813; background: url("../patterns/PNG/speaking-blue-squiggle.png") right bottom / contain no-repeat; z-index: 0; pointer-events: none; }

/* 8. "How to Invite…" — 3 big color discs (STEP N) + CTA. */
.invite { text-align: center; }
.invite__title { font-size: var(--fs-700); color: var(--c-olive); max-width: 22ch; margin: var(--space-sm) auto 0; line-height: var(--lh-snug); }
.invite-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 3rem); margin: var(--space-2xl) auto var(--space-xl); max-width: 980px; }
.invite-step { text-align: center; }
.invite-step__disc { width: clamp(108px, 11vw, 142px); aspect-ratio: 1; border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; margin: 0 auto var(--space-md); color: var(--c-cream); }
.invite-step__disc--olive { background: var(--c-olive-mid); }
.invite-step__disc--blue { background: var(--c-blue-deep); }
.invite-step__disc--orange { background: var(--c-orange); }
/* "STEP" + numeral are Hello Imperfect (hand-drawn) per both the Workshop AND Speaking comps. */
.invite-step__kicker { font-family: var(--font-accent); text-transform: uppercase; letter-spacing: 0.06em; font-size: var(--fs-200); line-height: 1; margin-bottom: 0.32em; }
.invite-step__num { font-family: var(--font-accent); font-size: var(--fs-800); line-height: 0.9; }
.invite-step__title { font-family: var(--font-body); font-weight: var(--fw-bold); font-size: var(--fs-300); color: var(--c-olive); }
.invite-step__body { color: var(--c-ink); font-size: var(--fs-300); margin-top: var(--space-2xs); max-width: 22ch; margin-inline: auto; }
.invite__actions { margin-top: var(--space-lg); }
.invite__actions .btn { padding-inline: 3.2em; }
@media (max-width: 760px) { .invite-steps { grid-template-columns: 1fr; max-width: 340px; } }

/* 9. "Join An Event Near You" — white DATE/LOCATION table + EVENT MATERIALS bullet grid. */
.events-near { text-align: center; position: relative; overflow: hidden; }
.events-near::before { content: ""; position: absolute; inset: 0; background: url("../patterns/PNG/speaking-events-band.png") center / cover no-repeat; z-index: 0; pointer-events: none; }
.events-near > .container { position: relative; z-index: 1; }
.events-near__title { color: var(--c-olive); }
.events-table { max-width: 620px; margin: var(--space-xl) auto 0; }
.events-table__cap, .materials__cap { font-family: var(--font-accent); color: var(--c-olive); font-size: var(--fs-500); letter-spacing: 0; text-transform: none; line-height: 1.1; }
.events-table table { width: 100%; background: var(--c-white); border-radius: var(--radius-md); border-collapse: collapse; margin-top: var(--space-md); box-shadow: 0 14px 34px rgba(40, 40, 40, 0.08); overflow: hidden; }
/* Comp: hand-drawn brush underline under each header; no row dividers; tight rows. */
.events-table th { font-family: var(--font-display); color: var(--c-olive); font-size: var(--fs-300); padding: clamp(1rem, 2vw, 1.4rem) clamp(0.9rem, 2vw, 1.3rem) clamp(0.9rem, 1.8vw, 1.15rem); background: url("../patterns/SVG/speaking-th-underline.svg") center bottom 0.5rem / 88px auto no-repeat; }
.events-table td { padding: 0.32em 1.4em; color: var(--c-ink); font-size: var(--fs-200); text-align: center; }
.events-table tbody tr:first-child td { padding-top: 0.55em; }
.events-table tbody tr:last-child td { padding-bottom: 0.7em; }
.materials { max-width: 780px; margin: var(--space-2xl) auto 0; text-align: center; }
.materials__lead { color: var(--c-ink); font-size: var(--fs-425); margin-top: var(--space-2xs); }
.materials__lead::after { content: ""; display: block; width: 60px; height: 2px; background: var(--c-olive); margin: var(--space-md) auto 0; }
/* Column-fill: each column holds 2 items top→bottom; the long "Event Promotion" item spans both rows of column 2. */
.materials-list { display: grid; grid-template-columns: repeat(4, auto); grid-template-rows: repeat(2, auto); grid-auto-flow: column; justify-content: center; gap: var(--space-2xs) clamp(1.5rem, 4vw, 3rem); margin-top: var(--space-lg); text-align: left; }
.materials-list li { position: relative; padding-left: 1.1em; color: var(--c-ink); font-size: var(--fs-200); }
.materials-list li::before { content: "•"; position: absolute; left: 0; color: var(--c-olive); }
.materials-list__span2 { grid-row: 1 / span 2; align-self: start; max-width: 18ch; }
@media (max-width: 700px) { .materials-list { grid-template-columns: repeat(2, auto); grid-template-rows: auto; grid-auto-flow: row; } .materials-list__span2 { grid-row: auto; } }

/* 10. "What Separation From Faith Does…" — blue band, centered title over 2-col (body | photo). */
.separation { position: relative; overflow: hidden; }
.separation__pattern { position: absolute; inset: 0; background: var(--c-blue) url("../patterns/PNG/speaking-separation-band.png") center / cover no-repeat; pointer-events: none; }
.separation > .container { position: relative; z-index: 1; }
.separation__title { text-align: center; font-size: var(--fs-700); color: var(--c-olive); line-height: var(--lh-snug); max-width: 26ch; margin: 0 auto var(--space-2xl); }
.separation__cols { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: center; }
.separation__body { color: var(--c-ink); font-size: var(--fs-300); line-height: 1.7; }
.separation__body > p + p { margin-top: var(--space-md); }
.separation__media { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4 / 3; }
.separation__media img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 800px) { .separation__cols { grid-template-columns: 1fr; gap: var(--space-lg); } .separation__media { order: -1; } }

/* 11. "Why choose…" — olive band, white title + 7-col line-icon row (icons pending → placeholders). */
.values-bar--olive { background: var(--c-olive); color: var(--c-cream); }
.values-bar__head { text-align: center; color: var(--c-cream); font-size: var(--fs-700); max-width: 24ch; margin: 0 auto clamp(2.5rem, 5vw, 4rem); }
.values-bar--olive .values-bar__grid { grid-template-columns: repeat(7, 1fr); gap: clamp(1.25rem, 1.6vw, 1.9rem); }
.values-bar__cap { font-family: var(--font-body); font-size: var(--fs-300); line-height: var(--lh-snug); color: rgba(250, 243, 233, 0.92); margin-top: var(--space-md); max-width: 22ch; margin-inline: auto; }
.values-bar__ph { font-size: var(--fs-75); text-transform: uppercase; letter-spacing: 0.08em; color: rgba(250, 243, 233, 0.5); border: 1px dashed rgba(250, 243, 233, 0.4); border-radius: var(--radius-sm); padding: 0.4em 0.7em; }
@media (max-width: 1000px) { .values-bar--olive .values-bar__grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 680px) { .values-bar--olive .values-bar__grid { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   WORKSHOP / INTERACTIVE Q&A WORKSHOP  (workshop.html)
   One page serves both nav items (client-confirmed same comp 2026-06-04).
   Reuses .page-hero, .testimonials, .invite-steps, .events-table/.materials,
   .belief-row, .newsletter, .cta-banner. NEW: .page-hero--workshop, .outcomes,
   .workshop-types, .testimonials--peach, .welcome-list, .qa-cards, .host-circles,
   .faq-list. Documented in design-system.md.
   ============================================================ */

/* 1. Hero — lime Hello Imperfect title (mirrors --services), slate-blue CTA. */
.page-hero--workshop { min-height: clamp(520px, 56vw, 740px); }
.page-hero--workshop .page-hero__title { font-family: var(--font-accent); color: var(--c-lime); text-transform: uppercase; font-size: clamp(2.4rem, 4.7vw, 3.9rem); max-width: 22ch; margin-inline: auto; line-height: 1.04; }
.page-hero--workshop .page-hero__title .hl-mark { color: var(--c-cream-warm); }  /* cream text over the olive bar on "in Real-Time." */
.page-hero--workshop .page-hero__subhead { font-family: var(--font-body); font-weight: var(--fw-semibold); font-size: var(--fs-300); max-width: 56ch; margin-inline: auto; }
.page-hero--workshop .hero-cta { margin-top: var(--space-lg); }

/* 2. Outcomes — cream; Biennale title (peach hl) + 5 line-icon outcomes + closer.
   Flex-wrap grid so the 5th item centers on its own row when it wraps. Icons pending. */
.outcomes { text-align: center; }
.outcomes__title { font-size: var(--fs-700); color: var(--c-olive); max-width: 20ch; margin: 0 auto; }
.outcomes__lead { font-size: var(--fs-450); color: var(--c-olive); max-width: 60rem; margin: var(--space-md) auto 0; line-height: var(--lh-snug); }
.outcomes__sub { font-size: var(--fs-200); color: var(--c-ink); max-width: 56ch; margin: var(--space-md) auto 0; }
.outcomes__intro { font-weight: var(--fw-bold); color: var(--c-olive); font-size: var(--fs-200); margin-top: var(--space-xl); }
.outcomes__grid { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(1.75rem, 3.5vw, 3rem); margin-top: var(--space-lg); }
.outcomes__item { flex: 0 1 168px; display: flex; flex-direction: column; align-items: center; }
.outcomes__icon { height: clamp(44px, 4.8vw, 60px); display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-sm); }
.outcomes__icon img, .outcomes__icon svg { height: 100%; width: auto; }
.outcomes__ph { font-size: var(--fs-75); text-transform: uppercase; letter-spacing: 0.08em; color: rgba(54, 68, 31, 0.4); border: 1px dashed rgba(54, 68, 31, 0.32); border-radius: var(--radius-sm); padding: 0.5em 0.7em; }
.outcomes__cap { font-size: var(--fs-300); line-height: var(--lh-snug); color: var(--c-ink); }
/* Orange squiggle divider (pending client SVG → flat rounded rule placeholder). */
.outcomes__divider { width: clamp(120px, 22vw, 240px); height: 6px; border-radius: 999px; background: var(--c-orange); margin: var(--space-2xl) auto var(--space-xl); opacity: 0.85; }
.outcomes__closer { font-weight: var(--fw-bold); color: var(--c-olive); font-size: var(--fs-400); max-width: 34ch; margin-inline: auto; }
.outcomes__closer-body { font-size: var(--fs-400); color: var(--c-ink); max-width: 62ch; margin: var(--space-md) auto 0; line-height: var(--lh-snug); }

/* 3. Workshop types — orange band; Hello Imperfect 2-tone title + 3 type columns. */
.workshop-types { text-align: center; }
.workshop-types__title { font-family: var(--font-accent); line-height: 1; margin-bottom: var(--space-2xl); }
.workshop-types__title .wt-top { display: block; text-transform: uppercase; color: var(--c-cream); font-size: clamp(2.2rem, 4.6vw, 3.6rem); text-shadow: 0 4px 0 rgba(42, 52, 25, 0.18); }
.workshop-types__title .wt-bot { display: block; color: var(--c-white); font-size: clamp(1.6rem, 3.4vw, 2.7rem); margin-top: 0.1em; }
.workshop-types__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 2.8vw, 2.5rem); max-width: 1260px; margin: 0 auto var(--space-2xl); }
.workshop-type { display: flex; flex-direction: column; align-items: center; }
.workshop-type__icon { height: clamp(56px, 6vw, 84px); display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-md); color: var(--c-cream); }
.workshop-type__icon img, .workshop-type__icon svg { height: 100%; width: auto; }
.workshop-type__ph { font-size: var(--fs-75); text-transform: uppercase; letter-spacing: 0.08em; color: rgba(250, 243, 233, 0.55); border: 1px dashed rgba(250, 243, 233, 0.45); border-radius: var(--radius-sm); padding: 0.5em 0.7em; }
.workshop-type__title { font-family: var(--font-accent); text-transform: uppercase; color: var(--c-cream); font-size: var(--fs-700); line-height: 1.05; margin-bottom: var(--space-sm); }
.workshop-type__body { color: var(--c-white); font-size: var(--fs-400); line-height: var(--lh-snug); max-width: 42ch; }
@media (max-width: 800px) { .workshop-types__grid { grid-template-columns: 1fr; max-width: 360px; gap: var(--space-xl); } }

/* 4. Testimonials --peach modifier — blue-pale band, peach quote glyphs (no lime SVG frame). */
.testimonials--peach .testimonials__frame { background: none; position: relative; }
.testimonials--peach .testimonials__frame::before,
.testimonials--peach .testimonials__frame::after { content: ""; position: absolute; width: clamp(64px, 9vw, 120px); aspect-ratio: 258 / 183; background-repeat: no-repeat; background-position: center; background-size: contain; opacity: 0.45; pointer-events: none; }
.testimonials--peach .testimonials__frame::before { background-image: url("../patterns/SVG/workshop-quote-open.svg"); top: 0; left: 0; }
.testimonials--peach .testimonials__frame::after { background-image: url("../patterns/SVG/workshop-quote-close.svg"); bottom: 0; right: 0; }
.testimonials__title { font-size: var(--fs-700); color: var(--c-olive); text-align: center; margin-bottom: var(--space-md); }

/* 5. Welcome list — cream-pale; Biennale title (peach hl) + 2-col blue-square checklist. */
.welcome { text-align: center; position: relative; overflow: hidden; }
.welcome > .container { position: relative; z-index: 1; }
.welcome__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; pointer-events: none; }
.welcome__title { font-size: var(--fs-700); color: var(--c-olive); max-width: 22ch; margin: 0 auto var(--space-2xl); }
/* Column-fill so the reading order down the left column is items 1-3, right is 4-6 (per comp). */
.welcome-list { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: repeat(3, auto); grid-auto-flow: column; gap: clamp(1.25rem, 3vw, 2.25rem) clamp(2rem, 5vw, 4rem); max-width: 940px; margin: 0 auto var(--space-2xl); text-align: left; list-style: none; padding: 0; }
.welcome-list li { display: grid; grid-template-columns: auto 1fr; gap: var(--space-md); align-items: start; color: var(--c-ink); font-size: var(--fs-200); line-height: var(--lh-snug); }
.welcome-list li::before { content: ""; width: 22px; height: 17px; border-radius: 3px 999px 999px 3px; background: var(--c-blue); margin-top: 0.25em; flex-shrink: 0; }
@media (max-width: 720px) { .welcome-list { grid-template-columns: 1fr; grid-template-rows: none; grid-auto-flow: row; max-width: 460px; } }

/* 6. Q&A cards — white; Biennale title (lime hls) + 3 tall OUTLINE rounded cards (content pending). */
.qa-band { text-align: center; }
.qa-band__title { font-size: var(--fs-700); color: var(--c-olive); max-width: 30ch; margin: 0 auto; }
.qa-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.25rem, 3vw, 2rem); margin-top: var(--space-2xl); }
.qa-card { border: 1.5px solid rgba(54, 68, 31, 0.28); border-radius: var(--radius-lg); min-height: clamp(300px, 28vw, 400px); }
@media (max-width: 800px) { .qa-cards { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; } }

/* 7. Host circles — cream-pale (+ gray watercolor pending); Biennale title (muted hl) + 3 portrait circles. */
.hosts { text-align: center; position: relative; overflow: hidden; }
.hosts > .container { position: relative; z-index: 1; }
.hosts__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; pointer-events: none; }
.hosts__title { font-size: var(--fs-700); color: var(--c-olive); max-width: 22ch; margin: 0 auto var(--space-2xl); }
.host-circles { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(2rem, 6vw, 5rem); margin-bottom: var(--space-2xl); }
.host { display: flex; flex-direction: column; align-items: center; gap: var(--space-md); }
.host__photo { width: clamp(190px, 21vw, 290px); aspect-ratio: 1; border-radius: 50%; background: var(--c-white); overflow: hidden; }
.host__photo img { width: 100%; height: 100%; object-fit: cover; }
.host__name { font-family: var(--font-body); font-weight: var(--fw-bold); font-size: var(--fs-300); color: var(--c-olive); }

/* 9. FAQ list — white; Biennale title (lime hl) + static blue-pale Q/A panels + note. */
.faq-band { text-align: center; }
.faq-band__title { font-size: var(--fs-700); color: var(--c-olive); max-width: 24ch; margin: 0 auto var(--space-sm); }
.faq-band__intro { font-size: var(--fs-400); color: var(--c-ink); max-width: 46rem; margin: 0 auto var(--space-lg); line-height: var(--lh-snug); }
.faq-list { display: flex; flex-direction: column; gap: clamp(1rem, 2vw, 1.5rem); max-width: 880px; margin: 0 auto; text-align: left; }
.faq { background: var(--c-blue-pale); border-radius: var(--radius-md); padding: clamp(1.4rem, 2.6vw, 2rem) clamp(1.5rem, 3vw, 2.4rem); }
.faq__q { font-family: var(--font-body); font-weight: var(--fw-bold); font-size: var(--fs-400); color: var(--c-olive); margin-bottom: var(--space-2xs); }
.faq__a { font-size: var(--fs-200); color: var(--c-ink); line-height: 1.65; }
.faq__a > p + p { margin-top: var(--space-md); }
.faq__a em { font-style: italic; }
.faq__note { display: grid; grid-template-columns: auto 1fr; gap: var(--space-md); align-items: center; max-width: 880px; margin: var(--space-2xl) auto 0; text-align: left; }
.faq__arrow { width: clamp(48px, 5.5vw, 68px); height: auto; flex-shrink: 0; }
.faq__arrow-ph { display: inline-flex; align-items: center; justify-content: center; width: clamp(40px, 5vw, 56px); height: clamp(28px, 3.4vw, 38px); background: var(--c-lime); border-radius: var(--radius-sm); color: var(--c-olive); font-weight: var(--fw-bold); font-size: var(--fs-300); }
.faq__note p { font-size: var(--fs-200); color: var(--c-ink); }
.faq__note strong { color: var(--c-olive); }
@media (max-width: 560px) { .faq__note { grid-template-columns: 1fr; gap: var(--space-sm); text-align: center; justify-items: center; } }

/* ============================================================
   MEET THE FOUNDERS (founders.html) — spec: design/pages/founders.md
   Reuse-heavy: .page-hero (olive duotone), .invite (×2), .newsletter.
   NEW below: .founders-story + .polaroid-stack, .founder-card, .board grid.
   Zero new color tokens — every fill maps to an existing --c-* token.
   ============================================================ */

/* §2 — "Making God Known… Since 2014": 2-col text + tilted polaroid cluster on blue-pale.
   Lime brush accents (client art, extracted from the comp) bleed from the left + right edges. */
.founders-story-band { position: relative; overflow: hidden; }
.founders-story-band > .container { position: relative; z-index: 1; }
.founders-edge { position: absolute; top: 0; height: 100%; width: auto; z-index: 0; pointer-events: none; }
.founders-edge--left { left: 0; }
.founders-edge--right { right: 0; }
.founders-story { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.founders-story__title { font-family: var(--font-display); color: var(--c-olive); font-size: var(--fs-700); line-height: var(--lh-snug); margin: 0; }
.founders-story__body { margin-top: var(--space-lg); color: var(--c-ink); font-size: var(--fs-300); line-height: 1.8; }
.founders-story__body > p + p { margin-top: var(--space-md); }
.founders-story__actions { margin-top: var(--space-lg); }
/* Comp button: solid slate-blue pill with tonal pale text (low-contrast, measured #A8B8C7 / #DCE5EB). */
.founders-story__actions .btn--blue { color: var(--c-blue-pale); }
.founders-story__actions .btn--blue:hover { color: var(--c-cream); }
/* Three blank white cards (photo placeholders), overlapping + rotated. Per-card shape + position
   measured from the comp's .ai rects (cluster ≈841×844 design-px): small square top-left,
   large portrait right, wide landscape bottom — NOT three identical portraits. */
.polaroid-stack { position: relative; width: 100%; aspect-ratio: 1 / 1; }
.polaroid { position: absolute; background: var(--c-white); border: var(--border); border-radius: var(--radius-lg); box-shadow: 0 16px 36px rgba(40, 40, 40, 0.13); }
.polaroid--1 { left: 20.6%; top: 0;      width: 33.7%; height: 36.6%; transform: rotate(-8deg); z-index: 3; } /* small ~square, top-left */
.polaroid--2 { left: 40%;   top: 10%;    width: 60%;   height: 65%;   transform: rotate(7deg);  z-index: 1; } /* large portrait, right */
.polaroid--3 { left: 0;     top: 45.5%;  width: 63.7%; height: 54.5%; transform: rotate(-5deg); z-index: 2; } /* wide landscape, bottom */

/* §3 — Meet the Founders: two two-tone cards, each with a circle portrait straddling the top. */
.founders-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.75rem, 4vw, 3.5rem); max-width: 1000px; margin: clamp(5.5rem, 8vw, 7rem) auto 0; align-items: start; }
.founder-card { position: relative; border-radius: var(--radius-lg); padding: clamp(5.5rem, 8vw, 7rem) clamp(1.75rem, 3vw, 2.75rem) clamp(2rem, 3.5vw, 2.75rem); }
.founder-card--lime { background: var(--c-lime); }
.founder-card--blue { background: var(--c-blue); }
.founder-card__avatar { position: absolute; top: clamp(-110px, -9vw, -82px); left: 50%; transform: translateX(-50%); width: clamp(150px, 17vw, 192px); aspect-ratio: 1; border-radius: 50%; background: var(--c-white); border: 5px solid var(--c-white); overflow: hidden; box-shadow: 0 12px 28px rgba(40, 40, 40, 0.16); }
.founder-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.founder-card__name { font-family: var(--font-display); text-transform: uppercase; color: var(--c-cream); font-size: var(--fs-700); line-height: 1; margin: 0 0 var(--space-md); }
.founder-card__bio { color: var(--c-olive); font-size: var(--fs-200); line-height: 1.7; }
.founder-card__bio > p + p { margin-top: var(--space-sm); }

/* §4 — Meet the Board: Hello Imperfect title + 3-col grid of bordered placeholder cards. */
.board { text-align: center; }
.board__title { font-family: var(--font-accent); text-transform: uppercase; color: var(--c-olive); font-size: var(--fs-700); line-height: var(--lh-snug); margin: 0 auto var(--space-2xl); }
.board-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.25rem, 3vw, 2.25rem); max-width: 1040px; margin-inline: auto; }
.board-card { background: var(--c-white); border: var(--border); border-radius: var(--radius-md); overflow: hidden; }
.board-card__media { aspect-ratio: 4 / 3.4; background: var(--c-white); display: block; }
.board-card__media img { width: 100%; height: 100%; object-fit: cover; }
.board-card__name { border-top: var(--border); padding: clamp(0.9rem, 1.8vw, 1.2rem); font-family: var(--font-body); color: var(--c-ink); font-size: var(--fs-300); }

/* §5 — reuses .invite; adds a centered lead paragraph (additive, Founders-only). */
.invite__lead { max-width: 62ch; margin: var(--space-md) auto 0; color: var(--c-ink); font-size: var(--fs-300); line-height: 1.7; }
.invite__lead strong { font-weight: var(--fw-bold); color: var(--c-olive); }
/* §5 sage watercolor blobs (extracted from comp) wash the band edges behind the content. */
.founders-cta { position: relative; overflow: hidden; }
.founders-cta > .container { position: relative; z-index: 1; }
.founders-cta__blobs { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; pointer-events: none; }
/* §6 lime brush art on the blue band: a squiggle from the top-left + brush hatches bottom-right. */
.founders-exp { position: relative; overflow: hidden; }
.founders-exp > .container { position: relative; z-index: 1; }
.founders-exp__squiggle { position: absolute; left: 0; top: 0; height: 80%; width: auto; z-index: 0; pointer-events: none; }
.founders-exp__br { position: absolute; right: 0; bottom: 0; width: clamp(220px, 26vw, 400px); height: auto; z-index: 0; pointer-events: none; }

/* Founders responsive */
@media (max-width: 840px) {
  .founders-story { grid-template-columns: 1fr; gap: clamp(2.5rem, 7vw, 3.5rem); }
  .polaroid-stack { max-width: 440px; margin-inline: auto; }
  .board-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .founders-grid { grid-template-columns: 1fr; max-width: 420px; gap: clamp(5rem, 16vw, 6rem); }
}
@media (max-width: 520px) {
  .board-grid { grid-template-columns: 1fr; max-width: 320px; }
}

/* ============================================================
   MEET THE SPEAKERS (meet-speakers.html · spec design/pages/meet-speakers.md)
   Reuses .page-hero, .testimonials, .newsletter. NEW: .speakers-intro,
   .speaker (alternating bio + extracted arrow callouts), .topics-cta,
   .movement-cta, .speaker-rule. Arrow SVGs = speaker-arrow-{1..6}.svg.
   ============================================================ */

/* 1. Hero — centered, orange hl behind "Biggest Questions". */
.page-hero--speakers { min-height: clamp(440px, 46vw, 720px); }
.page-hero--speakers .page-hero__subhead { font-family: var(--font-body); font-weight: var(--fw-semibold); font-size: var(--fs-300); color: var(--c-cream); margin-top: var(--space-sm); }

/* 2. Speakers intro — mint band, centered lead + big Biennale caps heading. */
.speakers-intro { position: relative; text-align: center; overflow: hidden; }
/* Wavy lime squiggle brush behind the band (extracted from the .ai, clip group 641). */
.speakers-intro__pattern { position: absolute; inset: 0; pointer-events: none; background: url("../patterns/PNG/speakers-intro-pattern.png") center / cover no-repeat; }
.speakers-intro > .container { position: relative; z-index: 1; }
.speakers-intro__lead { font-family: var(--font-body); font-weight: var(--fw-bold); color: var(--c-olive); font-size: var(--fs-400); line-height: var(--lh-snug); max-width: 62ch; margin-inline: auto; }
.speakers-intro__title { font-family: var(--font-accent); font-weight: 400; text-transform: uppercase; color: var(--c-olive); font-size: var(--fs-900); line-height: var(--lh-tight); letter-spacing: 0.01em; margin-top: var(--space-lg); }

/* 3–5. Speaker bios — 2-col (media | content), alternating side. The media side is a SINGLE
   PNG composite (photo + arrows + facts + name + name highlight) exported from the .ai, so
   positioning is baked in and the whole thing swaps as one asset. Placed large + bottom-flush
   to the panel (padding-bottom:0 + align-self:end). */
.speaker { padding-bottom: 0; overflow: hidden; }
.speaker__inner { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(1.5rem, 4vw, 4rem); align-items: end; }
.speaker__content { align-self: start; padding-bottom: var(--section-y); }
.speaker__media { align-self: end; }
.speaker__composite { display: block; width: 100%; max-width: 660px; height: auto; }
.speaker--media-left  .speaker__composite { margin-right: auto; }
.speaker--media-right .speaker__composite { margin-left: auto; }

/* content side — scripture quote, bio, watch CTA. */
.speaker__quote { margin: 0 0 var(--space-lg); }
/* Inter LIGHT ~22px to match the comp so the forced 4-/2-line wrap fits the brush highlight. */
.speaker__quote p { font-family: var(--font-body); font-weight: var(--fw-light); font-size: clamp(1.15rem, 0.95rem + 0.6vw, 1.4rem); line-height: 1.32; color: var(--c-olive); margin: 0; }
/* Painterly brush shape behind the verse — extracted per panel from the .ai
   (blue=Shawn matches the Watch button, coral=Roy, lime=Adrian). Applied as the element's
   OWN background (not a -z-index pseudo) so the scroll-reveal stacking context can't hide it. */
.speaker__quote-text { display: block; padding: 0.3em 0.55em; background: var(--q-hl) center / 100% 100% no-repeat; }
.speaker--shawn  .speaker__quote-text { --q-hl: url("../patterns/SVG/speaker-quote-hl-1.svg"); }
.speaker--roy    .speaker__quote-text { --q-hl: url("../patterns/SVG/speaker-quote-hl-2.svg"); }
.speaker--adrian .speaker__quote-text { --q-hl: url("../patterns/SVG/speaker-quote-hl-3.svg"); }
.speaker__ref { display: block; text-align: right; font-style: normal; font-weight: var(--fw-bold); color: var(--c-olive); font-size: var(--fs-400); margin-top: var(--space-xs); }
.speaker__bio { display: grid; gap: var(--space-sm); }
.speaker__bio p { font-family: var(--font-body); font-size: var(--fs-300); line-height: var(--lh-body); color: var(--c-muted); margin: 0; }
.speaker__watch { margin-top: var(--space-lg); }
.speaker__content .btn--blue { color: var(--c-white); }       /* white caps on Shawn's slate pill */
.speaker__content .btn--blue:hover { color: var(--c-white); }

/* Thin full-width color rules between speaker sections. */
.speaker-rule { height: clamp(10px, 1.3vw, 18px); }
.speaker-rule--olive { background: var(--c-olive); }
.speaker-rule--lime  { background: var(--c-lime); }

/* 6/7. Centered CTA bands. */
.topics-cta__title, .movement-cta__title { font-family: var(--font-display); color: var(--c-olive); font-size: var(--fs-700); line-height: var(--lh-snug); }
/* Roomier pills for the two download / event CTAs (override .btn--sm's tight padding). */
.topics-cta .btn, .movement-cta .btn { padding: 1.05em 2.6em; }
.topics-cta__lead { max-width: 64ch; margin: var(--space-md) auto var(--space-lg); font-size: var(--fs-300); line-height: var(--lh-body); color: var(--c-ink); }
.movement-cta { position: relative; overflow: hidden; }
.movement-cta > .container { position: relative; z-index: 1; }
.movement-cta__title { margin-bottom: var(--space-lg); }
.movement-cta__art { position: absolute; top: 0; bottom: 0; width: 16vw; pointer-events: none; } /* pending lime squiggle brush */
.movement-cta__art--l { left: 0; }
.movement-cta__art--r { right: 0; }

/* Mobile: stack columns; composite (with baked name + facts) above the bio, sized as large
   as the column allows so the baked text stays legible. */
@media (max-width: 900px) {
  .speaker__inner { grid-template-columns: 1fr; gap: var(--space-lg); }
  .speaker__media { order: -1; }                 /* photo+name+facts always above the bio */
  .speaker__composite { max-width: 520px; margin-inline: auto !important; }
}

/* ============================================================================
   DONATE PAGE (donate.html)  ·  spec: design/pages/donate.md
   Reuse-heavy: .page-hero, .belief-row (×2), .testimonials, .newsletter.
   NEW page-scoped blocks: .give-steps, .give-options, .give-circles,
   .founded card, .impact-steps, .give-list. No new tokens (orange/olive/
   lime/blue all exist). Comp-measured: hero title lime, §3 orange, §5 olive,
   §6 circles ORANGE (homepage stat circles are blue — overridden here).
   ============================================================================ */

/* 1. Hero — centered lime Hello-Imperfect caps title (mirrors --workshop), white subhead, lime CTA. */
.page-hero--donate { min-height: clamp(520px, 60vw, 820px); }
.page-hero--donate .page-hero__bg { object-position: 50% 30%; }
.page-hero--donate .page-hero__title { font-family: var(--font-accent); color: var(--c-lime); text-transform: uppercase; font-size: clamp(2.4rem, 5vw, 4.2rem); max-width: 18ch; margin-inline: auto; line-height: 1.05; }
.page-hero--donate .page-hero__subhead { font-family: var(--font-body); font-weight: var(--fw-semibold); font-size: var(--fs-300); max-width: 52ch; margin-inline: auto; }
.page-hero--donate .hero-cta { margin-top: var(--space-lg); }

/* 2. Questions about faith — reuses .belief-row; adds muted footnote stack under the body. */
.donate-q__notes { margin-top: var(--space-md); display: grid; gap: 0.6rem; }
.donate-q__notes p { margin: 0; font-size: var(--fs-200); color: var(--c-blue-deep); line-height: 1.5; max-width: 52ch; }

/* 3. Comes alongside (orange band) — cream Hello-Imperfect title + 4 numbered cream cards. */
/* Selector carries .donate-alongside so it beats base.css `.bg-orange h2` (else title forced pure white). */
.donate-alongside .donate-alongside__title { font-family: var(--font-accent); color: var(--c-cream-warm); text-transform: uppercase; text-align: center; font-size: clamp(1.8rem, 1rem + 2.6vw, 3rem); line-height: 1.08; max-width: 24ch; margin: 0 auto var(--space-xl); }
.give-steps { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem, 2vw, 1.75rem); }
.give-step { position: relative; margin-top: 2.1rem; padding: calc(var(--space-lg) + 1.4rem) var(--space-md) var(--space-md); background: var(--c-cream); border-radius: var(--radius-md); text-align: center; }
.give-step__num { position: absolute; top: 0; left: 50%; transform: translate(-50%, -50%); width: 4.2rem; height: 4.2rem; border-radius: 50%; background: var(--c-olive); color: var(--c-cream-warm); font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-400); display: grid; place-items: center; }
.give-step__body { margin: 0; font-size: var(--fs-200); color: var(--c-ink); line-height: 1.5; }

/* 4. The Solution — eyebrow + Biennale H2, then two body columns (lead green / aside gray + bullets). */
.donate-solution__title { font-family: var(--font-display); color: var(--c-olive); font-size: var(--fs-700); line-height: var(--lh-snug); margin-top: 0.4rem; }
.donate-solution__cols { margin-top: var(--space-lg); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: start; }
.donate-solution__lead { margin: 0; font-size: var(--fs-450); color: var(--c-olive); line-height: var(--lh-snug); }
.donate-solution__aside p { margin: 0 0 var(--space-sm); font-size: var(--fs-200); color: var(--c-blue-deep); }
.give-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.55rem; }
.give-list li { position: relative; padding-left: 1.4rem; font-size: var(--fs-200); color: var(--c-ink); }
.give-list li::before { content: ""; position: absolute; left: 0; top: 0.5em; width: 7px; height: 7px; border-radius: 50%; background: var(--c-blue); }

/* 5. Two ways to give (olive band) — lime-highlighted title + 2 lime-iconed contribution cards. */
.donate-ways__title { font-family: var(--font-display); color: var(--c-cream); font-size: var(--fs-700); text-align: center; line-height: var(--lh-snug); max-width: 24ch; margin: 0 auto var(--space-xl); }
.give-options { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.25rem, 3vw, 2.5rem); max-width: 880px; margin-inline: auto; }
.give-option { display: flex; align-items: center; gap: var(--space-md); padding: clamp(1.5rem, 3vw, 2.2rem) clamp(1.5rem, 4vw, 2.6rem); background: rgba(250, 243, 233, 0.05); border: 1.5px solid rgba(214, 216, 42, 0.38); border-radius: var(--radius-md); text-decoration: none; transition: border-color 0.2s ease, transform 0.2s ease; }
.give-option:hover { border-color: var(--c-lime); transform: translateY(-3px); }
.give-option__icon { flex: 0 0 auto; width: 3.4rem; height: 3.4rem; color: var(--c-lime); }
.give-option__icon svg { width: 100%; height: 100%; }
.give-option__label { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-500); color: var(--c-lime); line-height: 1.1; }

/* 6. Your own questions matter too — orange stat discs (NOT the blue homepage ones) + dark pill. */
.donate-matter { position: relative; overflow: hidden; text-align: center; }
.donate-matter__pattern { position: absolute; inset: 0; background: url(../patterns/PNG/home-movement-bg.png) center / cover no-repeat; opacity: 0.4; pointer-events: none; }
.donate-matter > .container { position: relative; z-index: 1; }
.donate-matter__title { font-family: var(--font-display); color: var(--c-olive); font-size: var(--fs-700); line-height: var(--lh-snug); max-width: 40ch; margin: 0 auto; }
.donate-matter__sub { margin: var(--space-md) auto var(--space-xl); max-width: 46ch; font-size: var(--fs-300); color: var(--c-ink); }
.give-circles { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(1.25rem, 3vw, 2.5rem); }
.give-circle { flex: 0 1 clamp(190px, 22vw, 280px); aspect-ratio: 1; border-radius: 50%; background: var(--c-orange); color: var(--c-white); display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; padding: clamp(1.5rem, 3vw, 2.4rem); }
.give-circle__title { margin: 0 0 0.4rem; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-400); color: var(--c-white); }
.give-circle__body { margin: 0; font-size: var(--fs-200); line-height: 1.4; color: var(--c-white); }
.donate-matter__actions { margin-top: var(--space-xl); }

/* 7. Top quotes — gray band; reuses .testimonials--peach. */
.donate-quotes { text-align: center; }
.donate-quotes__title { font-family: var(--font-display); color: var(--c-olive); font-size: var(--fs-700); margin-bottom: var(--space-lg); }

/* 8. Led by people who care (olive band) — reuses .belief-row, recolored for the dark band. */
.donate-led .belief-row__title { color: var(--c-cream); }
.donate-led .belief-row__body { color: var(--c-cream); opacity: 0.92; }
.donate-led .btn--outline { color: var(--c-cream); border-color: var(--c-cream); }
.donate-led .btn--outline:hover { background: var(--c-cream); color: var(--c-olive); }

/* 9. Founded on — blue-gray band, centered white Biennale + translucent card + orange CTA. */
.donate-founded { background: var(--c-blue); text-align: center; position: relative; overflow: hidden; }
.donate-founded__title { font-family: var(--font-display); color: var(--c-cream); font-size: var(--fs-700); line-height: var(--lh-snug); max-width: 22ch; margin: 0 auto; }
.donate-founded__card { max-width: 620px; margin: var(--space-lg) auto; background: rgba(250, 243, 233, 0.20); border-radius: var(--radius-md); padding: clamp(1.5rem, 3vw, 2.4rem); }
.donate-founded__card p { margin: 0; color: var(--c-cream); font-size: var(--fs-300); line-height: var(--lh-body); }

/* 11. Lasting impact — peach band, 3 big-numeral pill cards + orange CTA. */
.donate-impact { text-align: center; position: relative; overflow: hidden; }
.donate-impact__title { font-family: var(--font-display); color: var(--c-olive); font-size: var(--fs-700); line-height: var(--lh-snug); max-width: 26ch; margin: 0 auto; }
.donate-impact__sub { margin: var(--space-md) auto var(--space-xl); max-width: 40ch; font-size: var(--fs-300); color: var(--c-ink); }
.impact-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2.5vw, 2rem); max-width: 960px; margin-inline: auto; }
.impact-step { display: flex; align-items: center; gap: var(--space-sm); padding: clamp(1.1rem, 2vw, 1.6rem) clamp(1.25rem, 2.5vw, 1.8rem); background: var(--c-cream); border-radius: var(--radius-md); text-align: left; }
.impact-step__num { flex: 0 0 auto; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: clamp(2.4rem, 1.4rem + 3vw, 3.6rem); color: var(--c-blue); line-height: 1; }
.impact-step__title { margin: 0; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-200); color: var(--c-olive); line-height: 1.25; }
.donate-impact__actions { margin-top: var(--space-xl); }

/* Donate responsive — stack the new multi-col grids. (belief-row stacks via its own global rule.) */
@media (max-width: 760px) {
  .give-steps { grid-template-columns: repeat(2, 1fr); }
  .impact-steps { grid-template-columns: 1fr; }
  .impact-step { justify-content: flex-start; }
  .donate-solution__cols,
  .give-options { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .give-steps { grid-template-columns: 1fr; }
}
