/* =========================================================================
   GARDEN ŌTEPOTI — Four Seasons of the South
   Draft website style system
   Palette sampled from the delivered brand pack. Type: Fraunces + Hanken Grotesk.
   ========================================================================= */

:root{
  /* Surfaces */
  --paper:#FBF8F1;          /* warm off-white page */
  --paper-2:#F3EDE0;        /* deeper cream for alt sections */
  --paper-3:#ECF3E6;        /* faint green wash */
  --card:#FFFFFF;

  /* Ink */
  --ink:#16261B;            /* near-black forest, body + headings */
  --ink-soft:#42584A;       /* muted body copy */
  --ink-faint:#6E7F72;

  /* Brand */
  --forest:#16702A;         /* GARDEN dark green — primary */
  --forest-700:#0E5A1F;
  --leaf:#57AC3D;           /* ŌTEPOTI leaf green */
  --orange:#F6960B;         /* GO marigold — action accent */
  --orange-600:#E07E00;
  --daisy:#F4C81E;          /* yellow */

  /* Seasons */
  --spring:#8BD81E;
  --autumn:#A44133;
  --winter:#5BE2FE;
  --winter-ink:#1E4E79;
  --summer:#F2AF0D;
  --harvest:#F2C21E;

  /* Lines / shadow */
  --line:rgba(22,38,27,.12);
  --line-strong:rgba(22,38,27,.22);
  --shadow-sm:0 2px 10px rgba(22,38,27,.06);
  --shadow:0 18px 50px -24px rgba(22,38,27,.35);
  --shadow-lg:0 40px 90px -40px rgba(22,38,27,.45);

  --radius:18px;
  --radius-lg:26px;
  --container:1200px;
  --gutter:clamp(20px,5vw,64px);

  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-sans:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--paper);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:560;
  line-height:1.06;
  letter-spacing:-.01em;
  color:var(--ink);
  margin:0 0 .5em;
  font-optical-sizing:auto;
}
p{margin:0 0 1.1em}
::selection{background:var(--daisy);color:var(--ink)}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tight{padding-block:clamp(48px,6vw,86px)}
.bg-cream{background:var(--paper-2)}
.bg-green{background:var(--paper-3)}
.bg-forest{background:var(--forest);color:#EAF3E5}
.bg-ink{background:var(--ink);color:#E7EDE6}
.bg-forest h1,.bg-forest h2,.bg-forest h3,.bg-forest h4,
.bg-ink h1,.bg-ink h2,.bg-ink h3,.bg-ink h4{color:#fff}
.center{text-align:center}
.measure{max-width:62ch}
.measure-sm{max-width:48ch}
.mx-auto{margin-inline:auto}

.eyebrow{
  font:600 .8rem/1 var(--font-sans);
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--leaf);
  display:inline-flex;align-items:center;gap:.6em;
  margin-bottom:1.1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--orange);border-radius:2px}
.bg-forest .eyebrow,.bg-ink .eyebrow{color:var(--daisy)}
.bg-forest .eyebrow::before,.bg-ink .eyebrow::before{background:var(--daisy)}

h1,.h1{font-size:clamp(2.6rem,6vw,4.7rem)}
h2,.h2{font-size:clamp(2rem,4.2vw,3.25rem)}
h3,.h3{font-size:clamp(1.3rem,2.1vw,1.7rem)}
.lead{font-size:clamp(1.12rem,1.7vw,1.4rem);color:var(--ink-soft);line-height:1.55}
.bg-forest .lead,.bg-ink .lead{color:#CFE0CA}
.muted{color:var(--ink-soft)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--forest);--fg:#fff;--bd:var(--forest);
  display:inline-flex;align-items:center;gap:.6em;
  padding:.85em 1.5em;border-radius:100px;
  background:var(--bg);color:var(--fg);border:1.5px solid var(--bd);
  font-weight:650;font-size:.98rem;letter-spacing:.01em;cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,background .2s,color .2s;
  will-change:transform;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(22,38,27,.5)}
.btn--orange{--bg:var(--orange);--bd:var(--orange);--fg:#3a2400}
.btn--orange:hover{--bg:var(--orange-600)}
.btn--ghost{--bg:transparent;--fg:var(--forest);--bd:var(--line-strong)}
.btn--ghost:hover{--bd:var(--forest)}
.btn--light{--bg:#fff;--fg:var(--forest);--bd:#fff}
.btn--on-dark-ghost{--bg:transparent;--fg:#fff;--bd:rgba(255,255,255,.5)}
.btn--on-dark-ghost:hover{--bd:#fff}
.btn svg{width:1.05em;height:1.05em}

.btn-row{display:flex;flex-wrap:wrap;gap:.8rem}

/* ---------- Header / nav ---------- */
.header{
  position:sticky;top:0;z-index:60;
  background:rgba(251,248,241,.86);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.header.is-stuck{border-color:var(--line);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:clamp(70px,8vw,92px)}
.brand{display:flex;align-items:center;gap:.7rem;flex:0 0 auto}
.brand img{height:clamp(38px,4.6vw,52px);width:auto;transition:height .3s}
.header.is-stuck .brand img{height:clamp(34px,4vw,46px)}
.brand-locale{display:flex;flex-direction:column;justify-content:center;line-height:1.05;padding-left:.78rem;border-left:1.5px solid var(--line-strong)}
.brand-locale .pl{font-family:var(--font-display);font-size:clamp(.98rem,1.1vw,1.18rem);font-weight:600;color:var(--forest);letter-spacing:.004em}
.brand-locale .sub{font-family:var(--font-sans);font-size:.58rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-top:2px}
@media (max-width:560px){.brand-locale .sub{display:none}}
@media (max-width:380px){.brand-locale{display:none}}
.nav-links{display:flex;align-items:center;gap:clamp(.5rem,1vw,1.1rem);list-style:none;margin:0;padding:0}
.nav-links a{
  font-weight:560;font-size:.95rem;color:var(--ink);padding:.4em 0;position:relative;white-space:nowrap;
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--orange);
  border-radius:2px;transition:right .28s cubic-bezier(.2,.7,.2,1);
}
.nav-links a:hover::after{right:0}
.nav-cta{display:flex;align-items:center;gap:.7rem;flex:0 0 auto}
.nav-cta .btn--ghost{display:none}/* secondary CTA lives in hero/footer/menu, not the top bar */
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem;color:var(--ink)}
.nav-toggle svg{width:30px;height:30px}

/* Off-canvas menu hidden on desktop; re-enabled in the mobile breakpoint below */
.mobile-menu,.menu-backdrop{display:none}

@media (max-width:1520px){
  .nav-links,.nav-cta .btn--ghost{display:none}
}
@media (max-width:1520px){
  .nav-toggle{display:inline-flex}
  .mobile-menu{
    position:fixed;inset:0 0 0 auto;width:min(360px,86vw);z-index:70;
    background:var(--paper);box-shadow:var(--shadow-lg);
    transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);
    padding:5.5rem var(--gutter) 2rem;display:flex;flex-direction:column;gap:.2rem;overflow-y:auto;
  }
  .mobile-menu.open{transform:none}
  .mobile-menu a{padding:.85rem 0;border-bottom:1px solid var(--line);font-size:1.15rem;font-family:var(--font-display)}
  .mobile-menu .btn{margin-top:1.2rem;justify-content:center}
  .menu-backdrop{display:block;position:fixed;inset:0;background:rgba(22,38,27,.42);z-index:65;opacity:0;visibility:hidden;transition:.3s}
  .menu-backdrop.open{opacity:1;visibility:visible}
  .menu-close{position:absolute;top:1.4rem;right:1.4rem;background:none;border:0;cursor:pointer;color:var(--ink)}
  .menu-close svg{width:28px;height:28px}
}

/* ---------- Announcement bar ---------- */
.topbar{background:var(--forest);color:#EAF3E5;font-size:.86rem;letter-spacing:.01em}
.topbar .container{display:flex;gap:1rem;align-items:center;justify-content:center;padding-block:.55rem;text-align:center;flex-wrap:wrap}
.topbar strong{color:#fff}
.topbar .dot{width:7px;height:7px;border-radius:50%;background:var(--spring);display:inline-block}
.topbar a{color:var(--daisy);font-weight:650;text-decoration:underline;text-underline-offset:3px}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:clamp(560px,86vh,860px);display:flex;align-items:flex-end;color:#fff;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero__bg img{width:100%;height:100%;object-fit:cover;animation:slowzoom 22s ease-out forwards}
@keyframes slowzoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(13,38,20,.30) 0%,rgba(13,38,20,0) 30%),
    linear-gradient(8deg,rgba(9,28,15,.86) 4%,rgba(9,28,15,.38) 42%,rgba(9,28,15,0) 70%);
}
.hero__inner{padding-block:clamp(2.5rem,6vw,5rem);max-width:50rem}
.hero__tagline{
  font:600 .82rem/1 var(--font-sans);letter-spacing:.32em;text-transform:uppercase;
  color:var(--daisy);margin-bottom:1.3rem;display:flex;align-items:center;gap:.8rem;
}
.hero__tagline span{height:1px;width:46px;background:var(--daisy);opacity:.7}
.hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.35);margin-bottom:.5rem}
.hero h1 em{font-style:italic;color:var(--daisy);font-weight:460}
.hero__sub{font-size:clamp(1.1rem,1.7vw,1.4rem);color:#EEF4EA;max-width:40ch;margin-bottom:2rem;line-height:1.5}
.hero .btn-row{margin-bottom:2.4rem}
.hero__seasons{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;font-size:.85rem;color:#D9E6D4}
.hero__seasons img{width:34px;height:34px;border-radius:8px}
.scroll-cue{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);z-index:1;color:rgba(255,255,255,.7);display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase}
.scroll-cue .line{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.5);transform-origin:top}50%{transform:scaleY(1)}}

/* ---------- Intro ---------- */
.intro__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.intro__statlist{display:flex;gap:2.4rem;flex-wrap:wrap;margin-top:1.6rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.stat .num{font-family:var(--font-display);font-size:clamp(2.1rem,3.4vw,3rem);color:var(--forest);line-height:1}
.stat .lbl{font-size:.86rem;color:var(--ink-soft);margin-top:.3rem;max-width:16ch}
.intro__media{position:relative}
.intro__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover;width:100%}
.intro__media .credit{position:absolute;bottom:10px;right:14px;font-size:.7rem;color:rgba(255,255,255,.85);text-shadow:0 1px 4px rgba(0,0,0,.6)}
.leaf-badge{position:absolute;top:-26px;left:-26px;width:96px;height:96px;background:var(--daisy);border-radius:50%;display:grid;place-items:center;color:var(--ink);font-family:var(--font-display);font-size:.8rem;text-align:center;line-height:1.1;font-weight:600;box-shadow:var(--shadow);rotate:-8deg}
@media (max-width:840px){.intro__grid{grid-template-columns:1fr}.leaf-badge{display:none}}

/* ---------- Seasons ---------- */
.seasons-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:clamp(2rem,4vw,3.2rem);flex-wrap:wrap}
.season-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.season-card{
  --c:var(--leaf);
  background:var(--card);border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;position:relative;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s;
}
.season-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.season-card__top{height:8px;background:var(--c)}
.season-card__body{padding:1.6rem 1.5rem 1.7rem;display:flex;flex-direction:column;flex:1}
.season-card__mark{width:74px;height:74px;border-radius:16px;margin-bottom:1.1rem;box-shadow:var(--shadow-sm)}
.season-card h3{margin-bottom:.15rem}
.season-card .theme{font-family:var(--font-display);font-style:italic;color:var(--c);font-size:1.05rem;margin-bottom:.7rem;filter:saturate(.85) brightness(.78)}
.season-card .when{font-size:.8rem;font-weight:650;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.7rem}
.season-card p{font-size:.93rem;color:var(--ink-soft);margin-bottom:1.1rem}
.season-card .more{margin-top:auto;font-weight:650;color:var(--ink);font-size:.92rem;display:inline-flex;align-items:center;gap:.4em}
.season-card .more::after{content:"→";transition:transform .25s}
.season-card:hover .more::after{transform:translateX(4px)}
.season-card .flag{position:absolute;top:1.1rem;right:1.1rem;background:var(--c);color:#fff;font-size:.66rem;font-weight:750;letter-spacing:.08em;text-transform:uppercase;padding:.3em .7em;border-radius:100px}
.season-card.is-spring .flag{color:#2c4a06}
@media (max-width:980px){.season-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.season-grid{grid-template-columns:1fr}}

/* ---------- Gallery mosaic ---------- */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.mosaic figure{margin:0;border-radius:var(--radius);overflow:hidden;position:relative}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.mosaic figure:hover img{transform:scale(1.06)}
.mosaic .tall{grid-row:span 2}
.mosaic .wide{grid-column:span 2}
.mosaic figcaption{position:absolute;left:14px;bottom:12px;color:#fff;font-size:.82rem;font-weight:600;text-shadow:0 1px 8px rgba(0,0,0,.6);opacity:0;transform:translateY(6px);transition:.3s}
.mosaic figure:hover figcaption{opacity:1;transform:none}
@media (max-width:820px){.mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}.mosaic .wide{grid-column:span 2}}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--reverse .split__media{order:2}
.split__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%;aspect-ratio:5/4;object-fit:cover}
.split__media{position:relative}
@media (max-width:840px){.split{grid-template-columns:1fr}.split--reverse .split__media{order:0}}

.checklist{list-style:none;padding:0;margin:1.4rem 0 1.8rem;display:grid;gap:.7rem}
.checklist li{display:flex;gap:.8rem;align-items:flex-start;font-size:.98rem;color:var(--ink-soft)}
.checklist svg{flex:0 0 auto;width:22px;height:22px;color:var(--leaf);margin-top:2px}
.bg-forest .checklist li,.bg-ink .checklist li{color:#D6E4D1}
.bg-forest .checklist svg,.bg-ink .checklist svg{color:var(--daisy)}

/* ---------- Tiers (Friends / membership) ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;align-items:stretch}
.tier{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2rem 1.8rem;display:flex;flex-direction:column;position:relative;box-shadow:var(--shadow-sm)}
.tier.is-featured{border-color:var(--forest);box-shadow:var(--shadow);transform:translateY(-6px)}
.tier .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--orange);color:#3a2400;font-size:.7rem;font-weight:750;letter-spacing:.08em;text-transform:uppercase;padding:.4em .9em;border-radius:100px}
.tier h3{margin-bottom:.2rem}
.tier .price{font-family:var(--font-display);font-size:2.4rem;color:var(--forest);line-height:1;margin:.4rem 0 .1rem}
.tier .price span{font-size:.95rem;color:var(--ink-faint);font-family:var(--font-sans)}
.tier .ph{font-size:.78rem;color:var(--orange-600);font-weight:600;letter-spacing:.02em;margin-bottom:1.1rem}
.tier ul{list-style:none;padding:0;margin:0 0 1.6rem;display:grid;gap:.6rem}
.tier li{display:flex;gap:.6rem;font-size:.92rem;color:var(--ink-soft)}
.tier li svg{width:18px;height:18px;color:var(--leaf);flex:0 0 auto;margin-top:3px}
.tier .btn{margin-top:auto;justify-content:center}
@media (max-width:880px){.tiers{grid-template-columns:1fr}.tier.is-featured{transform:none}}

/* ---------- Cards row (shop / events) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.pcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.pcard__img{aspect-ratio:3/2;overflow:hidden;background:var(--paper-3)}
.pcard__img img{width:100%;height:100%;object-fit:cover}
.pcard__body{padding:1.3rem 1.4rem 1.5rem}
.pcard .tag{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--leaf)}
.pcard h3{font-size:1.2rem;margin:.4rem 0 .4rem}
.pcard p{font-size:.9rem;color:var(--ink-soft);margin:0}
.pcard .price-ph{margin-top:.9rem;font-weight:650;color:var(--orange-600);font-size:.9rem}
@media (max-width:860px){.cards{grid-template-columns:1fr}}

/* ---------- Placeholder chip ---------- */
.ph-chip{display:inline-block;background:repeating-linear-gradient(45deg,#fbe9c8,#fbe9c8 7px,#f7dca8 7px,#f7dca8 14px);color:#7a5200;border:1px dashed #d49b2a;font-size:.72rem;font-weight:700;letter-spacing:.04em;padding:.2em .6em;border-radius:6px}

/* ---------- Supporters ---------- */
.supporters{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}
.logo-slot{aspect-ratio:3/2;border:1px dashed var(--line-strong);border-radius:14px;display:grid;place-items:center;color:var(--ink-faint);font-size:.78rem;text-align:center;background:#fff;padding:.5rem}
.logo-slot.confirmed{border-style:solid;border-color:var(--leaf);color:var(--forest);font-weight:700;background:#F1F7EC}
.logo-slot .tick{display:block;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--leaf);font-weight:700;margin-top:.3rem}
@media (max-width:820px){.supporters{grid-template-columns:repeat(2,1fr)}}

/* ---------- Newsletter ---------- */
.signup{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center;background:var(--forest);color:#EAF3E5;border-radius:var(--radius-lg);padding:clamp(2rem,5vw,3.6rem);overflow:hidden;position:relative}
.signup h2{color:#fff}
.signup .lead,.signup p{color:#D7E6D1}
.signup form{display:flex;gap:.6rem;flex-wrap:wrap}
.signup input{flex:1;min-width:200px;padding:.95em 1.2em;border-radius:100px;border:1.5px solid rgba(255,255,255,.3);background:rgba(255,255,255,.08);color:#fff;font-size:1rem}
.signup input::placeholder{color:rgba(255,255,255,.6)}
.signup .fineprint{font-size:.78rem;color:#AFC8A8;margin-top:.9rem}
@media (max-width:760px){.signup{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#C3D2BD;font-size:.92rem}
.footer .container{padding-block:clamp(3rem,6vw,5rem)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
.footer img.flogo{height:46px;margin-bottom:1rem;filter:brightness(0) invert(1);opacity:.95}
.footer h4{color:#fff;font-family:var(--font-sans);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1rem;font-weight:700}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.55rem}
.footer a:hover{color:#fff}
.footer__ack{margin-top:2.5rem;padding-top:1.8rem;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;font-size:.82rem;color:#8FA489}
.footer__social{display:flex;gap:.8rem}
.footer__social a{width:38px;height:38px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:grid;place-items:center;transition:.2s}
.footer__social a:hover{background:var(--leaf);border-color:var(--leaf);color:var(--ink)}
.footer__social svg{width:18px;height:18px}
@media (max-width:820px){.footer__top{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.footer__top{grid-template-columns:1fr}}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__bg img{animation:none}
  html{scroll-behavior:auto}
}

/* ---------- Section divider leaf ---------- */
.divider{display:flex;align-items:center;gap:1rem;color:var(--leaf);justify-content:center;margin-bottom:2.4rem}
.divider .ln{height:1px;width:min(120px,18vw);background:var(--line-strong)}
.divider svg{width:30px;height:30px}

/* =========================================================================
   Inner-page components (Foundation, etc.)
   ========================================================================= */

/* Compact page hero */
.page-hero{position:relative;color:#fff;isolation:isolate;display:flex;align-items:flex-end;min-height:clamp(360px,50vh,540px)}
.page-hero__bg{position:absolute;inset:0;z-index:-2;overflow:hidden}
.page-hero__bg img{width:100%;height:100%;object-fit:cover}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(8deg,rgba(9,28,15,.86) 8%,rgba(9,28,15,.34) 58%,rgba(9,28,15,.10) 100%)}
.page-hero__inner{padding-block:clamp(2.2rem,5vw,3.8rem);max-width:48rem}
.page-hero h1{color:#fff;font-size:clamp(2.2rem,5vw,3.8rem);text-shadow:0 2px 24px rgba(0,0,0,.4);margin-bottom:.4rem}
.page-hero h1 em{font-style:italic;color:var(--daisy);font-weight:460}
.page-hero .lead{color:#EEF4EA;max-width:44ch}
.page-hero .eyebrow{color:var(--daisy)}
.page-hero .eyebrow::before{background:var(--daisy)}
.breadcrumb{font-size:.82rem;color:var(--ink-faint);margin-bottom:1.6rem}
.breadcrumb a:hover{color:var(--forest)}

/* Card footer (price + button pinned to bottom) */
.pcard__body{display:flex;flex-direction:column;flex:1}
.pcard .cardfoot{margin-top:auto;padding-top:1.1rem}
.pcard .cardfoot .btn{margin-top:.7rem;width:100%;justify-content:center}

/* Impact stats on dark bands */
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;text-align:center}
.bg-forest .stat .num,.bg-ink .stat .num{color:var(--daisy)}
.bg-forest .stat .lbl,.bg-ink .stat .lbl{color:#CFE0CA;margin-inline:auto}
@media (max-width:760px){.impact-grid{grid-template-columns:repeat(2,1fr)}}

/* Pull quote */
.quote{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.28;font-style:italic;max-width:22ch;margin:0}
.quote cite{display:block;font-style:normal;font-family:var(--font-sans);font-size:.9rem;letter-spacing:.04em;color:var(--ink-faint);margin-top:1rem}
.bg-forest .quote cite{color:#AFC8A8}
