.checkout-button_wrapper__cv4SD {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}

.checkout-button_error__9Ttcs {
  font-size: 13px;
  color: var(--c-red);
  text-align: center;
}

.marketing-pill_pill__tG7Xc {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--c-green-faint);
  color: var(--c-green-dark);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid var(--c-green-dark);
  border-color: color-mix(in srgb, var(--c-green-dark) 18%, transparent);
}

.marketing-pill_icon__4xKte {
  font-size: 15px;
  line-height: 1;
}

.marketing-pill_message__ehI72 {
  letter-spacing: 0.005em;
}

.page_page__BwVZt {
  min-height: 100vh;
}

.page_header__9vm19 {
  background: var(--surface-hero);
  padding: calc(var(--nav-height) + 80px) var(--page-gutter) 64px;
  text-align: center;
}

.page_eyebrow__ulh9s {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-wood-oak);
  margin-bottom: 16px;
}

.page_heading__juub_ {
  font-family: var(--font-heading);
  font-size: clamp(30px, 4vw, 48px);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.025em;
  line-height: 1.15;
  margin-bottom: 20px;
}

.page_subheading__WZPEq {
  font-size: 18px;
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.6;
  max-width: 480px;
  margin: 0 auto;
}

.page_section___pU3S {
  padding: 64px var(--page-gutter) 96px;
  background: var(--c-cream-light);
  display: flex;
  gap: 64px;
  max-width: 960px;
  margin: 0 auto;
  align-items: start;
}

/* ── Pricing card ── */
.page_card__eDVTs {
  flex: 0 0 360px;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: 16px;
  padding: 36px 32px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: sticky;
  top: calc(var(--nav-height) + 24px);
}

.page_cardHeader__1JTf_ {
  border-bottom: 1px solid var(--c-border);
  padding-bottom: 20px;
}

.page_planName__KlOLu {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-wood-oak);
  margin-bottom: 12px;
}

.page_priceRow__bABWw {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-bottom: 8px;
}

.page_price__JWROA {
  font-family: var(--font-heading);
  font-size: 48px;
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.03em;
  line-height: 1;
}

.page_period__AkqaS {
  font-size: 16px;
  font-weight: 300;
  color: var(--c-light-mute);
}

.page_priceNote__3JR1f {
  font-size: 13px;
  font-weight: 300;
  color: var(--c-light-mute);
}

/* ── Feature list ── */
.page_featureList__VBxAT {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.page_featureItem__3nWVL {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.4;
}

.page_featureCheck__KuJfq {
  color: var(--c-green-dark);
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Staff / existing-member notice (replaces CheckoutButton) ── */
.page_staffNotice__JnNx1 {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  background: var(--c-cream-light);
  border: 1px solid var(--c-border);
  border-radius: 10px;
  padding: 16px;
  text-align: center;
}

.page_staffNoticeText__XLwJm {
  font-size: 13px;
  font-weight: 400;
  color: var(--c-light-body);
  line-height: 1.5;
}

.page_staffNoticeBtn__WQh6E {
  display: block;
  padding: 11px 16px;
  background: var(--c-navy);
  color: var(--c-cream);
  border-radius: 9px;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  text-transform: capitalize;
  text-decoration: none;
}

.page_staffNoticeBtn__WQh6E:hover {
  background: #1a2a3a;
}

/* ── Guarantee ── */
.page_guarantee__r4hQd {
  font-size: 12px;
  font-weight: 300;
  color: var(--c-light-mute);
  text-align: center;
  line-height: 1.5;
}

.page_guaranteeLink__hkdQm {
  color: var(--c-green-dark);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ── FAQ ── */
.page_faq__A99Jl {
  flex: 1 1;
  min-width: 0;
}

.page_faqHeading__Aq1mo {
  font-family: var(--font-heading);
  font-size: 22px;
  font-weight: 500;
  color: var(--c-light-head);
  margin-bottom: 28px;
  letter-spacing: -0.01em;
}

.page_faqItem__MUxjB {
  border-top: 1px solid var(--c-border);
  padding: 20px 0;
}

.page_faqQ__bWnkp {
  font-size: 15px;
  font-weight: 500;
  color: var(--c-light-head);
  margin-bottom: 8px;
}

.page_faqA__SqJXg {
  font-size: 14px;
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.65;
}

.page_faqLink__egXX6 {
  color: var(--c-green-dark);
  text-decoration: underline;
  text-underline-offset: 2px;
}

@media (max-width: 768px) {
  .page_section___pU3S {
    flex-direction: column;
    padding-top: 40px;
  }

  .page_card__eDVTs {
    flex: none;
    width: 100%;
    position: static;
  }
}

.post-checkout-banner_banner__1SALU {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  max-width: 720px;
  margin: 0 auto 24px;
  padding: 14px 18px;
  border-radius: 12px;
  border: 1px solid;
  background: #fff;
}

.post-checkout-banner_bannerPending__S6XWS {
  background: rgba(185, 130, 40, 0.06);
  border-color: rgba(185, 130, 40, 0.22);
}

.post-checkout-banner_bannerSuccess__UhB9Q {
  background: rgba(34, 110, 60, 0.06);
  border-color: rgba(34, 110, 60, 0.22);
}

.post-checkout-banner_bannerError__fmR5w {
  background: rgba(160, 40, 40, 0.06);
  border-color: rgba(160, 40, 40, 0.22);
}

.post-checkout-banner_dot__ce8w_ {
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-top: 6px;
}

.post-checkout-banner_bannerPending__S6XWS .post-checkout-banner_dot__ce8w_ {
  background: #b98228;
  animation: post-checkout-banner_pulse__Hc7iW 1.6s ease-in-out infinite;
}

.post-checkout-banner_bannerSuccess__UhB9Q .post-checkout-banner_dot__ce8w_ {
  background: var(--c-green-dark);
}

.post-checkout-banner_bannerError__fmR5w .post-checkout-banner_dot__ce8w_ {
  background: var(--c-red);
}

@keyframes post-checkout-banner_pulse__Hc7iW {
  0%, 100% { opacity: 0.5; }
  50%      { opacity: 1; }
}

.post-checkout-banner_body__3uDfd {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.post-checkout-banner_text__gA5BX,
.post-checkout-banner_title__Rulk_ {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--c-light-head);
}

.post-checkout-banner_detail__bZRjQ {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 300;
  color: var(--c-light-mute);
  line-height: 1.5;
}

.post-checkout-banner_link__NokrY {
  color: var(--c-green-dark);
  font-weight: 500;
}

.post-checkout-banner_link__NokrY:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ──────────────────────────────────────────────────────────────────────────
 * Landing-page typography: prevent widows/orphans across every text block.
 * `pretty` (body text) keeps the last line from stranding a single word;
 * `balance` (headings) evens multi-line title wrap. Both are inherited, so
 * setting them on the section containers cascades to descendants.
 * ────────────────────────────────────────────────────────────────────────── */
.page_hero__huG5Q,
.page_section__ERoVC,
.page_problemSection__JhYLj {
  text-wrap: pretty;
}

.page_hero__huG5Q h1,
.page_section__ERoVC h2,
.page_section__ERoVC h3,
.page_problemSection__JhYLj h2,
.page_quoteCard__ItdLo p {
  text-wrap: balance;
}

/* ── Hero ── */
.page_hero__huG5Q {
  background: var(--surface-hero);
  padding: calc(var(--nav-height) + 44px + 64px) var(--page-gutter) 96px;
}

.page_heroGrid__97LDE {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 55% 45%;
  gap: 48px;
  align-items: center;
}

.page_heroContent__vVBi0 {
  min-width: 0;
}

.page_heroHeading__73CY5 {
  font-family: var(--font-heading);
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.03em;
  line-height: 1.15;
  margin: 20px 0 14px;
}

/* Hero tagline — the hopeful turn, and the hero's one accent.
   Green is Nari's growth colour, so the single pop of colour lands here,
   on the answer, rather than on the heading's frustration. */
.page_heroTagline__76HKF {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(21px, 2.6vw, 29px);
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--c-green-dark);
  margin: 0 0 22px;
  max-width: 560px;
  text-wrap: balance;
}

/* Progressive enhancement: a slow green shimmer gives the accent quiet life.
   Falls back to solid green-dark where background-clip:text is unsupported. */
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .page_heroTagline__76HKF {
    background: linear-gradient(
      120deg,
      var(--c-green) 0%,
      var(--c-green-dark) 35%,
      var(--c-green) 70%,
      var(--c-green-dark) 100%
    );
    background-size: 250% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    animation: page_heroTaglineShimmer__ljF6N 6s ease-in-out infinite;
  }
}

@keyframes page_heroTaglineShimmer__ljF6N {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@media (prefers-reduced-motion: reduce) {
  .page_heroTagline__76HKF {
    animation: none;
  }
}

.page_heroBody__nhkEj {
  font-family: var(--font-body);
  font-size: clamp(16px, 2vw, 18px);
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.65;
  max-width: 560px;
  margin-bottom: 36px;
}

.page_heroCta___l7nr {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 48px;
}

.page_heroArt__GzjEJ {
  display: flex;
  justify-content: center;
  align-items: center;
}

.page_heroArtImage__O3Ev_ {
  width: 100%;
  height: auto;
  max-width: 480px;
  object-fit: contain;
}

.page_statRow__28K7G {
  margin-top: 8px;
}

.page_statDivider__3O1CS {
  height: 1px;
  background: color-mix(in srgb, var(--c-light-mute) 25%, transparent);
  margin-bottom: 20px;
}

.page_statList__ilRuk {
  display: flex;
  gap: 40px;
  margin: 0;
  padding: 0;
  flex-wrap: nowrap;
}

.page_stat__Pimy4 {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.page_statValue__3yXnZ {
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 500;
  color: var(--c-green);
  letter-spacing: -0.02em;
  margin: 0;
}

.page_statLabel__h15SS {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 400;
  color: var(--c-light-mute);
  letter-spacing: 0.02em;
  margin: 0;
}

/* Supporting paragraph below the hero stat row. Italic + restrained colour
   so it reads as editorial provenance for the numbers above without
   competing with the headline copy. Max-width keeps the line length
   comfortable inside the hero column. */
.page_statDescription__GpDAG {
  margin: 24px 0 0;
  max-width: 64ch;
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.65;
  font-style: italic;
  color: var(--c-light-body);
  opacity: 0.85;
}

@media (max-width: 640px) {
  .page_heroGrid__97LDE {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .page_heroArt__GzjEJ {
    display: none;
  }

  .page_heroCta___l7nr {
    flex-direction: column;
    align-items: stretch;
  }

  .page_heroCta___l7nr > * {
    width: 100%;
    text-align: center;
    justify-content: center;
  }

  .page_statList__ilRuk {
    flex-wrap: wrap;
    gap: 24px;
  }
}

/* ── Sections ── */
.page_section__ERoVC {
  padding: 80px var(--page-gutter);
  background: var(--c-cream-light);
  scroll-margin-top: calc(var(--nav-height) + 44px + 8px);
}

.page_sectionAlt__t5xB9 {
  background: var(--surface-warm);
}

.page_sectionDark__BxMzy {
  background: var(--surface-forest);
}

.page_sectionInner__WHlsH {
  max-width: var(--max-width-wide);
  margin: 0 auto;
}

.page_eyebrow__LCUmw {
  margin-bottom: 14px;
}

.page_sectionHeading__9D2uE {
  font-family: var(--font-heading);
  font-size: clamp(26px, 3.5vw, 38px);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin-bottom: 20px;
  max-width: 640px;
}

.page_sectionHeadingDark__903cF {
  color: var(--c-text);
}

.page_sectionBody__o_0NJ {
  font-size: 16px;
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.7;
  max-width: 600px;
  margin-bottom: 16px;
}

.page_sectionBodyDark__aROFk {
  color: var(--c-text-mute);
}

/* ── Buttons ── */
.page_textLink__NFjPs {
  font-size: 15px;
  font-weight: 400;
  color: var(--c-light-mute);
  transition: color 0.15s;
}

.page_textLink__NFjPs:hover {
  color: var(--c-light-head);
}


/* ── Who Nari Is For ── */
.page_whoInner__fxryf {
  max-width: var(--max-width-wide);
  margin: 0 auto;
}

.page_whoHeader__2gWoB {
  max-width: 720px;
  margin: 0 auto 48px;
  text-align: center;
}

.page_whoHeading__qZCVJ {
  font-family: var(--font-heading);
  font-size: clamp(30px, 4vw, 46px);
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: var(--c-light-head);
  margin: 12px 0 20px;
  text-wrap: balance;
}

.page_whoHeadingAccent__ItDxL {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-warm-amber);
}

.page_whoIntro__ORVdO {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.65;
  color: var(--c-light-body);
  margin: 0 auto;
  max-width: 600px;
  text-wrap: pretty;
}

.page_whoIntroAccent__w0yYP {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

/* ── Featured Parents card ── */
.page_parentsFeature__7eo_U {
  position: relative;
  background: var(--surface-forest);
  border-radius: 20px;
  padding: clamp(36px, 5vw, 64px);
  color: var(--c-text);
  max-width: 960px;
  margin: 0 auto;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(26, 43, 30, 0.04),
    0 24px 60px -24px rgba(26, 43, 30, 0.28);
}

.page_parentsFeature__7eo_U::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 85% 12%,
    color-mix(in srgb, var(--c-warm-amber) 14%, transparent) 0%,
    transparent 55%
  );
  pointer-events: none;
}

.page_parentsFeatureKicker__JHvI9 {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-heading);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-warm-amber);
  margin-bottom: 18px;
}

.page_parentsFeatureIcon__3PlJQ {
  color: var(--c-warm-amber);
}

.page_parentsFeatureTitle__ZXHKc {
  position: relative;
  font-family: var(--font-heading);
  font-size: clamp(32px, 4.2vw, 52px);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--c-text);
  margin: 0 0 20px;
}

.page_parentsFeatureBody__1QuQP {
  position: relative;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.7;
  color: var(--c-text-mute);
  max-width: 620px;
  margin: 0 0 22px;
}

.page_parentsFeatureLetter__qm5m1 {
  position: relative;
  font-family: var(--font-heading);
  font-style: italic;
  font-size: 17px;
  color: var(--c-cream);
  margin: 0 0 20px;
}

.page_parentsFeatureCta__xcH0Z {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-heading);
  font-size: 15px;
  font-weight: 500;
  color: var(--c-warm-amber);
  text-decoration: none;
  padding-bottom: 4px;
  border-bottom: 1px solid color-mix(in srgb, var(--c-warm-amber) 40%, transparent);
  transition: gap 0.2s ease, border-color 0.2s ease;
}

.page_parentsFeatureCta__xcH0Z:hover,
.page_parentsFeatureCta__xcH0Z:focus-visible {
  gap: 14px;
  border-bottom-color: var(--c-warm-amber);
  outline: none;
}

.page_parentsFeatureArrow__E0_mM {
  transition: transform 0.2s ease;
}

.page_parentsFeatureCta__xcH0Z:hover .page_parentsFeatureArrow__E0_mM,
.page_parentsFeatureCta__xcH0Z:focus-visible .page_parentsFeatureArrow__E0_mM {
  transform: translateX(2px);
}

/* ── Philosophy + moments pairing (2-col) ── */
.page_whoPairing__lK1go {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 88px);
  max-width: 1040px;
  margin: 64px auto;
  padding-top: 48px;
  border-top: 1px solid var(--c-border);
  align-items: start;
}

.page_pairingKicker__uEtS8 {
  font-family: var(--font-heading);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-wood-oak);
  margin: 0 0 18px;
}

.page_onePhilosophy__AFx_g {
  margin: 0;
}

.page_onePhilosophyBody__ZUrYh {
  font-family: var(--font-heading);
  font-size: clamp(19px, 1.9vw, 24px);
  font-weight: 400;
  line-height: 1.4;
  color: var(--c-light-head);
  margin: 0;
  letter-spacing: -0.01em;
  text-wrap: pretty;
}

.page_onePhilosophyAccent__ZSIGE {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

/* ── Moments list (editorial, no chrome) ── */
.page_whoMoments___HhK0 {
  min-width: 0;
}

.page_momentsList__1AqZA {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
}

.page_momentRow__CGL9C {
  display: grid;
  grid-template-columns: minmax(160px, 0.9fr) 1fr;
  gap: 20px;
  align-items: baseline;
  padding: 16px 0;
  border-top: 1px solid var(--c-border);
}

.page_momentRow__CGL9C:first-child {
  border-top: none;
  padding-top: 4px;
}

.page_momentRow__CGL9C:last-child {
  padding-bottom: 4px;
}

.page_momentTitle__cowpz {
  font-family: var(--font-heading);
  font-size: 16px;
  font-weight: 500;
  color: var(--c-light-head);
  margin: 0;
  letter-spacing: -0.005em;
}

.page_momentText__dVlXH {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--c-wood-oak);
  margin: 0;
}

.page_whoClose__fJzXe {
  max-width: 640px;
  margin: 48px auto 0;
  text-align: center;
  font-family: var(--font-heading);
  font-size: clamp(16px, 1.7vw, 19px);
  font-weight: 400;
  line-height: 1.5;
  color: var(--c-light-head);
  text-wrap: balance;
}

.page_whoCloseAccent__Kgi1R {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

/* ── Who Nari Is For — motion ── */
@media (prefers-reduced-motion: no-preference) {
  @keyframes page_whoReveal__m3tGG {
    from {
      opacity: 0;
      transform: translateY(24px);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }

  @keyframes page_whoRevealSoft__5GOlh {
    from {
      opacity: 0;
      transform: translateY(12px);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }

  .page_parentsFeature__7eo_U {
    transition: transform 0.35s ease, box-shadow 0.35s ease;
  }

  .page_parentsFeature__7eo_U:hover {
    transform: translateY(-3px);
    box-shadow: 0 1px 2px rgba(26, 43, 30, 0.04),
      0 32px 80px -28px rgba(26, 43, 30, 0.36);
  }

  @supports (animation-timeline: view()) {
    .page_parentsFeature__7eo_U,
    .page_onePhilosophy__AFx_g,
    .page_whoMoments___HhK0,
    .page_whoClose__fJzXe {
      animation: page_whoReveal__m3tGG :local(auto) linear both;
      animation-timeline: view();
      animation-range: entry 0% entry 55%;
    }

    .page_momentRow__CGL9C {
      animation: page_whoRevealSoft__5GOlh :local(auto) linear both;
      animation-timeline: view();
      animation-range: entry 0% entry 65%;
    }

    .page_momentRow__CGL9C:nth-child(1) { animation-range: entry 0% entry 55%; }
    .page_momentRow__CGL9C:nth-child(2) { animation-range: entry 0% entry 62%; }
    .page_momentRow__CGL9C:nth-child(3) { animation-range: entry 0% entry 69%; }
    .page_momentRow__CGL9C:nth-child(4) { animation-range: entry 0% entry 76%; }
  }
}

@media (max-width: 900px) {
  .page_whoPairing__lK1go {
    grid-template-columns: 1fr;
    gap: 40px;
    margin: 48px auto;
    padding-top: 40px;
  }
}

@media (max-width: 640px) {
  .page_whoHeader__2gWoB {
    margin-bottom: 36px;
  }
  .page_parentsFeature__7eo_U {
    padding: 32px 24px;
    border-radius: 16px;
  }
  .page_momentRow__CGL9C {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 14px 0;
  }
}



/* ── The Real Problem ── */
.page_problemSection__JhYLj {
  padding-top: 80px;
  padding-bottom: 72px;
}

.page_problemInner__CogHT {
  max-width: 1040px;
  margin: 0 auto;
}

.page_problemHeader__QJL1c {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 40px;
}

.page_problemHeader__QJL1c .page_eyebrow__LCUmw {
  display: inline-flex;
  margin-bottom: 14px;
}

.page_problemHeading__xxiq9 {
  font-family: var(--font-heading);
  font-size: clamp(32px, 4.6vw, 52px);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.03em;
  line-height: 1.12;
  margin: 0 auto 18px;
  max-width: 720px;
}

.page_problemHeadingAccent__dab_C {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
  position: relative;
  white-space: nowrap;
}

.page_problemHeadingAccent__dab_C::after {
  content: "";
  position: absolute;
  left: 4%;
  right: 4%;
  bottom: -0.08em;
  height: 0.1em;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(100, 130, 44, 0.55) 18%,
    rgba(100, 130, 44, 0.55) 82%,
    transparent 100%
  );
  border-radius: 2px;
  pointer-events: none;
}

.page_problemIntro__1Ij7e {
  font-family: var(--font-body);
  font-size: 17px;
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.65;
  max-width: 560px;
  margin: 0 auto;
}

.page_problemEm__ffJae {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

.page_quoteGrid__w9MKb {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  align-items: stretch;
  gap: 20px;
  margin: 0 0 36px;
  list-style: none;
  padding: 0;
}

.page_quoteCard__ItdLo {
  position: relative;
  background:
    linear-gradient(180deg, #fff 0%, var(--c-cream-light) 100%);
  border: 1px solid var(--c-border);
  border-radius: 16px;
  padding: 20px 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow:
    0 1px 2px rgba(40, 30, 20, 0.04),
    0 8px 24px -16px rgba(40, 30, 20, 0.08);
  transition:
    transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1),
    box-shadow 0.3s ease,
    border-color 0.3s ease;
  overflow: hidden;
}

.page_quoteCard__ItdLo::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in srgb, var(--c-green) 60%, transparent) 50%,
    transparent
  );
  opacity: 0.5;
  transition: opacity 0.3s ease;
}

.page_quoteCard__ItdLo:hover {
  transform: translateY(-4px);
  box-shadow:
    0 1px 2px rgba(40, 30, 20, 0.04),
    0 22px 40px -18px rgba(40, 30, 20, 0.22);
  border-color: color-mix(in srgb, var(--c-green) 30%, var(--c-border));
}

.page_quoteCard__ItdLo:hover::before {
  opacity: 1;
}

.page_quoteCardTop__Jz8ZJ {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: -4px;
}

.page_quoteIndex__HXTIp {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--c-green);
  opacity: 0.65;
}

.page_quoteLeaf__AAXjI {
  color: var(--c-green);
  opacity: 0.35;
}

.page_quoteGlyph__muXgB {
  font-family: var(--font-heading);
  font-size: 48px;
  font-weight: 500;
  line-height: 0.6;
  color: var(--c-green-dark);
  opacity: 0.85;
  margin: 4px 0 -6px;
  -webkit-user-select: none;
          user-select: none;
}

.page_quoteBody__wdzkr {
  position: relative;
  font-family: var(--font-heading);
  font-size: 19px;
  font-weight: 400;
  color: var(--c-light-head);
  line-height: 1.4;
  letter-spacing: -0.01em;
  margin: 0;
  flex: 1 1;
}

.page_quoteDivider__TmEiv {
  display: block;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in srgb, var(--c-wood-oak) 30%, transparent) 50%,
    transparent
  );
  margin: 2px 0;
}

.page_quoteTruth__gnTUz {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  font-style: italic;
  color: var(--c-wood-oak);
  line-height: 1.55;
  margin: 0;
}

.page_quoteTruthDot__iEPMZ {
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--c-wood-oak);
  opacity: 0.75;
  transform: translateY(-2px);
}

.page_problemBand____v9p {
  position: relative;
  background:
    radial-gradient(
      ellipse at top left,
      color-mix(in srgb, var(--c-warm-amber) 8%, transparent),
      transparent 60%
    ),
    var(--surface-forest);
  border: 1px solid rgba(221, 184, 74, 0.14);
  border-radius: 16px;
  padding: 28px 36px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  overflow: hidden;
}

.page_problemBandContent__8bRlc {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  flex: 1 1 460px;
  min-width: 0;
}

.page_problemBandMark__AsZU7 {
  font-family: var(--font-heading);
  font-size: 56px;
  font-weight: 500;
  line-height: 0.7;
  color: var(--c-warm-amber);
  opacity: 0.45;
  margin-top: 6px;
  flex-shrink: 0;
}

.page_problemBandText__Aijtn {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 300;
  color: var(--c-text);
  line-height: 1.6;
  max-width: 640px;
  margin: 0;
}

.page_problemBandEm__iHmHu {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-warm-amber);
}

.page_problemBandBtn__VOgQl {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 11px;
  font-weight: 600;
  padding: 11px 18px;
  color: var(--c-cream) !important;
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(221, 184, 74, 0.55) !important;
  flex-shrink: 0;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.page_problemBandBtn__VOgQl:hover {
  background: rgba(221, 184, 74, 0.18) !important;
  border-color: rgba(221, 184, 74, 0.8) !important;
  color: #fff !important;
}

/* ── Mobile ── */
@media (max-width: 640px) {

  .page_problemSection__JhYLj {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .page_problemHeader__QJL1c {
    margin-bottom: 32px;
  }

  .page_problemBand____v9p {
    flex-direction: column;
    align-items: flex-start;
    padding: 28px 24px;
  }

  .page_problemBandContent__8bRlc {
    flex-basis: auto;
  }
}

/* ── Career Identity (editorial 3-beat) ── */
.page_identityInner__6jxoU {
  max-width: var(--max-width-wide);
  margin: 0 auto;
}

/* ── Editorial hero — portrait left, copy right ── */
.page_identityHero__AgqWj {
  display: grid;
  grid-template-columns: minmax(260px, 360px) 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
  max-width: 1080px;
  margin: 0 auto;
}

.page_identityFigure__yjQJ1 {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0;
}

.page_identityImageWrap__ib7Aj {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 24px;
  overflow: hidden;
  background: color-mix(in srgb, var(--c-green-dark) 5%, var(--c-cream) 95%);
  /* Subtle 1px brand-tinted border gives the print a defined edge that
     doesn't compete with the watercolour. The three-layer shadow stacks
     a crisp hairline, a soft midground, and a long ambient drop so the
     piece feels "lifted off the page" rather than pasted on. */
  border: 1px solid color-mix(in srgb, var(--c-green-dark) 14%, transparent);
  box-shadow:
    0 1px 3px rgba(26, 43, 30, 0.05),
    0 14px 28px -14px rgba(26, 43, 30, 0.12),
    0 32px 60px -24px rgba(26, 43, 30, 0.22);
}

.page_identityImage__X7jke {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page_identityCaption__scnt3 {
  font-family: var(--font-heading);
  font-size: 13px;
  font-weight: 400;
  font-style: italic;
  color: var(--c-light-body);
  line-height: 1.5;
  margin: 0;
  text-align: center;
  text-wrap: pretty;
}

.page_identityCopy___9bi0 {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.page_identityHeading__qLlvK {
  font-family: var(--font-heading);
  font-size: clamp(30px, 4vw, 46px);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.025em;
  line-height: 1.15;
  margin: 0 0 28px;
  text-wrap: balance;
}

.page_identityHeadingAccent__gCGt3 {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

.page_identityLead__w_StD {
  font-size: 16px;
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.7;
  margin: 0 0 24px;
  text-wrap: pretty;
}

.page_identityFour__TXY7B {
  display: inline-block;
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
  margin-right: 0.2em;
}

.page_identityLeadSoft__Kwplj {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: 16px;
  font-weight: 400;
  color: var(--c-wood-oak);
  line-height: 1.55;
  margin: 0 0 36px;
  text-wrap: pretty;
}

.page_identityPunch__rNyiV {
  font-family: var(--font-heading);
  font-size: clamp(22px, 2.4vw, 27px);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.012em;
  line-height: 1.3;
  margin: 0;
  text-wrap: balance;
}

.page_identityPunchAccent__fUP92 {
  color: var(--c-green-dark);
  font-weight: 500;
}

.page_identityCommit__6aYi5 {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: clamp(16px, 1.7vw, 19px);
  font-weight: 400;
  color: var(--c-green-dark);
  line-height: 1.5;
  margin: 20px 0 0;
  text-wrap: balance;
}

.page_identityLink__QK_NB {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 28px;
  font-family: var(--font-heading);
  font-size: 16px;
  color: var(--c-green-dark);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--c-green-dark) 35%, transparent);
  padding-bottom: 2px;
  transition: color 0.2s ease, border-color 0.2s ease;
  align-self: flex-start;
}

.page_identityLink__QK_NB:hover {
  color: var(--c-green);
  border-bottom-color: var(--c-green);
}

.page_identityLinkArrow__oD8P_ {
  transition: transform 0.2s ease;
}

.page_identityLink__QK_NB:hover .page_identityLinkArrow__oD8P_ {
  transform: translateX(3px);
}

@media (max-width: 900px) {
  .page_identityHero__AgqWj {
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: start;
  }
  .page_identityFigure__yjQJ1 {
    max-width: 320px;
    margin: 0 auto;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   Why Nari + Pricing (merged) — comparison grid leads, price is the payoff.
   On .sectionDark (forest): body uses --c-text/--c-text-mute; small accents use
   --c-gold / --on-dark-accent-warm (AA on dark); --c-warm-amber only on LARGE
   text (≥18.66px → 3:1 AA). Spacing follows the DS --space-* scale.
   ══════════════════════════════════════════════════════════════════════════ */
.page_mergeInner__oR1ZU {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 var(--page-gutter);
}

.page_mergeHeader__sai41 {
  max-width: 720px;
  margin: 0 0 var(--space-9);
}

.page_mergeHeading__v3_zb {
  font-family: var(--font-heading);
  font-size: clamp(30px, 4.4vw, 50px);
  font-weight: 500;
  color: var(--c-text);
  letter-spacing: -0.025em;
  line-height: 1.14;
  margin: var(--space-3) 0 var(--space-4);
  text-wrap: balance;
}

.page_mergeHeadingAccent___HROc {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-warm-amber);
}

.page_mergeIntro__VXW2W {
  font-family: var(--font-body);
  font-size: 17px;
  font-weight: 300;
  color: var(--c-text-mute);
  line-height: 1.65;
  max-width: 560px;
  margin: 0;
  text-wrap: pretty;
}

/* ── Comparison grid (market over Nari) ── */
.page_compareGrid__NyTP1 {
  list-style: none;
  margin: 0 0 var(--space-9);
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto auto auto auto;
  column-gap: var(--space-4);
}

/* Each card is a subgrid spanning the 4 shared rows (topic / market text /
   Nari label / Nari text), so those rows — and the divider — line up across
   every card no matter how many lines each blurb wraps to. Vertical insets
   come from the first/last child margins; padding-block would offset the
   subgrid tracks and break the cross-card alignment. */
.page_compareCard__g8Kzf {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  row-gap: var(--space-2);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--c-border-dark, rgba(245, 240, 234, 0.12));
  border-radius: var(--radius-md);
  padding-inline: var(--space-5);
  transition: transform var(--dur-base, 200ms) var(--ease-out, ease),
    border-color var(--dur-base, 200ms) var(--ease-out, ease),
    background var(--dur-base, 200ms) var(--ease-out, ease);
}

.page_compareTopic__XcC4m {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--on-dark-accent-warm);
  margin: var(--space-5) 0 0;
}

.page_compareMarketText__nPHW0 {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: 300;
  color: var(--c-text-mute);
  line-height: 1.5;
  margin: 0;
}

/* Divider sits on the Nari label's top edge → aligns across cards. */
.page_compareNariLabel__6Oni1 {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: 15px;
  font-weight: 500;
  color: var(--c-gold);
  margin: 0;
  padding-top: var(--space-4);
  border-top: 1px solid var(--c-border-dark, rgba(245, 240, 234, 0.12));
}

.page_compareNariText__902TI {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: 300;
  color: var(--c-text);
  line-height: 1.5;
  margin: 0 0 var(--space-5);
}

.page_mergeDivider__ybyeO {
  border: none;
  border-top: 1px solid var(--c-border-dark, rgba(245, 240, 234, 0.12));
  margin: var(--space-9) 0;
}

/* ── Pricing payoff (with soft gold glow behind the price) ── */
.page_payoff__QicTR {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(var(--space-7), 6vw, var(--space-10));
  align-items: start;
}

.page_payoff__QicTR::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 0;
  width: 280px;
  height: 280px;
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--c-gold) 12%, transparent),
    transparent 70%
  );
  z-index: 0;
  pointer-events: none;
}

.page_payoffLeft__MGycD,
.page_payoffRight__Q2jvC {
  position: relative;
  z-index: 1;
}

.page_payoffEyebrow__g1D96 {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--on-dark-accent-warm);
}

.page_payoffHeading__wPoOw {
  font-family: var(--font-heading);
  font-size: clamp(28px, 3.6vw, 40px);
  font-weight: 500;
  color: var(--c-text);
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: var(--space-3) 0 var(--space-4);
}

.page_payoffPrice__L9bkz {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-warm-amber);
}

.page_payoffBody__IiXwh {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 300;
  color: var(--c-text-mute);
  line-height: 1.6;
  margin: 0 0 var(--space-6);
  max-width: 420px;
  text-wrap: pretty;
}

.page_payoffCta__era6v {
  align-self: flex-start;
}

/* ── Anchor "what it replaces" list ── */
.page_anchorList__TOGxt {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.page_anchorItem__BL_YB {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-top: 1px solid var(--c-border-dark, rgba(245, 240, 234, 0.12));
}

.page_anchorItem__BL_YB:first-child {
  border-top: none;
}

.page_anchorNum__UGFdR {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  color: var(--c-text-mute);
}

.page_anchorBody__BcwiO {
  min-width: 0;
}

.page_anchorLabel__DH3ZZ {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: 400;
  color: var(--c-text);
  margin: 0;
}

.page_anchorSource__SCjCb {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--c-text-mute);
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: color var(--dur-fast, 120ms) ease;
}

.page_anchorSource__SCjCb:hover {
  color: var(--on-dark-accent-warm);
}

.page_anchorPrice__mPaiM {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  color: var(--c-text-mute);
  text-decoration: line-through;
  white-space: nowrap;
}

.page_anchorTotal__CWMhU {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: var(--space-4) 0 0;
  padding-top: var(--space-4);
  border-top: 1px solid color-mix(in srgb, var(--c-gold) 50%, transparent);
}

.page_anchorTotalLabel__hWLRc {
  font-family: var(--font-heading);
  font-size: 15px;
  font-weight: 500;
  color: var(--c-text);
}

.page_anchorTotalWas__EqKi6 {
  margin-left: auto;
  font-family: var(--font-body);
  font-size: var(--fs-md);
  color: var(--c-text-mute);
  text-decoration: line-through;
}

.page_anchorTotalNow__rW6_0 {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  font-weight: 500;
  color: var(--c-warm-amber);
}

.page_anchorFootnote__HO6yW {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 300;
  color: var(--c-text-mute);
  line-height: 1.5;
  margin: var(--space-4) 0 0;
  opacity: 0.7;
}

/* ── Why footer ── */
.page_whyRow__eMvLC {
  list-style: none;
  margin: var(--space-10) 0 0;
  padding: var(--space-9) 0 0;
  border-top: 1px solid var(--c-border-dark, rgba(245, 240, 234, 0.12));
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(var(--space-6), 4vw, var(--space-9));
}

.page_whyItem__FAsmV {
  min-width: 0;
}

.page_whyKicker__997eh {
  font-family: var(--font-heading);
  font-size: var(--fs-md);
  font-weight: 500;
  color: var(--c-gold);
  margin: 0 0 var(--space-3);
}

.page_whyBody__5FGAl {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: 300;
  color: var(--c-text-mute);
  line-height: 1.6;
  margin: 0;
  text-wrap: pretty;
}

.page_whySource__5IKuG {
  display: inline-block;
  margin-top: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--c-text-mute);
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: color var(--dur-fast, 120ms) ease;
}

.page_whySource__5IKuG:hover {
  color: var(--on-dark-accent-warm);
}

/* ── Hover + scroll-reveal motion (matches the homepage view()-timeline pattern) ── */
@media (prefers-reduced-motion: no-preference) {
  .page_compareCard__g8Kzf:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--c-gold) 40%, var(--c-border-dark, rgba(245, 240, 234, 0.12)));
    background: rgba(255, 255, 255, 0.05);
  }

  @keyframes page_mergeReveal__XzUZm {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: none; }
  }

  @supports (animation-timeline: view()) {
    .page_mergeHeader__sai41,
    .page_compareCard__g8Kzf,
    .page_payoff__QicTR,
    .page_whyRow__eMvLC {
      animation: page_mergeReveal__XzUZm :local(auto) linear both;
      animation-timeline: view();
      animation-range: entry 0% entry 50%;
    }
    .page_compareCard__g8Kzf:nth-child(1) { animation-range: entry 0% entry 48%; }
    .page_compareCard__g8Kzf:nth-child(2) { animation-range: entry 0% entry 54%; }
    .page_compareCard__g8Kzf:nth-child(3) { animation-range: entry 0% entry 60%; }
    .page_compareCard__g8Kzf:nth-child(4) { animation-range: entry 0% entry 66%; }
  }
}

/* ── Merged section — responsive ── */
@media (max-width: 900px) {
  .page_compareGrid__NyTP1 {
    grid-template-columns: repeat(2, 1fr);
  }
  .page_payoff__QicTR {
    grid-template-columns: 1fr;
    gap: var(--space-7);
  }
  .page_whyRow__eMvLC {
    grid-template-columns: 1fr;
    gap: var(--space-7);
  }
}

@media (max-width: 560px) {
  .page_compareGrid__NyTP1 {
    grid-template-columns: 1fr;
  }
}

/* ════════════════════════════════════════════════════════════════════════
   What Nari Does — unified showcase
   Section header + three numbered blocks (Resume / Coaching / Community)
   ──────────────────────────────────────────────────────────────────────── */

.feature-section_showcase__Ey60H {
  padding-block: clamp(72px, 9vw, 120px);
  padding-inline: var(--page-gutter);
  background: var(--c-cream-light);
  scroll-margin-top: calc(var(--nav-height) + 44px + 8px);
}

.feature-section_showcaseInner__RFvYf {
  max-width: 1120px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: clamp(48px, 6vw, 80px);
}

/* ── Section header ── */
.feature-section_showcaseHeader__MzOAx {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}

.feature-section_showcaseHeading__Z5nWP {
  font-family: var(--font-heading, "Lora", serif);
  font-size: clamp(30px, 4.2vw, 46px);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.025em;
  line-height: 1.14;
  margin: 0;
  text-wrap: balance;
}

.feature-section_showcaseHeadingAccent__RUI3e {
  font-family: var(--font-heading, "Lora", serif);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

.feature-section_showcaseIntro__lfUHG {
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 17px;
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.65;
  margin: 0;
  max-width: 580px;
  text-wrap: pretty;
}

/* ── Numbered block (Resume / Coaching) ── */
.feature-section_block__00gQc {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
}

/* Reverse: visual on the left, copy on the right (desktop). */
.feature-section_blockReverse__m6U15 .feature-section_blockCopy__v0emw {
  order: 2;
}
.feature-section_blockReverse__m6U15 .feature-section_mockWrap__92HIk {
  order: 1;
}

.feature-section_blockCopy__v0emw {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.feature-section_blockNumRow__1nH2l {
  display: flex;
  align-items: center;
  gap: 16px;
}

.feature-section_blockNum__nCdNu {
  font-family: var(--font-heading, "Lora", serif);
  font-size: clamp(40px, 5vw, 58px);
  font-weight: 500;
  line-height: 1;
  color: color-mix(in srgb, var(--c-green-dark) 22%, transparent);
  letter-spacing: -0.02em;
}

.feature-section_blockHeading__gdP3g {
  font-family: var(--font-heading, "Lora", serif);
  font-size: clamp(26px, 3.4vw, 36px);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.025em;
  line-height: 1.2;
  margin: 0;
  text-wrap: balance;
}

.feature-section_blockDivider__U3s3X {
  border: 0;
  height: 1px;
  background: linear-gradient(
    to right,
    transparent,
    var(--c-border) 18%,
    var(--c-border) 82%,
    transparent
  );
  margin: 0;
}

/* ── Community block (full-width) ── */
.feature-section_communityBlock__3vFeS {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.feature-section_communityBlockHead__kadU3 {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.feature-section_mockWrap__92HIk {
  display: flex;
  justify-content: center;
  min-width: 0;
}

.feature-section_eyebrow__7b_RD {
  margin-bottom: 4px;
}

.feature-section_headingAccent__1PFPe {
  font-family: var(--font-heading, "Lora", serif);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

/* Coaching block accent picks up the wood-oak tone of its eyebrow. */
.feature-section_blockReverse__m6U15 .feature-section_headingAccent__1PFPe {
  color: var(--c-wood-oak);
}

.feature-section_lead__NV2RN {
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 16px;
  font-weight: 300;
  color: var(--c-light-body);
  line-height: 1.65;
  margin: 0;
  max-width: 480px;
  text-wrap: pretty;
}

.feature-section_points__yRQqt {
  list-style: none;
  margin: 8px 0 4px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.feature-section_point__zLv5k {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 14px;
  font-weight: 400;
  color: var(--c-light-body);
  line-height: 1.5;
}

.feature-section_pointIcon__lRGAu {
  color: var(--c-green-dark);
  flex-shrink: 0;
  margin-top: 4px;
}

.feature-section_ctaRow__9witY {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 12px;
}

/* ── Resume Engine — floating-card stage + vertical numbered rail ────────── */
.feature-section_stage__CLFRh {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  width: 100%;
  padding: var(--space-7);
  border-radius: var(--radius-2xl);
  border: 1px solid var(--c-border);
  background: linear-gradient(
    150deg,
    color-mix(in srgb, var(--c-golden-sand) 9%, var(--c-cream-light)),
    color-mix(in srgb, var(--c-green-dark) 7%, var(--c-cream-light))
  );
}

/* Floating-card composition. */
.feature-section_cards__HYrcD {
  position: relative;
  flex: 1 1;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Decorative cards layered behind the front card for depth. */
.feature-section_cardBackA__2Nc2X,
.feature-section_cardBackB__AnwGW {
  position: absolute;
  border-radius: var(--radius-lg);
}

.feature-section_cardBackA__2Nc2X {
  z-index: 1;
  width: min(280px, 84%);
  height: 76%;
  background: color-mix(in srgb, var(--c-green-dark) 12%, var(--c-cream-light));
  transform: translate(-30px, -36px) rotate(-5deg);
  box-shadow: 0 10px 26px -12px rgba(30, 20, 10, 0.20);
}

.feature-section_cardBackB__AnwGW {
  z-index: 2;
  width: min(290px, 88%);
  height: 80%;
  background: color-mix(in srgb, var(--c-golden-sand) 16%, var(--c-cream-light));
  transform: translate(26px, 32px) rotate(4deg);
  box-shadow: 0 12px 28px -12px rgba(30, 20, 10, 0.22);
}

.feature-section_cardFront__4RTgv {
  position: relative;
  z-index: 3;
  width: min(340px, 100%);
  background: var(--c-cream-light);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 20px rgba(30, 20, 10, 0.10), 0 26px 50px -16px rgba(30, 20, 10, 0.20);
  padding: var(--space-5);
  /* All step panels share one grid cell, so the card is always as tall as the
     TALLEST step and never resizes when switching tabs (no magic min-height). */
  display: grid;
}

/* Each panel stacks in the single grid cell; inactive ones stay in layout
   (so they size the card) but are hidden from view + assistive tech. */
.feature-section_cardPanel__tHLrh {
  grid-area: 1 / 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s var(--ease-out, cubic-bezier(0.22, 1, 0.36, 1));
}

.feature-section_cardPanelActive__YaIoR {
  opacity: 1;
  visibility: visible;
}

.feature-section_cardTitle__hJSx8 {
  font-family: var(--font-mono, "DM Mono", monospace);
  font-size: var(--fs-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--tracking-eyebrow);
  color: var(--c-wood-oak);
  margin: 0;
}

/* ── Vertical numbered rail ──────────────────────────────────────────────── */
.feature-section_rail__8lZXW {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex-shrink: 0;
  width: 140px;
}

.feature-section_railItem__Nb9ZQ {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-1);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--c-cream-light) 65%, transparent);
  cursor: pointer;
  text-align: left;
  font: inherit;
  transition: background 0.16s ease, border-color 0.16s ease, transform 0.16s ease;
}

.feature-section_railItem__Nb9ZQ:hover {
  border-color: var(--c-green-dark);
  transform: translateX(-2px);
}

.feature-section_railItem__Nb9ZQ:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(100, 130, 44, 0.30);
}

.feature-section_railItemActive__I1uUq {
  background: var(--c-green-dark);
  border-color: var(--c-green-dark);
}

.feature-section_railItemActive__I1uUq:hover {
  transform: translateX(-2px);
}

.feature-section_railNum__rG_zJ {
  font-family: var(--font-mono, "DM Mono", monospace);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-light-mute);
}

.feature-section_railItemActive__I1uUq .feature-section_railNum__rG_zJ {
  color: color-mix(in srgb, var(--c-cream-light) 85%, transparent);
}

.feature-section_railLabel__V6wK7 {
  font-family: var(--font-sans, "DM Sans", sans-serif);
  font-size: var(--fs-base);
  font-weight: 500;
  color: var(--c-light-head);
  line-height: var(--lh-tight);
}

.feature-section_railItemActive__I1uUq .feature-section_railLabel__V6wK7 {
  color: var(--c-cream-light);
}

@media (prefers-reduced-motion: reduce) {
  .feature-section_cardPanel__tHLrh {
    transition: none;
  }
  .feature-section_railItem__Nb9ZQ {
    transition: none;
  }
  .feature-section_railItem__Nb9ZQ:hover,
  .feature-section_railItemActive__I1uUq:hover {
    transform: none;
  }
}

@media (max-width: 560px) {
  .feature-section_stage__CLFRh {
    flex-direction: column;
    padding: var(--space-5);
  }
  .feature-section_cards__HYrcD {
    min-height: 0;
    width: 100%;
  }
  .feature-section_cardBackA__2Nc2X,
  .feature-section_cardBackB__AnwGW {
    display: none;
  }
  .feature-section_cardFront__4RTgv {
    width: 100%;
    min-height: 0;
  }
  .feature-section_rail__8lZXW {
    flex-direction: row;
    width: 100%;
  }
  .feature-section_railItem__Nb9ZQ {
    flex: 1 1;
  }
}

.feature-section_rawList__0f8ei {
  list-style: disc outside;
  margin: 0;
  padding: 0 0 0 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.feature-section_rawList__0f8ei li {
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 12px;
  color: var(--c-light-mute);
  line-height: 1.45;
}

.feature-section_nariBadge__T30f0 {
  align-self: flex-start;
  font-family: var(--font-mono, "DM Mono", monospace);
  font-size: 9.5px;
  font-weight: 500;
  color: var(--c-green-dark);
  background: var(--c-green-faint);
  padding: 4px 9px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.feature-section_nariSummary__dsgBf {
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 12.5px;
  color: var(--c-light-body);
  line-height: 1.55;
  margin: 0;
}

.feature-section_nariList__cQiTq {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.feature-section_nariList__cQiTq li {
  position: relative;
  padding-left: 16px;
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 12.5px;
  color: var(--c-light-body);
  line-height: 1.5;
}

.feature-section_nariList__cQiTq li::before {
  content: "▪";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--c-golden-sand);
}

/* ── Tailor panel (step 3) ─────────────────────────────────────────────── */
.feature-section_field__2K1pL {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.feature-section_fieldLabel__Pwyu0 {
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 11px;
  font-weight: 500;
  color: var(--c-light-body);
}

.feature-section_fieldInput__sPIeo {
  background: color-mix(in srgb, var(--c-cream-dark) 28%, var(--c-cream-light));
  border: 1px solid var(--c-border);
  border-radius: 8px;
  padding: 8px 11px;
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 12px;
  color: var(--c-light-head);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.feature-section_fieldChevron__13GIR {
  color: var(--c-light-mute);
  font-size: 14px;
  line-height: 1;
}

.feature-section_chipRow__qSNN7 {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.feature-section_chip__QYnbs {
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 11.5px;
  font-weight: 500;
  padding: 7px 12px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid var(--c-border-mid);
  color: var(--c-light-body);
}

.feature-section_chipActive__Z2l6A {
  background: var(--c-green-deep, #1e3028);
  border-color: var(--c-green-deep, #1e3028);
  color: var(--c-cream-light);
}

/* Shared avatar tones (used by the coaching mock). */
.feature-section_toneForest__HAXjd {
  background: var(--c-green-dark);
}

.feature-section_toneAmber__Qpb7w {
  background: var(--c-golden-sand);
}

.feature-section_toneOak__O_3qL {
  background: var(--c-wood-oak);
}

.feature-section_toneSage__L5tGx {
  background: var(--c-warm-amber);
}

/* ── Coaching mock — fanned floating cards (free office hours leads) ─────── */
/* No tray/panel — the cards float directly on the section background; their
   own shadows do the separating. .coachStage is just a positioning frame. */
.feature-section_coachStage__yygvs {
  position: relative;
  width: 100%;
  min-height: 360px;
  padding: var(--space-7);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Behind: paid 1:1 (fanned up-left, the deeper commitment). */
.feature-section_coach1on1__WZNuM {
  position: absolute;
  z-index: 1;
  width: min(290px, 78%);
  background: var(--c-cream-light);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  box-shadow: 0 10px 26px -12px rgba(30, 20, 10, 0.20);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transform: translate(-30px, -82px) rotate(-5deg);
}

.feature-section_coach1on1Head__1t1j7 {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.feature-section_coachAvatar__h5x34 {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-pill);
  display: grid;
  place-items: center;
  color: var(--c-cream-light);
  font-family: var(--font-serif, "Lora", serif);
  font-size: 17px;
  font-weight: 500;
  flex-shrink: 0;
}

.feature-section_coachName___ZUhx {
  font-family: var(--font-serif, "Lora", serif);
  font-size: var(--fs-md);
  font-weight: 500;
  color: var(--c-light-head);
  margin: 0;
  line-height: var(--lh-tight);
}

.feature-section_coachMeta__wYinL {
  font-family: var(--font-sans, "DM Sans", sans-serif);
  font-size: var(--fs-base);
  color: var(--c-light-mute);
  margin: 0;
}

.feature-section_coach1on1Cta__ywXRJ {
  font-family: var(--font-sans, "DM Sans", sans-serif);
  font-size: var(--fs-base);
  font-weight: 500;
  color: var(--c-golden-sand);
}

/* Front: free office hours (the no-commitment lead-in). */
.feature-section_coachOffice__MsvHi {
  position: relative;
  z-index: 2;
  width: min(320px, 100%);
  background: var(--c-cream-light);
  border: 1px solid var(--c-border-mid);
  border-radius: var(--radius-lg);
  box-shadow: 0 10px 24px rgba(30, 20, 10, 0.10),
    0 28px 52px -16px rgba(30, 20, 10, 0.22);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transform: translate(22px, 42px) rotate(3deg);
}

.feature-section_freeTag__Fghfm {
  align-self: flex-start;
}

.feature-section_officeTitle__Z3zWB {
  font-family: var(--font-serif, "Lora", serif);
  font-size: var(--fs-lg);
  font-weight: 500;
  color: var(--c-light-head);
  letter-spacing: -0.01em;
  margin: var(--space-1) 0 0;
}

.feature-section_officeMeta__s4byu {
  font-family: var(--font-sans, "DM Sans", sans-serif);
  font-size: var(--fs-base);
  color: var(--c-light-mute);
  margin: 0;
}

.feature-section_officeWhen__XGidE {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  background: var(--c-green-faint, rgba(100, 130, 44, 0.1));
  border-radius: var(--radius);
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-sans, "DM Sans", sans-serif);
}

.feature-section_officeDay__qJBWw {
  font-size: var(--fs-base);
  font-weight: 600;
  color: var(--c-green-dark);
}

.feature-section_officeTime__H7vip {
  font-size: var(--fs-base);
  color: var(--c-green-dark);
}

.feature-section_officeNote__ycc4_ {
  font-family: var(--font-sans, "DM Sans", sans-serif);
  font-size: var(--fs-base);
  color: var(--c-light-body);
  line-height: var(--lh-normal);
  margin: 0;
}

.feature-section_officeCta__hjOmZ {
  align-self: flex-start;
  font-family: var(--font-sans, "DM Sans", sans-serif);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-green-dark);
}

@media (max-width: 560px) {
  .feature-section_coachStage__yygvs {
    flex-direction: column;
    gap: var(--space-4);
    min-height: 0;
    padding: var(--space-5);
  }
  .feature-section_coach1on1__WZNuM,
  .feature-section_coachOffice__MsvHi {
    position: relative;
    transform: none;
    width: 100%;
  }
  /* Lead with the free hook on mobile. */
  .feature-section_coachOffice__MsvHi {
    order: -1;
  }
}

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .feature-section_block__00gQc {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  /* Copy always comes first on mobile so the heading sits at the top. */
  .feature-section_blockReverse__m6U15 .feature-section_blockCopy__v0emw {
    order: -1;
  }
  .feature-section_blockReverse__m6U15 .feature-section_mockWrap__92HIk {
    order: 0;
  }
}

@media (max-width: 640px) {
  .feature-section_showcase__Ey60H {
    padding-block: 64px;
  }
  .feature-section_ctaRow__9witY {
    flex-direction: column;
    align-items: stretch;
  }
  .feature-section_ctaRow__9witY > * {
    width: 100%;
    justify-content: center;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   Community block (moved from the homepage so the whole 'What Nari Does'
   showcase lives in one component / one CSS module).
   ══════════════════════════════════════════════════════════════════════════ */
/* ── Community ── */
.feature-section_communityInner__GmbFJ {
  max-width: var(--max-width-wide);
  margin: 0 auto;
}

.feature-section_communityHeader__lLDqF {
  max-width: 720px;
  margin: 0 auto 56px;
  text-align: center;
}

.feature-section_communityHeading__inX47 {
  font-family: var(--font-heading);
  font-size: clamp(32px, 4.2vw, 50px);
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1.12;
  color: var(--c-light-head);
  margin: 14px 0 22px;
  text-wrap: balance;
}

.feature-section_communityHeadingAccent__YGUku {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

.feature-section_communityLead__kilUC {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.65;
  color: var(--c-light-body);
  margin: 0 auto;
  max-width: 600px;
  text-wrap: pretty;
}

.feature-section_communityLeadAccent__8ezId {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

/* ── Community pinboard ── */
.feature-section_communityPinboard__RgV8I {
  position: relative;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(320px, 1.35fr) minmax(220px, 1fr);
  grid-template-rows: auto auto;
  gap: 32px 36px;
  max-width: 1120px;
  margin: 0 auto 64px;
  align-items: center;
  justify-items: center;
}

.feature-section_communityPinboard__RgV8I::before {
  content: "";
  position: absolute;
  inset: -20px 4% -20px 4%;
  background:
    radial-gradient(
      ellipse 60% 70% at 50% 50%,
      color-mix(in srgb, var(--c-warm-amber) 8%, transparent) 0%,
      transparent 70%
    );
  filter: blur(40px);
  z-index: 0;
  pointer-events: none;
}

.feature-section_communityCards__HJzPy {
  display: contents;
}

/* Illustration — center, spans both rows */
.feature-section_communityFigure__FJ4BC {
  grid-column: 2;
  grid-row: 1 / span 2;
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: 466px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.feature-section_communityIllustrationWrap__YF_HI {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
}

.feature-section_communityIllustrationWrap__YF_HI::before {
  content: "";
  position: absolute;
  inset: 8% 6%;
  background: radial-gradient(
    ellipse at center,
    color-mix(in srgb, var(--c-warm-amber) 14%, transparent) 0%,
    transparent 70%
  );
  filter: blur(24px);
  z-index: 0;
  pointer-events: none;
}

.feature-section_communityIllustration__TQTap {
  position: relative;
  display: block;
  width: 100%;
  max-width: 466px;
  height: auto;
  z-index: 1;
}

.feature-section_communityFigureCaption__C50XN {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: 14px;
  color: var(--c-wood-oak);
  text-align: center;
  line-height: 1.4;
  margin: 0;
}

/* Pin positions — card placement + static rotation */
.feature-section_pinTopLeft__BAnmH {
  grid-column: 1;
  grid-row: 1;
  transform: rotate(-1.8deg);
}

.feature-section_pinTopRight__QqA0G {
  grid-column: 3;
  grid-row: 1;
  transform: rotate(1.4deg);
}

.feature-section_pinBottomLeft__6wB0c {
  grid-column: 1;
  grid-row: 2;
  transform: rotate(1.2deg);
}

.feature-section_pinBottomRight__Wd1G2 {
  grid-column: 3;
  grid-row: 2;
  transform: rotate(-1.6deg);
}

@media (max-width: 900px) {
  .feature-section_communityPinboard__RgV8I {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 24px;
  }
  .feature-section_communityFigure__FJ4BC {
    grid-column: 1;
    grid-row: auto;
    order: -1;
    max-width: 420px;
  }
  .feature-section_pinTopLeft__BAnmH,
  .feature-section_pinTopRight__QqA0G,
  .feature-section_pinBottomLeft__6wB0c,
  .feature-section_pinBottomRight__Wd1G2 {
    grid-column: 1;
    grid-row: auto;
    transform: none;
  }
}

/* ── Pinned cards — scrapbook feel ── */
.feature-section_communityCard__3IOT2 {
  position: relative;
  padding: 26px 22px 24px;
  border-radius: 4px;
  box-shadow: 0 3px 6px rgba(26, 43, 30, 0.08),
    0 18px 36px -22px rgba(26, 43, 30, 0.22);
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
  max-width: 280px;
  transform-origin: 50% 0%;
  transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.3, 1.1),
    box-shadow 0.3s ease;
  z-index: 1;
}

/* Thumbtack at top-center */
.feature-section_communityCard__3IOT2::before {
  content: "";
  position: absolute;
  top: -7px;
  left: 50%;
  width: 14px;
  height: 14px;
  margin-left: -7px;
  border-radius: 50%;
  background: radial-gradient(
    circle at 35% 30%,
    #e5b778 0%,
    #a8762f 55%,
    #6b471b 100%
  );
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.25),
    inset 0 -1px 2px rgba(0, 0, 0, 0.2);
  z-index: 3;
}

/* Paper-edge highlight for lift */
.feature-section_communityCard__3IOT2::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(255, 255, 255, 0.35);
  pointer-events: none;
  mix-blend-mode: overlay;
}

.feature-section_communityIconWrap__FC0tK {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.55);
  transition: transform 0.3s ease;
}

/* ── Tinted card variants (full fill, not white) ── */
.feature-section_communityCardGreen__E_pT_ {
  background: color-mix(in srgb, var(--c-green-dark) 12%, #fdf8ea 88%);
}
.feature-section_communityCardGreen__E_pT_ .feature-section_communityIconWrap__FC0tK {
  color: var(--c-green-dark);
}
.feature-section_communityCardGreen__E_pT_ .feature-section_communityCardTitle__Psbgo {
  color: var(--c-green-dark);
}

.feature-section_communityCardAmber__6tv8v {
  background: color-mix(in srgb, var(--c-warm-amber) 22%, #fdf4e3 78%);
}
/* Deliberate dark-amber (no DS token exists for it): --c-warm-amber fails AA
   on this light-amber card for small text, so we darken to clear 4.5:1. */
.feature-section_communityCardAmber__6tv8v .feature-section_communityIconWrap__FC0tK {
  color: #8f5a15;
}
.feature-section_communityCardAmber__6tv8v .feature-section_communityCardTitle__Psbgo {
  color: #8f5a15;
}

.feature-section_communityCardOak__ZVnqC {
  background: color-mix(in srgb, var(--c-wood-oak) 15%, #fbf3e6 85%);
}
.feature-section_communityCardOak__ZVnqC .feature-section_communityIconWrap__FC0tK {
  color: var(--c-wood-oak);
}
.feature-section_communityCardOak__ZVnqC .feature-section_communityCardTitle__Psbgo {
  color: var(--c-wood-oak);
}

.feature-section_communityCardRose__XFv4c {
  background: color-mix(in srgb, var(--c-red, #b54a4a) 12%, #fceee8 88%);
}
.feature-section_communityCardRose__XFv4c .feature-section_communityIconWrap__FC0tK {
  color: var(--c-red, #b54a4a);
}
.feature-section_communityCardRose__XFv4c .feature-section_communityCardTitle__Psbgo {
  color: var(--c-red, #b54a4a);
}

.feature-section_communityCardTitle__Psbgo {
  font-family: var(--font-heading);
  font-size: 17px;
  font-weight: 500;
  margin: 0;
  letter-spacing: -0.005em;
}

.feature-section_communityCardText__MiC0b {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--c-light-head);
  margin: 0;
}

/* ── Closing block ── */
.feature-section_communityClose__nwaTi {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}

.feature-section_communityCloseLine__rOlYG {
  font-family: var(--font-heading);
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 400;
  line-height: 1.4;
  color: var(--c-light-head);
  margin: 0 0 28px;
  text-wrap: balance;
}

.feature-section_communityCloseAccent__cbf1i {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 500;
  color: var(--c-green-dark);
}

.feature-section_communityCtaRow__NqZZO {
  display: inline-flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
  justify-content: center;
}

.feature-section_communityTextLink__fjk3v {
  font-family: var(--font-heading);
  font-size: 15px;
  font-weight: 500;
  color: var(--c-green-dark);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-bottom: 1px solid color-mix(in srgb, var(--c-green-dark) 30%, transparent);
  padding-bottom: 3px;
  transition: gap 0.2s ease, border-color 0.2s ease;
}

.feature-section_communityTextLink__fjk3v:hover,
.feature-section_communityTextLink__fjk3v:focus-visible {
  gap: 10px;
  border-bottom-color: var(--c-green-dark);
  outline: none;
}

.feature-section_communityArrow__gLhUv {
  transition: transform 0.2s ease;
}

.feature-section_communityTextLink__fjk3v:hover .feature-section_communityArrow__gLhUv,
.feature-section_communityTextLink__fjk3v:focus-visible .feature-section_communityArrow__gLhUv {
  transform: translateX(2px);
}

@media (max-width: 720px) {
  .feature-section_communityGrid__sOZlV {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .feature-section_communityCard__3IOT2 {
    padding: 24px 22px;
  }
}

/* ── Community — motion ── */
@media (prefers-reduced-motion: no-preference) {
  @keyframes feature-section_communityReveal__ncxF_ {
    from {
      opacity: 0;
      transform: translateY(20px);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }

  @keyframes feature-section_communityFade__aP2M5 {
    from { opacity: 0; }
    to { opacity: 1; }
  }

  /* Hover: straighten + pop (override each per-card rotation) */
  .feature-section_communityCard__3IOT2:hover {
    transform: rotate(0deg) scale(1.04) translateY(-4px);
    box-shadow: 0 6px 12px rgba(26, 43, 30, 0.12),
      0 28px 48px -18px rgba(26, 43, 30, 0.28);
    z-index: 2;
  }

  .feature-section_communityCard__3IOT2:hover .feature-section_communityIconWrap__FC0tK {
    transform: rotate(-6deg) scale(1.08);
  }

  /* Subtle thumbtack glint on card hover */
  .feature-section_communityCard__3IOT2:hover::before {
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3),
      inset 0 -1px 2px rgba(0, 0, 0, 0.2),
      0 0 0 3px color-mix(in srgb, #e5b778 22%, transparent);
  }

  @supports (animation-timeline: view()) {
    .feature-section_communityHeader__lLDqF,
    .feature-section_communityFigure__FJ4BC,
    .feature-section_communityClose__nwaTi {
      animation: feature-section_communityReveal__ncxF_ :local(auto) linear both;
      animation-timeline: view();
      animation-range: entry 0% entry 55%;
    }

    /* Cards fade in via opacity only so the rotations survive */
    .feature-section_communityCard__3IOT2 {
      animation: feature-section_communityFade__aP2M5 :local(auto) linear both;
      animation-timeline: view();
    }

    .feature-section_communityCard__3IOT2:nth-child(1) { animation-range: entry 0% entry 52%; }
    .feature-section_communityCard__3IOT2:nth-child(2) { animation-range: entry 0% entry 60%; }
    .feature-section_communityCard__3IOT2:nth-child(3) { animation-range: entry 0% entry 68%; }
    .feature-section_communityCard__3IOT2:nth-child(4) { animation-range: entry 0% entry 76%; }
  }
}

