/* ============================================================
   Fengfu® Blog — styles
   Extracted from the Claude design (Fengfu Blog.dc.html) into a
   maintainable stylesheet. Rendered output matches the design.

   Sections:
     1. Webfonts
     2. Design tokens (colors, typography, spacing, effects)
     3. Base / layout helpers
     4. Components (logo, nav, eyebrow, badge, button, card, footer)
     5. Page sections (hero, articles, newsletter)
     6. Responsive
   ============================================================ */

/* ---------- 1. Webfonts ---------- */
@import url("https://fonts.googleapis.com/css2?family=Frank+Ruhl+Libre:wght@400;500;700;900&family=Assistant:wght@300;400;500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&display=swap");

/* ---------- 2. Design tokens ---------- */
:root {
  /* —— Brand greens —— */
  --green-900: #2f3d27;
  --green-800: #3b4a30;
  --green-700: #45572f;
  --green-600: #5b6b3c;
  --green-500: #7c8a54;
  --green-300: #a9b388;
  --green-100: #d8ddc4;
  --green-50:  #eef0e3;

  /* —— Terracotta / clay —— */
  --clay-700: #9c5232;
  --clay-600: #b5663f;
  --clay-500: #c47a4f;
  --clay-300: #e0b095;
  --clay-100: #f2ddcd;

  /* —— Gold / bronze —— */
  --gold-700: #9a7634;
  --gold-600: #b8924e;
  --gold-500: #c9a85f;
  --gold-300: #e3cf9f;
  --gold-100: #f3e9d2;

  /* —— Muted teal —— */
  --teal-600: #5d8089;
  --teal-400: #7ba0a8;
  --teal-100: #d8e4e5;

  /* —— Neutrals: cream → sand → stone —— */
  --cream-50:  #faf6ee;
  --cream-100: #f6f0e4;
  --sand-200:  #efe6d4;
  --sand-300:  #e6d9c1;
  --stone-400: #b8ad99;
  --stone-600: #6f6757;
  --stone-800: #4a463c;
  --ink-900:   #322f28;
  --white:     #ffffff;

  /* —— Semantic aliases —— */
  --surface-page:     var(--cream-100);
  --surface-page-alt: var(--cream-50);
  --surface-card:     var(--white);
  --surface-sand:     var(--sand-200);
  --surface-sage:     var(--green-50);
  --surface-footer:   var(--green-800);

  --text-strong:  var(--ink-900);
  --text-body:    var(--stone-800);
  --text-muted:   var(--stone-600);
  --text-caption: var(--stone-400);
  --text-on-dark: var(--cream-50);
  --text-on-dark-muted: #c3cbb1;

  --brand-primary:  var(--green-800);
  --brand-headline: var(--green-700);
  --brand-accent:   var(--clay-600);
  --brand-gold:     var(--gold-600);

  --border-soft: var(--sand-300);
  --border-hair: #e9e0cf;

  --focus-ring: color-mix(in srgb, var(--gold-600) 55%, transparent);

  /* —— Typography —— */
  --font-display: "Frank Ruhl Libre", "Noto Serif Hebrew", Georgia, serif;
  --font-body: "Assistant", "Heebo", system-ui, -apple-system, sans-serif;
  --font-accent: "Cormorant Garamond", "Frank Ruhl Libre", Georgia, serif;

  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-black: 900;

  --fs-display: clamp(2.6rem, 5vw, 4.25rem);
  --fs-h1: clamp(2.1rem, 3.6vw, 3rem);
  --fs-h2: clamp(1.7rem, 2.6vw, 2.25rem);
  --fs-h3: 1.5rem;
  --fs-h4: 1.25rem;
  --fs-lead: 1.25rem;
  --fs-body: 1.0625rem;
  --fs-sm: 0.9375rem;
  --fs-xs: 0.8125rem;
  --fs-eyebrow: 0.875rem;

  --lh-tight: 1.15;
  --lh-snug: 1.35;
  --lh-body: 1.7;
  --lh-loose: 1.85;

  --ls-eyebrow: 0.14em;
  --ls-tight: -0.01em;
  --ls-wordmark: 0.02em;

  /* —— Spacing & layout —— */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;
  --sp-8: 64px;
  --sp-9: 96px;
  --sp-10: 128px;

  --section-y: clamp(64px, 9vw, 128px);
  --section-y-tight: clamp(40px, 6vw, 80px);

  --container: 1200px;
  --container-wide: 1320px;
  --container-narrow: 760px;

  --gutter: clamp(20px, 5vw, 64px);

  /* —— Effects —— */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --r-2xl: 44px;
  --r-pill: 999px;
  --r-blob: 48% 52% 60% 40% / 55% 45% 55% 45%;

  --shadow-xs: 0 1px 2px rgba(74, 70, 60, 0.06);
  --shadow-sm: 0 4px 14px rgba(74, 70, 60, 0.07);
  --shadow-md: 0 10px 30px rgba(74, 70, 60, 0.10);
  --shadow-lg: 0 22px 50px rgba(59, 74, 48, 0.14);
  --shadow-soft: 0 16px 40px -12px rgba(120, 100, 60, 0.18);
  --shadow-gold: 0 8px 28px -6px rgba(184, 146, 78, 0.40);
  --shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.5);

  --grad-sage: linear-gradient(135deg, #eef0e3 0%, #f6f0e4 100%);
  --grad-warm: linear-gradient(135deg, #faf6ee 0%, #f2e7d6 100%);
  --grad-glow: radial-gradient(circle at 50% 40%, rgba(201,168,95,0.28) 0%, rgba(201,168,95,0) 62%);
  --grad-footer: linear-gradient(170deg, #45572f 0%, #2f3d27 100%);
  --grad-clay: linear-gradient(135deg, #c47a4f 0%, #b5663f 100%);

  --ease-soft: cubic-bezier(0.33, 0.8, 0.35, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast: 160ms;
  --dur-base: 280ms;
  --dur-slow: 600ms;
  --lift: translateY(-4px);

  /* Document defaults */
  font-family: var(--font-body);
  color: var(--text-body);
  font-size: 16px;
}

@keyframes fengfu-breathe {
  0%, 100% { transform: scale(1); opacity: 0.85; }
  50% { transform: scale(1.04); opacity: 1; }
}
@keyframes fengfu-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* ---------- 3. Base / layout ---------- */
html { scroll-behavior: smooth; }
body { margin: 0; }

#ff-blog-root {
  background: var(--surface-page);
  color: var(--text-body);
  font-family: var(--font-body);
  min-height: 100vh;
  overflow-x: hidden;
}

.container {
  position: relative;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
  z-index: 2;
}

.section { position: relative; background: var(--surface-page); overflow: hidden; }

/* ---------- 4. Components ---------- */

/* Logo */
.logo {
  --logo-size: 34px;
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: calc(var(--logo-size) * 0.32);
  text-decoration: none;
}
.logo__mark {
  width: calc(var(--logo-size) * 1.15);
  height: calc(var(--logo-size) * 1.15);
  flex-shrink: 0;
}
.logo__word { display: flex; flex-direction: column; line-height: 1; }
.logo__name {
  font-family: var(--font-accent);
  font-weight: 600;
  font-size: calc(var(--logo-size) * 0.82);
  color: var(--green-800);
  letter-spacing: var(--ls-wordmark);
}
.logo__name sup { font-size: 0.42em; vertical-align: super; font-weight: 500; }
.logo__tag {
  font-family: var(--font-body);
  font-size: max(10px, calc(var(--logo-size) * 0.26));
  color: var(--text-muted);
  letter-spacing: 0.02em;
  margin-top: 0.15em;
}
.logo--light .logo__name { color: var(--cream-50); }
.logo--light .logo__tag { color: var(--text-on-dark-muted); }

/* Skip link */
.ff-skip {
  position: fixed;
  top: 10px;
  inset-inline-start: 10px;
  transform: translateY(-160%);
  background: var(--green-800);
  color: var(--cream-50);
  padding: 11px 20px;
  border-radius: var(--r-pill);
  z-index: 300;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  transition: transform .18s var(--ease-out);
}
.ff-skip:focus { transform: translateY(0); outline: 3px solid var(--gold-500); outline-offset: 2px; }

/* Desktop / mobile nav visibility */
.ff-desk { display: block; }
.ff-mob { display: none; }

/* Desktop NavBar */
.navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
  padding: 14px 28px;
  margin: 16px var(--gutter);
  background: color-mix(in srgb, var(--cream-50) 80%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: var(--r-pill);
  box-shadow: var(--shadow-soft);
  position: sticky;
  top: 12px;
  z-index: 50;
}
.navbar__links {
  display: flex;
  align-items: center;
  gap: clamp(12px, 1.8vw, 30px);
  flex-wrap: wrap;
}
.navbar__links a {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--text-body);
  text-decoration: none;
  position: relative;
  padding-bottom: 4px;
  border-bottom: 2px solid transparent;
  transition: color var(--dur-fast) var(--ease-soft);
}
.navbar__links a:hover { color: var(--green-800); }
.navbar__links a[aria-current="page"] {
  font-weight: 700;
  color: var(--green-800);
  border-bottom-color: var(--gold-600);
}
.navbar__links a:focus-visible { outline: 2px solid var(--gold-600); outline-offset: 4px; border-radius: 4px; }

/* Mobile bar */
.ff-mob {
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: 12px 18px;
  margin: 14px var(--gutter);
  background: color-mix(in srgb, var(--cream-50) 88%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: var(--r-pill);
  box-shadow: var(--shadow-soft);
  position: sticky;
  top: 12px;
  z-index: 50;
}
.ff-burger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: none;
  background: transparent;
  color: var(--green-800);
  cursor: pointer;
  border-radius: var(--r-pill);
}
.ff-burger:focus-visible { outline: 2px solid var(--gold-600); outline-offset: 2px; }

/* Mobile drawer + scrim */
.ff-scrim {
  position: fixed;
  inset: 0;
  background: rgba(47, 61, 39, .45);
  z-index: 120;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .25s var(--ease-out), visibility .25s var(--ease-out);
}
.ff-scrim.ff-open { opacity: 1; visibility: visible; pointer-events: auto; }
.ff-drawer {
  position: fixed;
  top: 0;
  inset-inline-end: 0;
  height: 100%;
  width: min(84vw, 340px);
  background: var(--cream-50);
  z-index: 130;
  box-shadow: var(--shadow-lg);
  transform: translateX(110%);
  visibility: hidden;
  pointer-events: none;
  transition: transform .28s var(--ease-out), visibility .28s var(--ease-out);
  display: flex;
  flex-direction: column;
  padding: var(--sp-6);
  box-sizing: border-box;
  overflow-y: auto;
}
.ff-drawer.ff-open { transform: translateX(0); visibility: visible; pointer-events: auto; }
.ff-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-5);
}
.ff-link {
  display: flex;
  align-items: center;
  min-height: 50px;
  padding: 6px 12px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.2rem;
  color: var(--green-700);
  text-decoration: none;
  border-radius: 14px;
  border-inline-start: 3px solid transparent;
  transition: background .15s var(--ease-out), color .15s;
}
.ff-link:hover { background: var(--green-50); }
.ff-link:focus-visible { outline: 2px solid var(--gold-600); outline-offset: 2px; }
.ff-link[aria-current="page"] {
  color: var(--green-900);
  font-weight: 700;
  background: var(--green-50);
  border-inline-start-color: var(--gold-600);
}
.ff-close {
  width: 44px;
  height: 44px;
  border: none;
  background: transparent;
  color: var(--green-800);
  cursor: pointer;
  border-radius: var(--r-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ff-close:focus-visible { outline: 2px solid var(--gold-600); outline-offset: 2px; }
.ff-drawer__cta { margin-top: auto; padding-top: var(--sp-5); }

/* Eyebrow */
.eyebrow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6em;
  color: var(--green-600);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
}
.eyebrow--start { justify-content: flex-start; }
.eyebrow--clay { color: var(--clay-600); }
.eyebrow--gold { color: var(--gold-700); }
.eyebrow__leaf { width: 18px; height: 18px; flex-shrink: 0; }
.eyebrow::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cpath d='M32 58 V28' stroke='%233b4a30' stroke-width='2.4' stroke-linecap='round'/%3E%3Cpath d='M32 30 C29 24 29 18 32 12 C35 18 35 24 32 30 Z' fill='%235b6b3c'/%3E%3Cpath d='M31 34 C24 33 18 28 15 20 C23 20 30 24 32 32 Z' fill='%237c8a54'/%3E%3Cpath d='M33 34 C40 33 46 28 49 20 C41 20 34 24 32 32 Z' fill='%237c8a54'/%3E%3Cpath d='M31 42 C26 42 21 39 18 33 C24 33 30 36 32 41 Z' fill='%23a9b388'/%3E%3Cpath d='M33 42 C38 42 43 39 46 33 C40 33 34 36 32 41 Z' fill='%23a9b388'/%3E%3C/svg%3E") center/contain no-repeat;
}
/* When an explicit inline leaf is present, suppress the pseudo leaf */
.eyebrow:has(.eyebrow__leaf)::before { display: none; }

/* Badge */
.badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-body);
  font-weight: 600;
  border-radius: var(--r-pill);
  line-height: 1.2;
  padding: 5px 14px;
  font-size: 0.82rem;
}
.badge--sage { background: var(--green-50); color: var(--green-700); }
.badge--clay { background: var(--clay-100); color: var(--clay-700); }
.badge--gold { background: var(--gold-100); color: var(--gold-700); }

/* Button */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-family: var(--font-body);
  font-weight: 600;
  line-height: 1;
  border-radius: var(--r-pill);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  border: 1px solid transparent;
  transition: transform var(--dur-fast) var(--ease-soft),
              box-shadow var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out);
}
.btn--sm { padding: 9px 18px; font-size: 0.9rem; }
.btn--md { padding: 13px 28px; font-size: 1rem; }
.btn--lg { padding: 16px 36px; font-size: 1.0625rem; }
.btn--primary { background: var(--green-800); color: var(--cream-50); border-color: var(--green-800); box-shadow: var(--shadow-sm); }
.btn--gold { background: var(--gold-600); color: var(--cream-50); border-color: var(--gold-600); box-shadow: var(--shadow-sm); }
.btn--accent { background: var(--clay-600); color: var(--cream-50); border-color: var(--clay-600); box-shadow: var(--shadow-sm); }
.btn--outline { background: transparent; color: var(--clay-700); border: 1.5px solid var(--clay-500); }
.btn--outline-green { background: transparent; color: var(--green-800); border: 1.5px solid var(--green-600); }
.btn--ghost { background: transparent; color: var(--green-800); border: 1px solid transparent; }
.btn:hover { transform: translateY(-2px); }
.btn--primary:hover, .btn--gold:hover, .btn--accent:hover { box-shadow: var(--shadow-gold); }
.btn--outline:hover { background: color-mix(in srgb, var(--clay-100) 60%, transparent); }
.btn--ghost:hover { background: var(--green-50); }
.btn:active { transform: scale(0.97); }
.btn:focus-visible { outline: 2px solid var(--gold-600); outline-offset: 2px; }
.btn--block { width: 100%; justify-content: center; }
.btn__icon { display: inline-flex; transition: transform var(--dur-base) var(--ease-out); }
.btn:hover .btn__icon { transform: translateX(3px); }

/* FeatureCard */
.card {
  display: flex;
  flex-direction: column;
  background: var(--surface-card);
  border-radius: var(--r-xl);
  border: 1px solid var(--border-hair);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  transition: transform var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
}
.card:hover { box-shadow: var(--shadow-lg); transform: var(--lift); }
.card__media {
  position: relative;
  height: 180px;
  margin: 10px 10px 0;
  border-radius: var(--r-lg);
  overflow: hidden;
}
.card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1);
  transition: transform var(--dur-slow) var(--ease-out);
}
.card:hover .card__media img { transform: scale(1.05); }
.card__body {
  padding: 26px 28px 30px;
  display: flex;
  flex-direction: column;
  gap: 0.7em;
  flex: 1;
  position: relative;
}
.card__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-h3);
  color: var(--green-700);
  margin: 0;
  line-height: 1.25;
}
.card__title--clay { color: var(--clay-600); }
.card__title--gold { color: var(--gold-700); }
.card__text {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--text-body);
  line-height: var(--lh-body);
  margin: 0;
  flex: 1;
}
.card__meta {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--text-muted);
  margin: 0.2em 0 0;
}
.card__rule { height: 1px; background: var(--border-soft); margin: 0.6em 0 0.1em; }
.card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-sm);
  color: var(--green-700);
  text-decoration: none;
  margin-top: 0.3em;
}
.card__cta--clay { color: var(--clay-600); }
.card__cta--gold { color: var(--gold-700); }
.card__cta-arrow { transition: transform var(--dur-base) var(--ease-out); }
.card:hover .card__cta-arrow { transform: translateX(-4px); }

/* Footer */
.footer { background: var(--grad-footer); color: var(--text-on-dark); }
.footer__grid {
  max-width: var(--container);
  margin: 0 auto;
  padding: var(--sp-9) var(--gutter) var(--sp-6);
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
  gap: var(--sp-7);
  align-items: start;
}
.footer__brand { display: flex; flex-direction: column; gap: 1em; max-width: 280px; }
.footer__about {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--text-on-dark-muted);
  line-height: var(--lh-body);
  margin: 0;
}
.footer__social { display: flex; gap: 0.6em; }
.footer__social a {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--cream-50) 14%, transparent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--cream-50);
}
.footer__col { display: flex; flex-direction: column; gap: 0.7em; }
.footer__col h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  color: var(--cream-50);
  margin: 0;
}
.footer__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.55em; }
.footer__list--offset { margin-top: 1.7em; }
.footer a.footer__link {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--text-on-dark-muted);
  text-decoration: none;
}
.footer a.footer__link:hover { color: var(--cream-50); }
.footer__contact a {
  display: flex;
  gap: 0.5em;
  align-items: center;
}
.footer__quote {
  margin: 0.6em 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-sm);
  color: var(--text-on-dark);
  line-height: 1.6;
  border-inline-start: 2px solid var(--gold-500);
  padding-inline-start: 0.9em;
}
.footer__bottom { border-top: 1px solid color-mix(in srgb, var(--cream-50) 14%, transparent); }
.footer__bottom-inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: var(--sp-4) var(--gutter);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1em;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--text-on-dark-muted);
}
.footer__legal { display: flex; gap: 1.4em; }

/* ---------- 5. Page sections ---------- */

/* Hero */
.hero { padding: var(--sp-7) 0 var(--sp-6); }
.hero__blob {
  position: absolute;
  width: 420px;
  height: 420px;
  background: var(--green-100);
  border-radius: var(--r-blob);
  filter: blur(2px);
  opacity: .5;
  pointer-events: none;
  top: -160px;
  inset-inline-start: -160px;
}
.hero__inner { text-align: center; max-width: 760px; margin: 0 auto; }
.hero__eyebrow-wrap { display: flex; justify-content: center; }
.hero h1 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: var(--fs-h1);
  color: var(--green-700);
  margin: .3em 0 .4em;
}
.hero__lead {
  font-family: var(--font-body);
  font-size: var(--fs-lead);
  color: var(--text-body);
  line-height: var(--lh-body);
  margin: 0 auto;
  max-width: 58ch;
}
.hero__tags {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
}

/* Articles */
.articles { padding: var(--section-y-tight) 0 var(--section-y); }
.articles__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
  align-items: stretch;
}

/* Newsletter */
.newsletter { padding: 0 0 var(--section-y); }
.newsletter__panel {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp-7);
  align-items: center;
  background: var(--surface-sand);
  border: 1px solid var(--border-hair);
  border-radius: var(--r-2xl);
  padding: var(--sp-7);
  box-shadow: var(--shadow-soft);
}
.newsletter__text { text-align: right; }
.newsletter__text h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-h2);
  color: var(--green-700);
  margin: .3em 0 .35em;
}
.newsletter__text p {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--text-body);
  line-height: var(--lh-body);
  margin: 0;
  max-width: 48ch;
}
.newsletter__form { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.newsletter__form input {
  flex: 1;
  min-width: 200px;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--text-body);
  background: var(--surface-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-pill);
  padding: 14px 22px;
  outline: none;
}
.newsletter__form input:focus-visible { border-color: var(--gold-600); box-shadow: 0 0 0 3px var(--focus-ring); }

/* ============================================================
   Additional design-system components (used across pages)
   ============================================================ */

/* IconMedallion */
.medallion {
  --med-size: 64px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--med-size);
  height: var(--med-size);
  border-radius: var(--r-pill);
  flex-shrink: 0;
}
.medallion--sage { background: var(--green-50); color: var(--green-700); }
.medallion--clay { background: var(--clay-100); color: var(--clay-700); }
.medallion--gold { background: var(--gold-100); color: var(--gold-700); }
.medallion--teal { background: var(--teal-100); color: var(--teal-600); }
.medallion--solidGreen { background: var(--green-800); color: var(--cream-50); }
.medallion--solidClay { background: var(--clay-600); color: var(--cream-50); }

/* Divider with centred leaf */
.divider { display: flex; align-items: center; gap: 1em; width: 100%; }
.divider__line { flex: 1; height: 1px; background: var(--border-soft); }
.divider__leaf { width: 18px; height: 18px; flex-shrink: 0; }

/* StatBlock */
.stat { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.4em; }
.stat__value {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 3.4vw, 2.75rem);
  color: var(--green-700);
  line-height: 1;
}
.stat__label {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--text-muted);
  line-height: 1.4;
  max-width: 16ch;
}
.stat .medallion { margin-bottom: 0.3em; }

/* Card icon (FeatureCard with Lucide medallion) */
.card__icon {
  width: 60px;
  height: 60px;
  border-radius: var(--r-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--cream-50);
  box-shadow: var(--shadow-md);
}
.card__icon--green { background: var(--green-800); }
.card__icon--clay { background: var(--clay-600); }
.card__icon--gold { background: var(--gold-600); }
.card__icon--static { margin-bottom: 0.2em; }
.card__icon--float { position: absolute; top: -34px; inset-inline-start: 28px; }
.card__title--pushed { margin-top: 0.8em; }

/* FSL Pillar */
.fsl-pillar {
  position: relative;
  background: var(--surface-card);
  border-radius: var(--r-xl);
  border: 1px solid var(--border-hair);
  padding: 52px 30px 34px;
  margin-top: 38px;
  text-align: center;
  box-shadow: var(--shadow-soft);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.fsl-pillar:hover { box-shadow: var(--shadow-lg); transform: var(--lift); }
.fsl-pillar__letter {
  position: absolute;
  top: -38px;
  inset-inline-start: 50%;
  transform: translateX(50%);
  width: 76px;
  height: 76px;
  border-radius: var(--r-pill);
  color: var(--cream-50);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-accent);
  font-weight: 600;
  font-size: 2.2rem;
  border: 4px solid var(--surface-card);
}
.fsl-pillar__latin { font-family: var(--font-accent); font-weight: 600; font-size: 1.9rem; margin: 6px 0 2px; letter-spacing: 0.01em; }
.fsl-pillar__he { font-family: var(--font-display); font-weight: 500; font-size: 1.05rem; color: var(--green-700); margin: 0 0 14px; }
.fsl-pillar__rule { display: block; width: 44px; height: 1px; background: var(--border-soft); margin: 0 auto 16px; }
.fsl-pillar__body { font-family: var(--font-body); font-size: var(--fs-body); color: var(--text-body); line-height: var(--lh-body); margin: 0; }
.fsl-pillar__icon { display: inline-flex; align-items: center; justify-content: center; width: 64px; height: 64px; border-radius: var(--r-pill); margin-top: 22px; }
.fsl-pillar--F .fsl-pillar__letter { background: var(--green-600); box-shadow: 0 10px 24px -8px var(--green-600); }
.fsl-pillar--F .fsl-pillar__latin { color: var(--green-600); }
.fsl-pillar--F .fsl-pillar__icon { background: var(--green-50); color: var(--green-600); }
.fsl-pillar--S .fsl-pillar__letter { background: var(--clay-600); box-shadow: 0 10px 24px -8px var(--clay-600); }
.fsl-pillar--S .fsl-pillar__latin { color: var(--clay-600); }
.fsl-pillar--S .fsl-pillar__icon { background: var(--clay-100); color: var(--clay-600); }
.fsl-pillar--L .fsl-pillar__letter { background: var(--green-800); box-shadow: 0 10px 24px -8px var(--green-800); }
.fsl-pillar--L .fsl-pillar__latin { color: var(--green-800); }
.fsl-pillar--L .fsl-pillar__icon { background: var(--green-50); color: var(--green-800); }

/* FSL Orbit */
.orbit { position: relative; width: 100%; max-width: 500px; aspect-ratio: 1; margin: 0 auto; }
.orbit__glow { position: absolute; inset: 12%; border-radius: 50%; background: var(--grad-glow); }
.orbit__svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.orbit__center {
  position: absolute; top: 50%; inset-inline-start: 50%;
  transform: translate(50%, -50%);
  width: 30%; height: 30%;
  border-radius: 50%;
  background: var(--grad-footer);
  color: var(--cream-50);
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-lg);
  animation: fengfu-breathe 6s var(--ease-soft) infinite;
}
.orbit__center span { font-family: var(--font-accent); font-weight: 600; font-size: clamp(1.4rem, 5vw, 2.4rem); }
.orbit__center sup { font-size: 0.4em; vertical-align: super; }
.orbit__node { position: absolute; transform: translate(50%, -50%); text-align: center; }
.orbit__disc {
  display: flex; align-items: center; justify-content: center;
  width: clamp(48px, 12vw, 76px); height: clamp(48px, 12vw, 76px);
  border-radius: 50%; margin: 0 auto;
  box-shadow: var(--shadow-sm);
  border: 2px solid var(--surface-card);
}
.orbit__dot { width: 12px; height: 12px; border-radius: 50%; }
.orbit__label { font-family: var(--font-display); font-weight: 700; font-size: 0.92rem; color: var(--green-800); margin-top: 6px; }
.orbit__sub { font-family: var(--font-body); font-size: 0.72rem; color: var(--text-muted); }
.orbit__node--sage .orbit__disc { background: var(--green-100); color: var(--green-800); }
.orbit__node--sage .orbit__dot { background: var(--green-600); }
.orbit__node--teal .orbit__disc { background: var(--teal-100); color: var(--teal-600); }
.orbit__node--teal .orbit__dot { background: var(--teal-400); }
.orbit__node--clay .orbit__disc { background: var(--clay-100); color: var(--clay-700); }
.orbit__node--clay .orbit__dot { background: var(--clay-600); }
.orbit__node--gold .orbit__disc { background: var(--gold-100); color: var(--gold-700); }
.orbit__node--gold .orbit__dot { background: var(--gold-600); }

/* ============================================================
   Page section helpers
   ============================================================ */
.bg-sand { background: var(--surface-sand); }
.section--y { padding: var(--section-y) 0; }
.section--y-tight { padding: var(--section-y-tight) 0 var(--section-y); }
.container--narrow { max-width: var(--container-narrow); }
.text-center { text-align: center; }
.text-right { text-align: right; }
.section__head { text-align: center; max-width: 720px; margin: 0 auto var(--sp-7); }
.section__head .eyebrow { justify-content: center; }
.h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-h2); color: var(--green-700); margin: .3em 0 .4em; line-height: 1.2; }
.lead-line { font-family: var(--font-display); font-weight: 500; font-size: 1.15rem; color: var(--green-800); }
.body-text { font-family: var(--font-body); font-size: var(--fs-body); color: var(--text-body); line-height: var(--lh-body); }
.muted-sm { font-family: var(--font-body); font-size: var(--fs-sm); color: var(--text-muted); }

/* blobs / glow decor */
.blob { position: absolute; border-radius: var(--r-blob); filter: blur(2px); opacity: .5; pointer-events: none; }
.blob--green { background: var(--green-100); }
.blob--clay { background: var(--clay-100); }
.blob--gold { background: var(--gold-100); }
.glow { position: absolute; background: var(--grad-glow); pointer-events: none; }

/* page hero (centered) */
.page-hero { padding: var(--sp-7) 0 var(--sp-6); }
.page-hero__inner { text-align: center; max-width: 760px; margin: 0 auto; }
.page-hero h1 { font-family: var(--font-display); font-weight: 900; font-size: var(--fs-h1); color: var(--green-700); margin: .3em 0 .4em; }
.page-hero__lead { font-family: var(--font-body); font-size: var(--fs-lead); color: var(--text-body); line-height: var(--lh-body); margin: 0 auto; max-width: 56ch; }

/* generic two-column split */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-8); align-items: center; }
.split__media { position: relative; display: flex; justify-content: center; }
.split__text { text-align: right; }
.media-frame { position: relative; width: 100%; overflow: hidden; box-shadow: var(--shadow-lg); border: 6px solid var(--cream-50); }
.media-frame--blob { border-radius: var(--r-blob); }
.media-frame--soft { border-radius: var(--r-2xl); box-shadow: var(--shadow-soft); border: none; }
.media-frame--round { border-radius: 50%; }
.media-frame img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* home hero */
.home-hero { padding: var(--sp-8) 0 var(--section-y); }
.home-hero__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: var(--sp-8); align-items: center; }
.home-hero h1 { font-family: var(--font-display); font-weight: 900; font-size: var(--fs-display); color: var(--green-700); line-height: 1.08; margin: .3em 0 .35em; }

/* highlights glass strip */
.hl-strip {
  position: relative; margin-top: var(--sp-7);
  background: color-mix(in srgb, var(--cream-50) 80%, transparent);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--border-hair); border-radius: var(--r-2xl);
  box-shadow: var(--shadow-soft); padding: var(--sp-5) var(--sp-6);
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-5);
}
.hl-item { display: flex; align-items: center; gap: var(--sp-3); }
.hl-item + .hl-item { border-inline-start: 1px solid var(--border-soft); padding-inline-start: var(--sp-5); }
.hl-item span { font-family: var(--font-body); font-size: var(--fs-sm); color: var(--text-body); line-height: 1.4; font-weight: 500; }

/* value row (about) */
.value-row { display: flex; justify-content: center; gap: var(--sp-7); flex-wrap: wrap; }
.value-item { display: flex; flex-direction: column; align-items: center; gap: var(--sp-3); }
.value-item span { font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; color: var(--green-800); }

/* numbered steps (about) */
.steps { display: flex; flex-direction: column; gap: var(--sp-5); }
.step { display: flex; gap: var(--sp-5); align-items: flex-start; background: var(--surface-card); border: 1px solid var(--border-hair); border-radius: var(--r-xl); padding: var(--sp-5) var(--sp-6); box-shadow: var(--shadow-sm); }
.step__num { font-family: var(--font-accent); font-weight: 600; font-size: 2.4rem; line-height: 1; flex-shrink: 0; }
.step__num--green { color: var(--green-300); }
.step__num--clay { color: var(--clay-300); }
.step__num--gold { color: var(--gold-300); }
.step h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: var(--green-800); margin: 0 0 .25em; }

/* feature row card (icon + text) used by FSL who-it-fits */
.feature-row { display: flex; gap: var(--sp-4); background: var(--surface-card); border: 1px solid var(--border-hair); border-radius: var(--r-xl); padding: var(--sp-5); box-shadow: var(--shadow-sm); }
.feature-row h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: var(--green-800); margin: 0 0 .3em; }

/* centered icon feature (why it works / process) */
.icon-feature { text-align: center; }
.icon-feature .medallion { margin: 0 auto var(--sp-4); }
.icon-feature h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.25rem; color: var(--green-800); margin: 0 0 .35em; }
.icon-feature p { margin: 0 auto; max-width: 30ch; }

/* simple tile (audiences / process step) */
.tile { text-align: center; }
.tile .medallion { margin: 0 auto var(--sp-3); }
.tile h3, .tile span.tile__label { font-family: var(--font-display); font-weight: 700; color: var(--green-800); display: block; }
.tile--card { background: var(--surface-card); border: 1px solid var(--border-hair); border-radius: var(--r-xl); padding: var(--sp-6) var(--sp-4); box-shadow: var(--shadow-sm); }

/* checklist (training) */
.check-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--sp-4); }
.check-list li { display: flex; gap: var(--sp-3); align-items: flex-start; }
.check-list__leaf { flex-shrink: 0; margin-top: 2px; width: 18px; height: 18px; }

/* grids */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-6); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); align-items: stretch; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-6); }
.grid--center { align-items: center; }

/* CTA band (forest green) */
.cta-band { position: relative; background: var(--grad-footer); color: var(--cream-50); border-radius: var(--r-2xl); padding: var(--sp-8) var(--sp-7); text-align: center; overflow: hidden; }
.cta-band h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-h2); margin: 0 0 .4em; color: var(--cream-50); }
.cta-band p { font-family: var(--font-body); font-size: var(--fs-body); color: var(--text-on-dark-muted); margin: 0 auto 1.5em; max-width: 48ch; line-height: var(--lh-body); }
.cta-band__actions { display: flex; justify-content: center; }

/* note strip (programs / how-we-work) */
.note-strip { text-align: center; background: var(--surface-card); border-radius: var(--r-xl); border: 1px solid var(--border-hair); padding: var(--sp-5) var(--sp-6); box-shadow: var(--shadow-sm); }

/* contact */
.contact-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--sp-8); align-items: start; }
.contact-form { background: var(--surface-card); border: 1px solid var(--border-hair); border-radius: var(--r-2xl); padding: var(--sp-7); box-shadow: var(--shadow-soft); }
.contact-form h2 { font-family: var(--font-display); font-weight: 700; font-size: 1.5rem; color: var(--green-700); margin: 0 0 .8em; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.field { display: flex; flex-direction: column; gap: .4em; }
.field--full { grid-column: 1 / -1; }
.field label { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; color: var(--green-800); }
.ff-field { font-family: var(--font-body); font-size: var(--fs-body); color: var(--text-body); background: var(--surface-card); border: 1px solid var(--border-soft); border-radius: 16px; padding: 13px 18px; outline: none; width: 100%; box-sizing: border-box; }
.ff-field:focus { border-color: var(--gold-500); box-shadow: 0 0 0 3px var(--focus-ring); }
.contact-info { display: flex; flex-direction: column; gap: var(--sp-5); }
.info-row { display: flex; gap: var(--sp-4); align-items: center; }
.info-row__label { font-family: var(--font-body); font-size: var(--fs-xs); color: var(--text-muted); }
.info-row a, .info-row__value { font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; color: var(--green-800); text-decoration: none; }
.info-card { background: var(--grad-footer); color: var(--cream-50); border-radius: var(--r-xl); padding: var(--sp-6); margin-top: var(--sp-2); }
.info-card p:first-child { font-family: var(--font-display); font-weight: 500; font-size: 1.1rem; line-height: 1.6; margin: 0 0 .6em; color: var(--cream-50); }
.info-card p:last-child { font-family: var(--font-body); font-size: var(--fs-sm); color: var(--text-on-dark-muted); line-height: var(--lh-body); margin: 0; }

/* ---------- 6. Responsive ---------- */
@media (max-width: 880px) {
  .articles__grid { grid-template-columns: 1fr; }
  .newsletter__panel { grid-template-columns: 1fr; }
  .newsletter__text { text-align: center; }
  .newsletter__text .eyebrow { justify-content: center; }
  .ff-desk { display: none; }
  .ff-mob { display: flex; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--sp-6); }
  .footer__bottom-inner { justify-content: center; text-align: center; }

  .home-hero__grid, .split, .grid-2, .grid-3, .contact-grid, .form-grid { grid-template-columns: 1fr; }
  .grid-4, .hl-strip, .grid--mid2 { grid-template-columns: repeat(2, 1fr); }
  .hl-item + .hl-item { border-inline-start: 0; padding-inline-start: 0; }
}
@media (max-width: 620px) {
  .footer__grid { grid-template-columns: 1fr; }
  .footer__list--offset { margin-top: 0; }
}
@media (max-width: 540px) {
  .grid-4, .hl-strip, .grid--mid2 { grid-template-columns: 1fr; }
}
