/* ============================================================
   COMMONWELL — community wellbeing charity
   Palette & type system adapted from a nature-park aesthetic
   ============================================================ */

:root{
  --cream:        #f5f5ef;
  --dark-green:   #223c36;
  --neutral-green:#c5c6b1;
  --light-green:  #c9dd44;
  --green:        #71a34f;
  --orange:       #7b4fb0; /* accent (plum purple) */
  --yellow:       #f3b948;
  --ink:          #223c36;
  --muted:        #5c6b62;

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 80px);
  --radius: 22px;

  --font-display: 'Anton', Impact, sans-serif;
  --font-sub: 'Antonio', sans-serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }

/* ---------- Lenis ---------- */
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }

/* ---------- Typography ---------- */
.h2{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(2.1rem, 5.2vw, 4.1rem);
  line-height:.98;
  letter-spacing:.5px;
  text-transform:uppercase;
  margin:.1em 0 .35em;
  color:var(--dark-green);
}
.h2--light{ color:var(--cream); }

.eyebrow{
  font-family:var(--font-sub);
  text-transform:uppercase;
  letter-spacing:3px;
  font-weight:600;
  font-size:.82rem;
  margin:0 0 .4rem;
}
.eyebrow--green{ color:var(--green); }
.eyebrow--cream{ color:var(--light-green); }

/* split-text helper */
.split-line{ display:block; overflow:hidden; }
.split-line > span{ display:inline-block; will-change:transform; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--font-sub); font-weight:600; letter-spacing:.5px;
  text-transform:uppercase; font-size:.92rem;
  padding:.85em 1.6em; border-radius:100px; border:2px solid transparent;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn--solid{ background:var(--orange); color:#fff; box-shadow:0 8px 22px -8px rgba(123,79,176,.7); }
.btn--solid:hover{ background:#6a3fa0; }
.btn--ghost{ background:transparent; border-color:var(--dark-green); color:var(--dark-green); }
.btn--ghost:hover{ background:var(--dark-green); color:var(--cream); }
.btn--ghost-light{ border-color:rgba(255,255,255,.8); color:#fff; }
.btn--ghost-light:hover{ background:#fff; color:var(--dark-green); }
.btn--lg{ padding:1.05em 2em; font-size:1rem; }
.btn--block{ width:100%; }

.link-arrow{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font-sub); font-weight:600; text-transform:uppercase;
  letter-spacing:1px; font-size:.9rem; color:var(--orange);
  border-bottom:2px solid transparent; padding-bottom:2px; transition:.25s;
}
.link-arrow span{ transition:transform .25s; }
.link-arrow:hover span{ transform:translateX(5px); }
.link-arrow:hover{ border-color:currentColor; }
.link-arrow--green{ color:var(--green); }
.link-arrow--orange{ color:var(--orange); }

/* ---------- Ticks list ---------- */
.ticks li{ position:relative; padding-left:1.9em; margin:.5em 0; }
.ticks li::before{
  content:""; position:absolute; left:0; top:.15em;
  width:1.2em; height:1.2em; border-radius:50%;
  background:var(--light-green);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/85% no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/85% no-repeat;
}
.ticks--sm li{ font-size:.95rem; margin:.35em 0; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
  padding:18px 0;
}
.nav.scrolled{
  background:var(--cream);
  box-shadow:0 6px 30px -12px rgba(34,60,54,.35);
  padding:10px 0;
}
.nav__inner{
  max-width:none; margin:0 auto; padding:0 clamp(22px,3vw,48px);
  display:flex; align-items:center; gap:24px;
}
.brand{ display:flex; align-items:center; gap:10px; color:var(--dark-green); }
.brand__name{
  font-family:var(--font-display); font-size:1.5rem; letter-spacing:1px;
  text-transform:uppercase; color:var(--dark-green);
}
.nav:not(.scrolled) .brand__name{ color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.3); }

/* logo (SVG used as a mask so it follows the brand text colour and
   stays visible as the header flips between transparent and cream) */
.brand__logo{
  display:block; width:52px; height:59px; flex:0 0 auto;
  background-color:currentColor;
  -webkit-mask:url('../assets/logo.svg') center/contain no-repeat;
          mask:url('../assets/logo.svg') center/contain no-repeat;
  transition:background-color .35s ease;
}
.nav .brand{ color:var(--dark-green); }
.nav:not(.scrolled) .brand{ color:#fff; }
.nav:not(.scrolled) .brand__logo{ filter:drop-shadow(0 2px 10px rgba(0,0,0,.35)); }
.brand--footer{ color:var(--cream); }
.brand--footer .brand__logo{ width:66px; height:75px; }
.nav__links{ display:flex; gap:22px; margin-left:auto; }
.nav__links a{
  font-family:var(--font-sub); font-weight:500; font-size:.98rem;
  color:var(--dark-green); position:relative; padding:4px 0;
}
.nav:not(.scrolled) .nav__links a{ color:#fff; text-shadow:0 1px 8px rgba(0,0,0,.35); }
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--orange); transition:width .25s ease;
}
.nav__links a:hover::after{ width:100%; }
.nav__actions{ display:flex; gap:10px; }
.nav__actions .btn{ padding:.6em 1.2em; font-size:.85rem; }
.nav:not(.scrolled) .nav__actions .btn--ghost{ border-color:rgba(255,255,255,.85); color:#fff; }
.nav:not(.scrolled) .nav__actions .btn--ghost:hover{ background:#fff; color:var(--dark-green); }

.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:6px; }
.nav__burger span{ width:26px; height:2.5px; background:var(--dark-green); border-radius:2px; transition:.3s; }
.nav:not(.scrolled) .nav__burger span{ background:#fff; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; flex-direction:column;
  align-items:stretch; overflow:hidden; color:#fff;
}
.hero__media{ position:absolute; inset:0; z-index:-2; background:var(--dark-green); }
.hero__video{ width:100%; height:100%; object-fit:cover; background:var(--dark-green); }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(34,60,54,.55) 0%, rgba(34,60,54,.15) 35%, rgba(34,60,54,.65) 100%),
    radial-gradient(120% 90% at 20% 80%, rgba(34,60,54,.55), transparent 60%);
}
.hero__content{
  flex:1 1 auto; display:flex; flex-direction:column; justify-content:center;
  align-items:flex-start; max-width:820px; padding:150px var(--pad) 40px;
}
.hero__eyebrow{
  font-family:var(--font-sub); text-transform:uppercase; letter-spacing:3px;
  font-size:.82rem; font-weight:600; color:var(--light-green); margin:0 0 1rem;
}
.hero__title{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(3rem, 9vw, 7rem); line-height:.92; letter-spacing:1px;
  text-transform:uppercase; margin:0 0 .35em; text-shadow:0 4px 30px rgba(0,0,0,.3);
}
.hero__lede{ font-size:clamp(1.05rem,1.6vw,1.35rem); max-width:560px; margin:0 0 2rem; color:rgba(255,255,255,.92); }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; }

.hero__strip{
  position:relative; z-index:2; width:100%; margin-top:auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  background:rgba(34,60,54,.72); backdrop-filter:blur(8px);
  border-top:1px solid rgba(255,255,255,.12);
}
.strip__item{ padding:22px var(--pad); text-align:center; border-right:1px solid rgba(255,255,255,.12); }
.strip__item:last-child{ border-right:0; }
.strip__num{ display:block; font-family:var(--font-display); font-size:clamp(1.8rem,3.5vw,2.8rem); color:var(--light-green); line-height:1; }
.strip__label{ font-family:var(--font-sub); text-transform:uppercase; letter-spacing:1.5px; font-size:.72rem; color:rgba(255,255,255,.8); }

.hero__scrollcue{
  position:absolute; left:50%; bottom:150px; transform:translateX(-50%); z-index:3;
  width:26px; height:42px; border:2px solid rgba(255,255,255,.7); border-radius:14px;
}
.hero__scrollcue span{
  position:absolute; left:50%; top:8px; width:4px; height:8px; margin-left:-2px;
  background:#fff; border-radius:2px; animation:scrollcue 1.6s infinite;
}
@keyframes scrollcue{ 0%{opacity:0;transform:translateY(0)} 30%{opacity:1} 100%{opacity:0;transform:translateY(14px)} }

/* ---------- blob divider ---------- */
.blob-divider{ position:relative; margin-top:-1px; line-height:0; background:transparent; }
.blob-divider svg{ width:100%; height:90px; display:block; }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ position:relative; padding:40px var(--pad) 110px; max-width:var(--maxw); margin:0 auto; }
.about__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(30px,6vw,90px); align-items:center; }
.about__media{ position:relative; }
.blobshape{
  border-radius:64% 36% 57% 43% / 47% 56% 44% 53%;
  overflow:hidden; aspect-ratio:4/3.4; box-shadow:0 30px 60px -25px rgba(34,60,54,.45);
}
.blobshape img{ width:100%; height:100%; object-fit:cover; }
.about__badge{
  position:absolute; right:-12px; bottom:-18px; background:var(--orange); color:#fff;
  width:140px; height:140px; border-radius:50%; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; font-size:.8rem; line-height:1.2;
  padding:14px; box-shadow:0 18px 40px -14px rgba(123,79,176,.7); font-weight:600;
}
.about__badge span{ font-family:var(--font-display); font-size:2.6rem; display:block; }
.about__text p{ color:var(--muted); margin:.9em 0; }
.about__text .ticks{ margin:1.4em 0; }
.about__text .ticks li{ color:var(--ink); font-weight:500; }
.deco--about{ position:absolute; top:30px; right:6%; opacity:.6; width:110px; }

/* ============================================================
   SECTION HEADS
   ============================================================ */
.section-head{ max-width:760px; margin:0 auto clamp(40px,5vw,64px); text-align:center; }
.section-head__sub{ color:var(--muted); font-size:1.08rem; max-width:600px; margin:.4em auto 0; }
.section-head--light .section-head__sub{ color:rgba(255,255,255,.85); }

/* ============================================================
   PROGRAMMES
   ============================================================ */
.programmes{ padding:60px var(--pad) 110px; max-width:var(--maxw); margin:0 auto; }
/* Three-part rows: intro | image | "how it works" panel (colour alternates) */
.prog-rows{ display:flex; flex-direction:column; gap:26px; }
.prog-row{
  display:grid;
  grid-template-columns:1fr 1.18fr 1.12fr;
  grid-template-areas:"intro img how";
  background:#fff; border-radius:var(--radius); overflow:hidden;
  /* thin divider so each stacked card stays distinct at its top edge */
  border-top:1.5px solid #1f2d28;
  box-shadow:0 18px 45px -30px rgba(34,60,54,.5);
  min-height:320px;
}
.prog-row__intro{ grid-area:intro; padding:60px clamp(26px,2.8vw,44px) clamp(26px,2.8vw,44px); display:flex; flex-direction:column; justify-content:center; }
.prog-row__intro h3{
  font-family:var(--font-display); font-weight:400; text-transform:uppercase;
  font-size:clamp(1.7rem,2.5vw,2.4rem); line-height:1; letter-spacing:.5px;
  margin:.28em 0 .12em; color:var(--dark-green);
}
.prog-row__meta{ font-family:var(--font-sub); font-weight:600; text-transform:uppercase; letter-spacing:.5px; font-size:.8rem; color:var(--green); margin:0 0 1em; }
.prog-row__intro > p:last-child{ color:var(--muted); margin:0; font-size:1rem; }
.prog-row__tag{
  position:absolute; top:20px; left:clamp(26px,2.8vw,44px); z-index:3; margin:0;
  font-family:var(--font-sub); text-transform:uppercase;
  letter-spacing:1px; font-size:.72rem; font-weight:600; padding:.35em .95em; border-radius:100px; color:var(--dark-green);
}
.prog-row__img{ grid-area:img; position:relative; min-height:240px; overflow:hidden; }
.prog-row__img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.2,.8,.2,1); }
.prog-row:hover .prog-row__img img{ transform:scale(1.06); }

.prog-row__how{ grid-area:how; padding:clamp(26px,2.8vw,44px); display:flex; flex-direction:column; justify-content:center; color:#fff; }
.prog-row__how h4{ font-family:var(--font-display); font-weight:400; text-transform:uppercase; letter-spacing:1px; font-size:clamp(1.4rem,2.2vw,2rem); margin:0 0 .7em; }
.prog-row__how ol{ counter-reset:step; list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.85em; }
.prog-row__how li{ position:relative; padding-left:2.6em; counter-increment:step; font-size:.97rem; line-height:1.45; }
.prog-row__how li::before{
  content:counter(step); position:absolute; left:0; top:-.1em;
  width:1.8em; height:1.8em; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-sub); font-weight:700; font-size:.82em;
  background:rgba(255,255,255,.22);
}
/* accent variants */
.prog-row[data-accent="green"]  .prog-row__how{ background:var(--green); }
.prog-row[data-accent="orange"] .prog-row__how{ background:var(--orange); }
.prog-row[data-accent="yellow"] .prog-row__how{ background:var(--yellow); color:var(--dark-green); }
.prog-row[data-accent="yellow"] .prog-row__how li::before{ background:rgba(34,60,54,.16); }
.prog-row[data-accent="green"]  .prog-row__tag{ background:var(--light-green); }
.prog-row[data-accent="yellow"] .prog-row__tag{ background:var(--yellow); }
.prog-row[data-accent="orange"] .prog-row__tag{ background:#dccff2; }

/* Sticky "stacking deck": each row pins a little lower than the last, so as
   you scroll they pile up on top of one another. Active at every width. */
.prog-rows{ gap:22px; }
.prog-row{ position:sticky; will-change:transform; }
.prog-row:nth-child(1){ top:96px; }
.prog-row:nth-child(2){ top:148px; }
.prog-row:nth-child(3){ top:200px; }
.prog-row:nth-child(4){ top:252px; }
.prog-row:nth-child(5){ top:304px; }
.prog-row:nth-child(6){ top:356px; }

/* ============================================================
   EVENTS (host)
   ============================================================ */
.events{ background:var(--dark-green); color:var(--cream); position:relative; overflow:hidden; }
.events::before{
  content:""; position:absolute; top:-60px; left:-60px; width:280px; height:280px;
  background:radial-gradient(circle, rgba(201,221,68,.16), transparent 70%); border-radius:50%;
}
.events__grid{
  max-width:var(--maxw); margin:0 auto; padding:clamp(60px,8vw,110px) var(--pad);
  display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(30px,6vw,80px); align-items:center;
}
.events__text p{ color:rgba(245,245,239,.85); }
.events__list{ margin:1.6em 0; }
.events__list li{ padding:.7em 0; border-bottom:1px solid rgba(255,255,255,.14); }
.events__list strong{ color:var(--light-green); }
.events__cta{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-top:1.2em; }
.events__from{ font-family:var(--font-sub); text-transform:uppercase; letter-spacing:1px; font-size:.85rem; color:rgba(255,255,255,.7); }
.events__media{ border-radius:48% 52% 60% 40% / 52% 45% 55% 48%; overflow:hidden; aspect-ratio:1/1; box-shadow:0 30px 60px -25px rgba(0,0,0,.5); }
.events__media img,.events__media video{ width:100%; height:100%; object-fit:cover; }

/* ============================================================
   PARTNER
   ============================================================ */
.partner{ padding:clamp(70px,9vw,120px) var(--pad); max-width:var(--maxw); margin:0 auto; }
/* sticky stacking deck — same behaviour as the programme rows */
.partner__grid{ display:flex; flex-direction:column; gap:22px; }
.partner__card{
  display:grid; grid-template-columns:.95fr 1.05fr; grid-template-areas:"img body";
  background:#fff; border-radius:var(--radius); overflow:hidden;
  box-shadow:0 18px 45px -30px rgba(34,60,54,.5);
  border-top:6px solid var(--accent, var(--green));
  min-height:360px; position:sticky; will-change:transform;
}
.partner__card:nth-child(1){ top:108px; }
.partner__card:nth-child(2){ top:150px; }
.partner__img{ grid-area:img; position:relative; min-height:300px; overflow:hidden; }
.partner__img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.partner__body{ grid-area:body; padding:clamp(28px,3vw,46px); display:flex; flex-direction:column; justify-content:center; }
.partner__kicker{ font-family:var(--font-sub); text-transform:uppercase; letter-spacing:2px; font-size:.78rem; font-weight:600; color:var(--accent,var(--green)); }
.partner__body h3{ font-family:var(--font-display); font-weight:400; text-transform:uppercase; font-size:clamp(1.6rem,2.6vw,2.2rem); margin:.2em 0 .4em; color:var(--dark-green); line-height:1; }
.partner__body p{ color:var(--muted); }
.partner__body .ticks{ margin:1.2em 0 1.6em; }

/* ============================================================
   FAQs
   ============================================================ */
.faqs{ background:var(--neutral-green); padding:clamp(70px,9vw,120px) var(--pad); }
.faqs__inner{ max-width:980px; margin:0 auto; display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(30px,5vw,70px); align-items:start; }
.faqs__head{ position:sticky; top:110px; }
.faqs__head p{ color:var(--muted); }
.faqs__head a{ color:var(--green); font-weight:600; border-bottom:2px solid currentColor; }
.accordion{ display:flex; flex-direction:column; gap:12px; }
.acc-item{ background:var(--cream); border-radius:16px; overflow:hidden; box-shadow:0 10px 30px -22px rgba(34,60,54,.5); }
.acc-q{
  width:100%; text-align:left; background:none; border:0; padding:20px 22px;
  font-family:var(--font-sub); font-weight:600; font-size:1.08rem; color:var(--dark-green);
  display:flex; justify-content:space-between; align-items:center; gap:16px;
}
.acc-icon{ position:relative; flex:0 0 18px; height:18px; }
.acc-icon::before,.acc-icon::after{ content:""; position:absolute; background:var(--orange); border-radius:2px; transition:.3s; }
.acc-icon::before{ top:8px; left:0; width:18px; height:2.5px; }
.acc-icon::after{ left:8px; top:0; width:2.5px; height:18px; }
.acc-item.open .acc-icon::after{ transform:scaleY(0); }
.acc-a{ max-height:0; overflow:hidden; transition:max-height .4s ease; }
.acc-a p{ padding:0 22px 22px; margin:0; color:var(--muted); }
.acc-a a{ color:var(--green); font-weight:600; }

/* ============================================================
   VOICES
   ============================================================ */
.voices{ background:var(--green); padding:clamp(70px,9vw,120px) var(--pad) clamp(90px,11vw,140px); position:relative; }
.voices-swiper{ max-width:880px; margin:0 auto; overflow:visible; }
.voice{ background:var(--cream); border-radius:26px; padding:clamp(30px,4vw,52px); margin:0; text-align:center; box-shadow:0 30px 60px -30px rgba(0,0,0,.45); }
.voice__hearts{ color:var(--orange); letter-spacing:4px; font-size:1.1rem; margin-bottom:1rem; }
.voice blockquote{ font-family:var(--font-sub); font-weight:500; font-size:clamp(1.2rem,2.3vw,1.6rem); line-height:1.4; color:var(--dark-green); margin:0 0 1.4em; }
.voice figcaption{ display:flex; align-items:center; justify-content:center; gap:14px; }
.voice figcaption img{ width:58px; height:58px; border-radius:50%; object-fit:cover; }
.voice figcaption span{ text-align:left; font-size:.95rem; color:var(--muted); display:flex; flex-direction:column; }
.voice figcaption strong{ color:var(--dark-green); font-family:var(--font-sub); font-size:1.05rem; }
.voices-pagination{ text-align:center; margin-top:30px; }
.voices-pagination .swiper-pagination-bullet{ width:10px; height:10px; background:var(--cream); opacity:.5; transition:.3s; }
.voices-pagination .swiper-pagination-bullet-active{ opacity:1; width:28px; border-radius:6px; background:var(--light-green); }

/* ============================================================
   WAYS TO GIVE
   ============================================================ */
.give{ padding:clamp(70px,9vw,120px) var(--pad) clamp(80px,10vw,130px); max-width:var(--maxw); margin:0 auto; }
.give__toggle{ display:flex; gap:4px; width:max-content; margin:0 auto 44px; background:#fff; padding:5px; border-radius:100px; box-shadow:0 10px 30px -20px rgba(34,60,54,.5); }
.give__toggle button{ border:0; background:none; padding:.6em 1.5em; border-radius:100px; font-family:var(--font-sub); font-weight:600; text-transform:uppercase; letter-spacing:1px; font-size:.85rem; color:var(--muted); transition:.3s; }
.give__toggle button.is-active{ background:var(--dark-green); color:var(--cream); }
.give-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.give-card{ background:#fff; border-radius:var(--radius); padding:34px 26px 30px; text-align:center; position:relative; box-shadow:0 18px 45px -30px rgba(34,60,54,.5); border:2px solid transparent; transition:transform .35s, box-shadow .35s; display:flex; flex-direction:column; }
.give-card:hover{ transform:translateY(-6px); }
.give-card--featured{ border-color:var(--orange); box-shadow:0 30px 55px -28px rgba(123,79,176,.5); }
.give-card__flag{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--orange); color:#fff; font-family:var(--font-sub); text-transform:uppercase; letter-spacing:1px; font-size:.72rem; font-weight:600; padding:.35em 1em; border-radius:100px; white-space:nowrap; }
.give-card__amt{ font-family:var(--font-display); font-size:3.4rem; color:var(--dark-green); line-height:1; }
.give-card__cur{ font-size:1.6rem; vertical-align:super; margin-right:2px; }
.give-card__per{ font-family:var(--font-body); font-size:.95rem; font-weight:500; color:var(--muted); }
.give-card h3{ font-family:var(--font-sub); text-transform:uppercase; letter-spacing:1px; color:var(--green); font-size:1.1rem; margin:.5em 0 .3em; }
.give-card p{ color:var(--muted); font-size:.95rem; margin:0 0 1.6em; flex:1; }
.give__note{ text-align:center; color:var(--muted); margin-top:28px; font-size:.95rem; }
.give__note::before{ content:"✓ "; color:var(--green); font-weight:700; }

/* ============================================================
   GET INVOLVED
   ============================================================ */
.involved{ position:relative; padding:clamp(70px,9vw,120px) var(--pad); }
.involved__bg{ position:absolute; inset:0; background-size:cover; background-position:center; }
.involved__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(135deg, rgba(34,60,54,.92), rgba(34,60,54,.7)); }
.involved__panel{
  position:relative; max-width:1080px; margin:0 auto; background:var(--cream);
  border-radius:30px; overflow:hidden; display:grid; grid-template-columns:.9fr 1.1fr;
  box-shadow:0 40px 80px -40px rgba(0,0,0,.6);
}
.involved__intro{ padding:clamp(34px,4vw,56px); background:var(--neutral-green); }
.involved__intro p{ color:var(--ink); }
.involved__intro .ticks{ margin-top:1.4em; }
.involved__form{ padding:clamp(30px,4vw,48px); display:flex; flex-direction:column; gap:16px; }
.field{ display:flex; flex-direction:column; gap:6px; }
.field--row{ flex-direction:row; gap:16px; }
.field--row > div{ flex:1; display:flex; flex-direction:column; gap:6px; }
.field label{ font-family:var(--font-sub); font-weight:600; font-size:.88rem; color:var(--dark-green); text-transform:uppercase; letter-spacing:.5px; }
.field .opt{ color:var(--muted); font-weight:400; text-transform:none; letter-spacing:0; }
.field input,.field select,.field textarea{
  font-family:var(--font-body); font-size:1rem; padding:.8em 1em; border:2px solid #dcdccd;
  border-radius:12px; background:#fff; color:var(--ink); transition:border .25s; width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--green); }
.field textarea{ resize:vertical; }
.form-status{ font-size:.95rem; margin:0; min-height:1.2em; }
.form-status.ok{ color:var(--green); font-weight:600; }
.form-status.err{ color:var(--orange); font-weight:600; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--dark-green); color:rgba(245,245,239,.8); padding:clamp(60px,7vw,90px) var(--pad) 30px; }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px; }
.brand--footer .brand__name{ color:var(--cream); }
.footer__tag{ margin:1.2em 0; max-width:320px; font-size:.95rem; }
.footer__socials{ display:flex; gap:18px; }
.footer__socials a{ font-family:var(--font-sub); text-transform:uppercase; letter-spacing:1px; font-size:.85rem; color:var(--light-green); transition:.25s; }
.footer__socials a:hover{ color:#fff; }
.footer__col h4{ font-family:var(--font-sub); text-transform:uppercase; letter-spacing:1.5px; color:#fff; font-size:.92rem; margin:0 0 1em; }
.footer__col a{ display:block; padding:.32em 0; font-size:.95rem; transition:.25s; }
.footer__col a:hover{ color:var(--light-green); }
.footer__contact p{ margin:0 0 1em; font-size:.95rem; line-height:1.7; }
.footer__contact a{ display:inline; }
.footer__bottom{ max-width:var(--maxw); margin:40px auto 0; padding-top:24px; border-top:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:.85rem; }
.footer__legal a:hover{ color:var(--light-green); }
.footer__credit{ font-size:.82rem; color:rgba(245,245,239,.5); display:inline-block; transition:color .25s ease; transform-origin:center; }
.footer__credit:hover{ color:var(--light-green); animation:wiggle .55s ease; }
@keyframes wiggle{ 0%,100%{transform:rotate(0)} 15%{transform:rotate(-3deg)} 30%{transform:rotate(3deg)} 45%{transform:rotate(-2.5deg)} 60%{transform:rotate(2deg)} 75%{transform:rotate(-1deg)} }
@media (prefers-reduced-motion:reduce){ .footer__credit:hover{ animation:none; } }

/* ============================================================
   INNER PAGES — hero banner, breadcrumbs, sections, CTA band
   ============================================================ */
.nav__links a.active{ color:var(--orange); }
.nav__links a.active::after{ width:100%; }
.nav:not(.scrolled) .nav__links a.active{ color:#fff; text-decoration:underline; text-underline-offset:6px; }

.page-hero{
  position:relative; min-height:54vh; display:flex; align-items:flex-end;
  padding:170px var(--pad) 70px; overflow:hidden; color:#fff;
}
.page-hero__bg{ position:absolute; inset:0; z-index:-2; background-size:cover; background-position:center; transform:scale(1.05); }
.page-hero::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(to bottom, rgba(34,60,54,.5), rgba(34,60,54,.86)); }
.page-hero--plain{ background:var(--dark-green); }
.page-hero--plain::after{ display:none; }
.page-hero__inner{ max-width:var(--maxw); margin:0 auto; width:100%; }
.crumbs{ font-family:var(--font-sub); text-transform:uppercase; letter-spacing:2px; font-size:.78rem; color:var(--light-green); margin:0 0 1.1rem; display:flex; gap:.6em; align-items:center; }
.crumbs a{ color:rgba(255,255,255,.85); }
.crumbs a:hover{ color:#fff; }
.page-hero__title{ font-family:var(--font-display); font-weight:400; text-transform:uppercase; font-size:clamp(2.6rem,7vw,5.4rem); line-height:.95; letter-spacing:1px; margin:0 0 .25em; text-shadow:0 4px 30px rgba(0,0,0,.25); }
.page-hero__lede{ font-size:clamp(1.05rem,1.5vw,1.3rem); max-width:640px; color:rgba(255,255,255,.92); margin:0; }

.page-section{ max-width:var(--maxw); margin:0 auto; padding:clamp(60px,8vw,100px) var(--pad); }
.page-section--tint{ background:var(--neutral-green); }
.page-section--green{ background:var(--green); color:#fff; }
.page-section--dark{ background:var(--dark-green); color:var(--cream); }
.page-section__wrap{ max-width:var(--maxw); margin:0 auto; padding:clamp(60px,8vw,100px) var(--pad); }
.prose{ max-width:760px; }
.prose p{ color:var(--muted); margin:0 0 1.1em; font-size:1.06rem; }
.lead{ font-size:1.18rem !important; color:var(--dark-green) !important; font-weight:500; }

/* generic two-column feature */
.feature{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,6vw,70px); align-items:center; }
.feature + .feature{ margin-top:clamp(50px,7vw,90px); }
.feature--rev .feature__media{ order:2; }
.feature__media{ border-radius:var(--radius); overflow:hidden; box-shadow:0 30px 60px -30px rgba(34,60,54,.45); aspect-ratio:4/3.2; }
.feature__media img{ width:100%; height:100%; object-fit:cover; }
.feature__body h2{ margin-top:0; }
.feature__body p{ color:var(--muted); margin:.7em 0; }

/* simple card grid */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.cards--2{ grid-template-columns:repeat(2,1fr); }
.card{ background:#fff; border-radius:var(--radius); padding:34px 30px; box-shadow:0 18px 45px -30px rgba(34,60,54,.5); }
.card__ic{ width:54px; height:54px; border-radius:15px; background:var(--light-green); display:flex; align-items:center; justify-content:center; font-size:1.6rem; margin-bottom:16px; }
.card h3{ font-family:var(--font-sub); font-weight:700; font-size:1.35rem; color:var(--dark-green); margin:0 0 .35em; }
.card p{ color:var(--muted); margin:0; font-size:.98rem; }

/* big outlined step numerals (How it works) */
.step__num{
  font-family:var(--font-display); font-weight:400; letter-spacing:1px;
  font-size:clamp(3rem,4.6vw,4.4rem); line-height:.82; display:inline-block;
  margin:0 0 .14em; color:transparent;
  -webkit-text-stroke:2px var(--green); text-stroke:2px var(--green);
}
.step__num::after{
  content:""; display:block; width:2rem; height:5px; border-radius:3px;
  background:var(--light-green); margin-top:.16em;
}

/* CTA band */
.cta-band{ background:var(--dark-green); color:var(--cream); text-align:center; padding:clamp(64px,8vw,110px) var(--pad); position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; top:-80px; right:-80px; width:320px; height:320px; background:radial-gradient(circle, rgba(201,221,68,.16), transparent 70%); border-radius:50%; }
.cta-band__inner{ max-width:760px; margin:0 auto; position:relative; }
.cta-band h2{ font-family:var(--font-display); font-weight:400; text-transform:uppercase; font-size:clamp(2rem,5vw,3.6rem); line-height:1; margin:0 0 .4em; }
.cta-band p{ color:rgba(245,245,239,.85); max-width:540px; margin:0 auto 1.7em; }
.cta-band__btns{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cta-band .btn--ghost{ border-color:rgba(255,255,255,.8); color:#fff; }
.cta-band .btn--ghost:hover{ background:#fff; color:var(--dark-green); }

/* stats bar (inner pages) */
.statbar{ display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid rgba(255,255,255,.16); border-bottom:1px solid rgba(255,255,255,.16); }
.statbar > div{ padding:32px 18px; text-align:center; border-right:1px solid rgba(255,255,255,.16); }
.statbar > div:last-child{ border-right:0; }
.statnum{ display:block; font-family:var(--font-display); font-size:clamp(2rem,3.6vw,3rem); color:var(--light-green); line-height:1; }
.statlabel{ font-family:var(--font-sub); text-transform:uppercase; letter-spacing:1.5px; font-size:.74rem; color:rgba(255,255,255,.8); }

/* ============================================================
   REVEAL (GSAP fallback baseline)
   ============================================================ */
.reveal{ opacity:0; transform:translateY(40px); }
.reveal.in{ opacity:1; transform:none; transition:opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* Desktop nav already shows Donate + Get involved permanently,
   so the hero CTA buttons are redundant there (they bled through
   the translucent impact strip). Keep them only on mobile, where
   the nav collapses to a burger. */
@media (min-width:1025px){
  .hero__cta{ display:none; }
}
/* On shorter desktop windows, scale the hero down so the impact strip
   (with the count-up numbers) always stays inside the first screen. */
@media (min-width:1025px) and (max-height:880px){
  .hero__content{ padding-top:118px; padding-bottom:24px; }
  .hero__title{ font-size:clamp(2.8rem, 8.5vh, 5.4rem); }
  .hero__lede{ font-size:1.05rem; margin-bottom:1rem; }
}

@media (max-width:1024px){
  .nav__links{ display:none; }
  .nav__burger{ display:flex; margin-left:auto; }
  .nav__actions{ display:none; }
  .about__grid,.events__grid,.faqs__inner,.involved__panel{ grid-template-columns:1fr; }
  .faqs__head{ position:static; }
  .prog-row{ grid-template-columns:1fr 1fr; grid-template-areas:"img img" "intro how"; min-height:0; }
  .prog-row__img{ min-height:300px; }
  .give-grid{ grid-template-columns:repeat(2,1fr); }
  .partner__grid{ grid-template-columns:1fr; }
  .events__media{ max-width:480px; }
  .feature{ grid-template-columns:1fr; gap:30px; }
  .feature--rev .feature__media{ order:0; }
  .feature__media{ max-width:560px; }
  .cards{ grid-template-columns:repeat(2,1fr); }

  /* mobile menu */
  .nav__links.open{
    display:flex; flex-direction:column; position:absolute; top:100%; left:0; right:0;
    background:var(--cream); padding:20px var(--pad); gap:6px; box-shadow:0 20px 40px -20px rgba(0,0,0,.3);
  }
  .nav__links.open a{ color:var(--dark-green) !important; text-shadow:none !important; padding:10px 0; border-bottom:1px solid #e6e6da; }
}
@media (max-width:720px){
  .hero__content{ padding-top:100px; padding-bottom:24px; }
  .hero__strip{ grid-template-columns:repeat(2,1fr); }
  .strip__item:nth-child(2){ border-right:0; }
  .strip__item{ padding:16px; }
  .hero__scrollcue{ display:none; }
  /* compact single-column cards so each fits the screen when it pins.
     Intro (with its pill) goes on top so the pill stays visible in the
     peek strip as later cards stack over it. */
  .prog-rows{ gap:0; }
  .prog-row{ grid-template-columns:1fr; grid-template-areas:"intro" "img" "how"; min-height:0; }
  .prog-row__img{ min-height:160px; }
  .prog-row__intro{ padding:46px 22px 16px; justify-content:flex-start; }
  .prog-row__tag{ top:16px; left:22px; }
  .prog-row__intro h3{ font-size:1.7rem; margin-top:.1em; }
  .prog-row__intro > p:last-child{ font-size:.95rem; }
  .prog-row__how{ padding:20px 22px 26px; }
  .prog-row__how h4{ font-size:1.4rem; margin-bottom:.5em; }
  .prog-row__how li{ font-size:.92rem; }
  .prog-row:nth-child(1){ top:64px; }
  .prog-row:nth-child(2){ top:108px; }
  .prog-row:nth-child(3){ top:152px; }
  .prog-row:nth-child(4){ top:196px; }
  .prog-row:nth-child(5){ top:240px; }
  .prog-row:nth-child(6){ top:284px; }
  /* partner cards: vertical + sticky stack on mobile */
  .partner__card{ grid-template-columns:1fr; grid-template-areas:"img" "body"; min-height:0; }
  .partner__img{ min-height:190px; }
  .partner__card:nth-child(1){ top:72px; }
  .partner__card:nth-child(2){ top:104px; }
  .give-grid{ grid-template-columns:1fr; }
  .cards,.cards--2{ grid-template-columns:1fr; }
  .page-hero{ min-height:48vh; padding-top:130px; }
  .statbar{ grid-template-columns:repeat(2,1fr); }
  .statbar > div:nth-child(2){ border-right:0; }
  .field--row{ flex-direction:column; }
  .footer__top{ grid-template-columns:1fr 1fr; }
  .footer__brand{ grid-column:1/-1; }
  .about__badge{ width:110px; height:110px; }
  .about__badge span{ font-size:2rem; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; transition-duration:.05ms !important; }
  .reveal{ opacity:1; transform:none; }
}
