/* ============================================
   styles.css — EcoStyle Grove Design System
   All component styles for the Grove theme
   ============================================ */
.grove{ overflow-x:clip; }

/* ============================================
   NAV
   ============================================ */
.nav{ position:sticky; top:0; z-index:100; background:rgba(243,240,230,.82); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.nav .row{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; padding:.7rem 0; }
.brand{ display:flex; align-items:center; gap:.6rem; }
.brand img{ width:42px; height:42px; }
.brand b{ font-family:var(--serif); font-size:1.4rem; font-weight:500; color:var(--forest); letter-spacing:-.01em; }
.brand b span{ font-weight:700; }
.menu{ display:flex; align-items:center; gap:.4rem; }
.menu a{ font-weight:600; font-size:.94rem; color:var(--ink); padding:.5rem .85rem; border-radius:100px; transition:background .18s,color .18s; }
.menu a:hover{ background:var(--sage-mist); color:var(--forest); }
.menu a.active{ color:var(--forest); background:var(--sage-soft); }
.btn{ display:inline-flex; align-items:center; gap:.5rem; font-weight:700; border-radius:100px; border:1.5px solid transparent; transition:transform .16s, box-shadow .2s, background .2s; cursor:pointer; text-decoration:none; font-family:var(--sans); }
.btn .ic{ width:1.1em; height:1.1em; }
.btn-pri{ background:var(--forest); color:var(--cream); padding:.72rem 1.3rem; box-shadow:0 8px 20px -8px rgba(35,66,52,.6); }
.btn-pri:hover{ transform:translateY(-2px); box-shadow:0 14px 28px -10px rgba(35,66,52,.7); }
.btn-ghost{ border-color:rgba(255,255,255,.5); color:#fff; padding:.72rem 1.3rem; background:rgba(255,255,255,.06); }
.btn-ghost:hover{ background:rgba(255,255,255,.16); }
.btn-light{ background:#fff; color:var(--forest); padding:.78rem 1.4rem; box-shadow:0 10px 24px -10px rgba(0,0,0,.4); }
.btn-light:hover{ transform:translateY(-2px); }
.btn-lg{ padding:.95rem 1.7rem; font-size:1.05rem; }
.btn-outline{ border-color:var(--forest); color:var(--forest); padding:.72rem 1.3rem; background:transparent; }
.btn-outline:hover{ background:var(--forest); color:var(--cream); }
.nav-cta{ display:flex; gap:.6rem; align-items:center; }
.nav-cta .btn-text{ font-weight:700; color:var(--forest); padding:.5rem .4rem; }
.menu-btn{ display:none; }

/* mobile menu */
.menu.open{ display:flex; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:var(--paper); border-bottom:1px solid var(--line); box-shadow:0 16px 32px -16px rgba(0,0,0,.15); padding:1rem 5%; z-index:100; }
.menu.open a{ padding:.8rem 1rem; border-radius:12px; width:100%; }

/* ============================================
   HERO
   ============================================ */
.hero{ position:relative; background:radial-gradient(120% 120% at 12% 0%, var(--forest-grad-1) 0%, var(--forest-grad-2) 62%, var(--forest-deep) 100%); color:#eef4ee; overflow:hidden; padding:clamp(2.2rem,4.5vw,3.6rem) 0 clamp(3.2rem,5.5vw,5rem); }
.hero::before{ content:""; position:absolute; right:-130px; top:-140px; width:520px; height:520px; border-radius:50%; background:rgba(159,192,166,.12); }
.hero::after{ content:""; position:absolute; left:-120px; bottom:-160px; width:380px; height:380px; border-radius:50%; background:rgba(125,168,79,.12); }
.hero-card{ position:relative; z-index:2; }
.hero-grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.08fr .92fr; gap:clamp(1.5rem,3vw,3.5rem); align-items:center; }
.eyebrow{ display:inline-flex; align-items:center; gap:.5rem; background:rgba(159,192,166,.18); border:1px solid rgba(159,192,166,.32); color:#cfe3ce; font-size:.74rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; padding:.45rem .9rem; border-radius:100px; }
.eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--olive); }
.hero h1{ font-size:clamp(2.4rem,5.2vw,4.8rem); margin:1.2rem 0 0; color:#fff; letter-spacing:-.025em; line-height:1.04; }
.hero h1 em{ font-style:normal; color:var(--sage); }
.hero .lede{ margin-top:1.2rem; max-width:40ch; font-size:1.1rem; color:#cfe0d2; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.6rem; }
.hero-trust{ display:flex; gap:1.6rem; margin-top:1.8rem; flex-wrap:wrap; }
.hero-trust div{ display:flex; flex-direction:column; }
.hero-trust b{ font-family:var(--serif); font-size:1.6rem; color:#fff; }
.hero-trust span{ font-size:.82rem; color:#aac3ad; letter-spacing:.04em; }

/* hero visual */
.hero-visual{ position:relative; min-height:360px; display:grid; place-items:center; }
.blob{ width:min(320px,75%); aspect-ratio:1; border-radius:50%; background:linear-gradient(160deg,#fbfaf4,#e7efe3); display:grid; place-items:center; box-shadow:inset 0 0 0 1px rgba(255,255,255,.5), 0 30px 60px -24px rgba(0,0,0,.45); }
@keyframes morph{ 0%,100%{ border-radius:50%; } }
.blob img{ width:74%; filter:drop-shadow(0 14px 24px rgba(0,0,0,.18)); }
.chip{ position:absolute; background:rgba(255,255,255,.96); color:var(--forest); border-radius:14px; padding:.55rem .75rem; box-shadow:0 12px 28px -10px rgba(0,0,0,.35); display:flex; align-items:center; gap:.5rem; font-weight:700; font-size:.82rem; }
.chip .ic{ width:1.2em; height:1.2em; color:var(--green); flex:none; }
.chip span{ white-space:nowrap; line-height:1.2; }
.chip small{ display:block; font-weight:600; font-size:.68rem; color:var(--muted); white-space:nowrap; }
.chip.c1{ top:6%; left:14%; }
.chip.c2{ top:42%; right:-4%; }
.chip.c3{ bottom:10%; left:2%; }
.float{ animation:floaty 6s ease-in-out infinite; }
.float.d1{ animation-delay:-2s; } .float.d2{ animation-delay:-4s; }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }

/* ============================================
   DONATION GOAL BAND
   ============================================ */
.goal{ margin-top:-2.6rem; position:relative; z-index:5; }
.goal-card{ background:#fff; border-radius:24px; padding:1.6rem clamp(1.4rem,3vw,2.4rem); box-shadow:0 24px 50px -28px rgba(22,42,32,.4); border:1px solid var(--line); display:grid; grid-template-columns:auto 1fr auto; gap:clamp(1.2rem,3vw,2.4rem); align-items:center; }
.goal-head{ display:flex; align-items:center; gap:.9rem; }
.goal-ring{ width:64px; height:64px; border-radius:50%; display:grid; place-items:center; background:var(--sage-mist); color:var(--green); flex:none; }
.goal-ring .ic{ width:30px; height:30px; }
.goal-head b{ font-family:var(--serif); font-size:1.05rem; color:var(--forest); display:block; }
.goal-head span{ font-size:.84rem; color:var(--muted); }
.goal-bar-wrap{ min-width:200px; }
.goal-nums{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:.5rem; }
.goal-nums b{ font-family:var(--serif); font-size:1.5rem; color:var(--forest); }
.goal-nums b em{ font-style:normal; font-size:.9rem; color:var(--muted); font-family:var(--sans); font-weight:600; }
.goal-nums .pct{ font-weight:800; color:var(--green); }
.track{ height:14px; border-radius:100px; background:var(--cream-2); overflow:hidden; }
.track i{ display:block; height:100%; width:0; border-radius:100px; background:linear-gradient(90deg,var(--olive),var(--green)); transition:width 1.6s cubic-bezier(.22,1,.36,1); }

/* ============================================
   SECTION SCAFFOLDING
   ============================================ */
.section{ padding:clamp(3.6rem,7vw,6rem) 0; }
.sec-head{ max-width:640px; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.kicker{ display:inline-flex; align-items:center; gap:.5rem; color:var(--green); font-weight:800; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; }
.kicker .ic{ width:1.1em; height:1.1em; }
.sec-head h2{ font-size:clamp(2rem,3.8vw,3rem); color:var(--forest); margin:.7rem 0 0; }
.sec-head p{ margin-top:.8rem; color:var(--muted); font-size:1.08rem; }

/* ============================================
   HOW IT WORKS — Steps
   ============================================ */
.steps{ position:relative; display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.8rem; }
.steps::before{ content:""; position:absolute; top:42px; left:14%; right:14%; height:2px; background:repeating-linear-gradient(90deg,var(--sage) 0 8px,transparent 8px 16px); z-index:0; }
.step{ position:relative; z-index:1; background:var(--paper); border:1px solid var(--line); border-radius:24px; padding:1.8rem; text-align:center; transition:transform .25s, box-shadow .25s; }
.step:hover{ transform:translateY(-6px); box-shadow:0 24px 44px -26px rgba(22,42,32,.5); }
.step-ic{ width:84px; height:84px; margin:0 auto; border-radius:24px; background:linear-gradient(160deg,var(--forest-grad-1),var(--forest-grad-2)); color:#fff; display:grid; place-items:center; box-shadow:0 16px 30px -16px rgba(22,42,32,.7); }
.step-ic .ic{ width:38px; height:38px; }
.step .num{ position:absolute; top:1.2rem; right:1.4rem; font-family:var(--serif); font-size:2.4rem; color:var(--cream-2); font-weight:700; line-height:1; }
.step h3{ font-size:1.35rem; color:var(--forest); margin:1.1rem 0 .5rem; }
.step p{ color:var(--muted); font-size:.98rem; }

/* ============================================
   WHY IT MATTERS
   ============================================ */
.matter{ background:linear-gradient(180deg,var(--sage-mist),transparent); }
.cards3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.8rem; }
.mcard{ background:#fff; border-radius:24px; padding:2rem; border:1px solid var(--line); position:relative; overflow:hidden; transition:transform .25s; }
.mcard:hover{ transform:translateY(-6px); }
.mcard .ic-wrap{ width:60px; height:60px; border-radius:18px; display:grid; place-items:center; margin-bottom:1.2rem; }
.mcard .ic-wrap .ic{ width:30px; height:30px; }
.mcard:nth-child(1) .ic-wrap{ background:var(--sage-soft); color:var(--green-600); }
.mcard:nth-child(2) .ic-wrap{ background:rgba(125,168,79,.18); color:var(--olive); }
.mcard:nth-child(3) .ic-wrap{ background:rgba(156,107,63,.16); color:var(--brown); }
.mcard h3{ font-size:1.3rem; color:var(--forest); margin-bottom:.5rem; }
.mcard p{ color:var(--muted); }

/* ============================================
   SCHOOL TRACKER
   ============================================ */
.tracker .school-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.6rem; }
.school{ background:var(--paper); border:1px solid var(--line); border-radius:22px; padding:1.6rem; display:flex; flex-direction:column; gap:1rem; }
.school-top{ display:flex; align-items:center; justify-content:space-between; gap:.6rem; }
.school-top h3{ font-size:1.12rem; color:var(--forest); }
.badge{ font-size:.68rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; padding:.3rem .6rem; border-radius:100px; background:var(--cream-2); color:var(--muted); }
.badge.live{ background:var(--sage-soft); color:var(--green-600); }
.school-stats{ display:flex; gap:1.4rem; }
.school-stats div b{ font-family:var(--serif); font-size:1.5rem; color:var(--forest); display:block; line-height:1; }
.school-stats div span{ font-size:.78rem; color:var(--muted); }
.school-foot{ font-size:.82rem; color:var(--muted); display:flex; align-items:center; gap:.4rem; border-top:1px dashed var(--line); padding-top:.9rem; }
.school-foot .ic{ width:1em; height:1em; }

/* impact stats bar */
.impact{ margin-top:2rem; background:radial-gradient(120% 130% at 80% 0%,var(--forest-grad-1),var(--forest-grad-2)); border-radius:28px; padding:clamp(1.8rem,4vw,2.8rem); display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; color:#fff; }
.stat{ text-align:center; }
.stat b{ font-family:var(--serif); font-size:clamp(2.2rem,4vw,3.2rem); display:block; color:#fff; }
.stat span{ color:#a9c4ac; font-size:.86rem; font-weight:600; letter-spacing:.03em; }
.stat .ic{ width:26px; height:26px; color:var(--sage); margin:0 auto .4rem; }

/* ============================================
   CTA BAND
   ============================================ */
.cta-band{ text-align:center; }
.cta-band .wrap{ width:100%; }
.cta-card{ background:radial-gradient(120% 140% at 15% 10%,var(--forest-grad-1),var(--forest-deep)); padding:clamp(2.8rem,6vw,5.5rem); color:#fff; position:relative; overflow:hidden; }
.cta-card::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 85% 90%,rgba(125,168,79,.22),transparent 50%); }
.cta-card .inner{ position:relative; z-index:2; max-width:620px; margin-inline:auto; }
.cta-card h2{ font-size:clamp(2rem,4vw,3.2rem); color:#fff; }
.cta-card p{ margin:1rem 0 2rem; color:#cfe0d2; font-size:1.1rem; }
.cta-actions{ display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

/* ============================================
   FOOTER
   ============================================ */
.foot{ background:var(--forest-deep); color:#bcd0bf; margin-top:clamp(3rem,6vw,5rem); }
.foot .grid{ display:grid; grid-template-columns:1.6fr 1fr 1.2fr; gap:2.4rem; padding:3.4rem 0 2.4rem; }
.foot .brand b{ color:#fff; }
.foot .brand img{ filter:drop-shadow(0 4px 8px rgba(0,0,0,.3)); }
.foot p.tag{ margin-top:1rem; max-width:32ch; font-size:.95rem; color:#9bb59e; }
.foot h4{ font-family:var(--sans); font-weight:800; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:#dfe9df; margin-bottom:1rem; }
.foot ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.6rem; }
.foot a{ color:#bcd0bf; transition:color .18s; }
.foot a:hover{ color:#fff; }
.foot .contact a{ display:flex; align-items:center; gap:.55rem; }
.foot .contact .ic{ width:1.1em; height:1.1em; }
.foot .socials{ display:flex; gap:.6rem; margin-top:1rem; }
.foot .socials a{ width:40px; height:40px; border-radius:12px; border:1px solid rgba(255,255,255,.16); display:grid; place-items:center; }
.foot .socials a:hover{ background:rgba(255,255,255,.1); }
.foot .socials .ic{ width:20px; height:20px; }
.foot .bar{ border-top:1px solid rgba(255,255,255,.12); padding:1.3rem 0; font-size:.84rem; color:#8aa68d; text-align:center; }

/* ============================================
   PAGE HERO (Sub-pages: donate, signup, about)
   ============================================ */
.page-hero{ position:relative; background:radial-gradient(120% 120% at 12% 0%,var(--forest-grad-1),var(--forest-grad-2) 62%,var(--forest-deep) 100%); color:#eef4ee; overflow:hidden; padding:clamp(3rem,6vw,5rem) 0 clamp(2.5rem,5vw,4rem); text-align:center; }
.page-hero::before{ content:""; position:absolute; right:-100px; top:-100px; width:400px; height:400px; border-radius:50%; background:rgba(159,192,166,.1); }
.page-hero h1{ font-size:clamp(2.2rem,5vw,3.6rem); color:#fff; margin-bottom:.8rem; }
.page-hero p{ max-width:560px; margin:0 auto; font-size:1.1rem; color:#cfe0d2; }

/* ============================================
   DONATE PAGE — Grove language
   ============================================ */
.donate{ overflow-x:clip; }

/* donate hero visual */
.hero .tagline{ margin-top:1.4rem; font-family:var(--serif); font-style:italic; font-size:1.35rem; color:var(--sage); }
.hero-meta{ display:flex; gap:1.6rem; margin-top:2rem; flex-wrap:wrap; }
.hero-meta div{ display:flex; align-items:center; gap:.6rem; color:#cfe0d2; font-size:.92rem; font-weight:600; }
.hero-meta .ic{ width:1.3em; height:1.3em; color:var(--sage); }
.drop{ position:relative; display:grid; place-items:center; min-height:380px; }
.drop-card{ width:min(360px,82%); background:#fff; border-radius:24px; padding:1.8rem 1.8rem 2.2rem; box-shadow:0 30px 60px -24px rgba(0,0,0,.5); text-align:center; }
.drop-card h3{ font-size:1.7rem; color:var(--forest); line-height:1.05; }
.clothes-row{ display:flex; justify-content:center; gap:.2rem; margin:1.1rem 0 .4rem; }
.clothes-row .ic{ width:46px; height:46px; }
.clothes-row .ic:nth-child(1){ color:var(--olive); transform:rotate(-8deg); }
.clothes-row .ic:nth-child(2){ color:var(--green); }
.clothes-row .ic:nth-child(3){ color:var(--brown); transform:rotate(8deg); }
.big-arrow{ width:64px; height:64px; margin:.4rem auto 0; color:var(--green); animation:bob 1.8s ease-in-out infinite; transform:rotate(90deg); }
@keyframes bob{ 0%,100%{ transform:rotate(90deg) translateX(0); } 50%{ transform:rotate(90deg) translateX(10px); } }
.drop-box{ margin-top:.2rem; height:30px; border:3px solid var(--green); border-top:none; border-radius:0 0 14px 14px; width:62%; margin-inline:auto; }

/* accept / don't */
.accept{ background:linear-gradient(180deg,var(--sage-mist),transparent); }
.acc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; margin-top:2.8rem; }
.acc{ background:#fff; border:1px solid var(--line); border-radius:24px; padding:2rem; }
.acc.yes{ border-top:5px solid var(--olive); }
.acc.no{ border-top:5px solid var(--brown-soft); }
.acc-head{ display:flex; align-items:center; gap:.8rem; margin-bottom:1.3rem; }
.acc-head .badge-ic{ width:52px; height:52px; border-radius:50%; display:grid; place-items:center; flex:none; }
.acc-head > div{ min-width:0; }
.acc.yes .badge-ic{ background:rgba(125,168,79,.18); color:var(--olive); }
.acc.no .badge-ic{ background:rgba(156,107,63,.16); color:var(--brown); }
.acc-head .badge-ic .ic{ width:28px; height:28px; }
.acc-head h3{ font-size:1.5rem; color:var(--forest); }
.acc-head span{ font-size:.86rem; color:var(--muted); display:block; font-weight:600; }
.acc ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.95rem; }
.acc li{ display:flex; gap:.75rem; align-items:flex-start; color:var(--ink); font-size:1rem; line-height:1.45; }
.acc li .ic{ width:1.3em; height:1.3em; flex:none; margin-top:.15rem; }
.acc.yes li .ic{ color:var(--olive); }
.acc.no li .ic{ color:var(--brown); }
.acc li b{ color:var(--forest); }
.acc-note{ margin-top:1.4rem; padding:.85rem 1.1rem; border-radius:14px; font-size:.94rem; font-weight:600; display:flex; align-items:center; gap:.6rem; }
.acc.yes .acc-note{ background:var(--sage-mist); color:var(--green-600); }
.acc.yes .acc-note .ic{ width:1.2em; height:1.2em; color:var(--green); }
.guide-note{ text-align:center; margin-top:1.6rem; color:var(--muted); font-size:.95rem; }
.guide-note a{ color:var(--green); font-weight:700; border-bottom:1.5px solid var(--sage); }

/* where to donate */
.where-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:1.6rem; margin-top:2.8rem; align-items:stretch; }
.loc-list{ display:flex; flex-direction:column; gap:1rem; }
.loc{ background:var(--paper); border:1px solid var(--line); border-radius:20px; padding:1.3rem 1.5rem; display:flex; align-items:center; gap:1.1rem; transition:transform .2s, background .2s; }
.loc:hover{ transform:translateX(6px); background:#fff; }
.loc .lpin{ width:48px; height:48px; border-radius:14px; background:var(--sage-mist); color:var(--green); display:grid; place-items:center; flex:none; }
.loc .lpin .ic{ width:24px; height:24px; }
.loc .ltext h4{ font-family:var(--serif); font-size:1.18rem; color:var(--forest); }
.loc .ltext p{ color:var(--muted); font-size:.9rem; margin-top:.15rem; }
.loc.main{ background:radial-gradient(120% 130% at 85% 0%,var(--forest-grad-1),var(--forest-grad-2)); border:none; color:#fff; }
.loc.main .lpin{ background:rgba(255,255,255,.16); color:#fff; }
.loc.main .ltext h4{ color:#fff; } .loc.main .ltext p{ color:#bcd4be; }
.loc.main .pill{ margin-left:auto; background:var(--sage); color:var(--forest-deep); font-size:.66rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; padding:.3rem .7rem; border-radius:100px; }
.scan{ background:var(--forest); border-radius:24px; padding:2rem; color:#fff; display:flex; flex-direction:column; align-items:center; text-align:center; gap:1rem; justify-content:center; }
.scan h3{ font-size:1.4rem; color:#fff; }
.scan p{ color:#bcd4be; font-size:.95rem; }
.scan .flyer-thumb{ width:200px; border-radius:14px; overflow:hidden; box-shadow:0 18px 40px -18px rgba(0,0,0,.7); border:4px solid #fff; transition:transform .2s; }
.scan .flyer-thumb:hover{ transform:scale(1.03); }
.scan .flyer-thumb img{ width:100%; display:block; }
.scan .badge-live{ display:inline-flex; align-items:center; gap:.4rem; font-size:.78rem; color:var(--sage); font-weight:700; letter-spacing:.06em; text-transform:uppercase; }
.scan .badge-live .ic{ width:1.1em; height:1.1em; }

/* spread the word — poster gallery */
.spread{ background:var(--forest-deep); color:#dfe9df; }
.spread .sec-head h2{ color:#fff; }
.spread .sec-head .kicker{ color:var(--sage); }
.spread .sec-head p{ color:#a9c4ad; }
.posters{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; margin-top:2.6rem; }
.poster{ background:#fff; border-radius:16px; overflow:hidden; box-shadow:0 24px 50px -28px rgba(0,0,0,.6); transition:transform .25s; position:relative; display:block; }
.poster:hover{ transform:translateY(-8px) rotate(-1deg); }
.poster img{ width:100%; aspect-ratio:952/1271; object-fit:cover; display:block; }
.poster .cap{ position:absolute; left:0; right:0; bottom:0; background:linear-gradient(0deg,rgba(15,28,21,.92),transparent); color:#fff; padding:1.6rem .9rem .8rem; font-size:.8rem; font-weight:700; letter-spacing:.02em; display:flex; align-items:center; gap:.4rem; opacity:0; transition:opacity .25s; }
.poster:hover .cap{ opacity:1; }
.poster .cap .ic{ width:1.1em; height:1.1em; }
.spread-actions{ display:flex; justify-content:center; gap:.8rem; margin-top:2.2rem; flex-wrap:wrap; }

/* lightbox */
.lb{ position:fixed; inset:0; z-index:300; background:rgba(15,28,21,.92); display:none; align-items:center; justify-content:center; padding:4vh 4vw; }
.lb.open{ display:flex; }
.lb img{ max-width:100%; max-height:92vh; border-radius:10px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lb .close{ position:absolute; top:18px; right:22px; width:46px; height:46px; border-radius:50%; border:1px solid rgba(255,255,255,.3); background:rgba(255,255,255,.08); color:#fff; display:grid; place-items:center; font-size:1.6rem; line-height:1; cursor:pointer; }

/* ============================================
   FORM (Signup page)
   ============================================ */
.form-layout{ display:grid; grid-template-columns:1fr 1.4fr; gap:3rem; max-width:960px; margin:2.5rem auto 0; }
.form-sidebar h2{ font-size:1.35rem; color:var(--forest); margin-bottom:1.2rem; }
.checklist{ list-style:none; padding:0; margin:0 0 1.6rem; }
.checklist li{ position:relative; padding:.5rem 0 .5rem 1.6rem; color:var(--ink); font-size:.94rem; }
.checklist li::before{ content:'\2713'; position:absolute; left:0; color:var(--green); font-weight:700; }
.reassurance-box{ background:var(--sage-mist); border:1px solid var(--sage-soft); border-radius:16px; padding:1.2rem 1.4rem; font-size:.88rem; color:var(--ink); }
.reassurance-box p+p{ margin-top:.5rem; color:var(--muted); }
.form-group{ margin-bottom:1.3rem; }
.form-label{ display:block; font-weight:700; font-size:.9rem; margin-bottom:.4rem; color:var(--ink); }
.required{ color:#c1292e; }
.optional{ color:var(--muted); font-weight:400; font-size:.82rem; }
.form-input{ width:100%; padding:.7em .9em; font-family:var(--sans); font-size:.95rem; border:1.5px solid var(--line); border-radius:14px; background:var(--paper); color:var(--ink); transition:border-color .18s, box-shadow .18s; appearance:none; }
.form-input:focus{ outline:none; border-color:var(--green); box-shadow:0 0 0 3px rgba(62,115,85,.12); }
.form-input.error{ border-color:#c1292e; box-shadow:0 0 0 3px rgba(193,41,46,.08); }
select.form-input{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235c6b60' stroke-width='2' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; padding-right:2.2em; }
.form-textarea{ resize:vertical; min-height:100px; }
.form-helper{ display:block; font-size:.8rem; color:var(--muted); margin-top:.3rem; }
.form-error{ display:block; font-size:.8rem; color:#c1292e; margin-top:.3rem; min-height:1.2em; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.3rem; }
.form-group--checkbox{ margin-top:.5rem; }
.checkbox-label{ display:flex; align-items:flex-start; gap:.55rem; cursor:pointer; font-size:.9rem; line-height:1.5; color:var(--ink); }
.checkbox-label input[type="checkbox"]{ position:absolute; opacity:0; width:0; height:0; }
.checkbox-custom{ flex-shrink:0; width:22px; height:22px; border:2px solid var(--sage-soft); border-radius:6px; margin-top:1px; display:flex; align-items:center; justify-content:center; transition:all .18s; background:#fff; }
.checkbox-label input:checked+.checkbox-custom{ background:var(--forest); border-color:var(--forest); }
.checkbox-label input:checked+.checkbox-custom::after{ content:''; width:6px; height:10px; border:solid #fff; border-width:0 2px 2px 0; transform:rotate(45deg); margin-bottom:2px; }
.checkbox-label input:focus-visible+.checkbox-custom{ outline:3px solid var(--sage); outline-offset:2px; }
.btn-full{ width:100%; justify-content:center; }

/* confirmation */
.confirmation-card{ background:var(--paper); border-radius:24px; padding:3rem 2rem; text-align:center; box-shadow:0 24px 50px -28px rgba(22,42,32,.4); border:1px solid var(--line); }
.confirmation-card--error{ border-top:4px solid #c1292e; }
.confirmation-icon{ font-size:3rem; margin-bottom:1.2rem; }
.confirmation-card h1{ font-size:1.8rem; margin-bottom:.4rem; }
.confirmation-lead{ font-size:1.1rem; color:var(--muted); margin-bottom:2rem; }
.confirmation-summary{ background:var(--sage-mist); border-radius:14px; padding:1.4rem; text-align:left; margin-bottom:2rem; }
.confirmation-summary h2{ font-size:1rem; font-family:var(--sans); margin-bottom:.8rem; color:var(--forest); }
.summary-list{ display:grid; grid-template-columns:auto 1fr; gap:.5rem 1.2rem; }
.summary-list dt{ font-weight:700; color:var(--muted); font-size:.88rem; }
.summary-list dd{ color:var(--ink); font-size:.95rem; word-break:break-word; margin:0; }
.confirmation-next{ margin-bottom:2rem; }
.confirmation-next p{ margin-bottom:.4rem; }

/* ============================================
   ABOUT — Team cards, partners
   ============================================ */
.about-intro{ max-width:720px; margin:0 auto 2rem; }
.about-intro h2{ font-size:1.6rem; color:var(--forest); margin-bottom:1rem; }
.about-intro p{ color:var(--muted); margin-bottom:1rem; font-size:1.02rem; }
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.4rem; }
.team-card{ background:var(--paper); border:1px solid var(--line); border-radius:24px; padding:2rem 1.4rem; text-align:center; transition:transform .25s; }
.team-card:hover{ transform:translateY(-5px); }
.team-avatar{ width:72px; height:72px; border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 1rem; color:#fff; font-weight:700; font-size:1.2rem; font-family:var(--sans); }
.team-name{ font-size:1.08rem; color:var(--forest); margin-bottom:2px; }
.team-role{ color:var(--green); font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.05em; margin-bottom:.8rem; font-family:var(--sans); }
.team-bio{ color:var(--muted); font-size:.88rem; line-height:1.6; }
.partners-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:2.4rem; }
.partner-card{ text-align:center; padding:1.6rem; background:var(--paper); border:1px solid var(--line); border-radius:22px; }
.partner-logo{ font-size:2rem; margin-bottom:.8rem; }
.partner-card h3{ font-size:1rem; color:var(--forest); margin-bottom:.3rem; }
.partner-card p{ color:var(--muted); font-size:.85rem; }

/* ============================================
   REVEAL ANIMATION
   ============================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); }
.reveal.in{ opacity:1; transform:none; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width:900px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-visual{ min-height:340px; margin-top:1rem; }
  .drop{ min-height:300px; margin-top:1rem; }
  .steps,.cards3,.tracker .school-grid,.team-grid,.partners-grid,.acc-grid{ grid-template-columns:1fr; }
  .steps::before{ display:none; }
  .impact{ grid-template-columns:repeat(2,1fr); }
  .foot .grid{ grid-template-columns:1fr; gap:2rem; }
  .form-layout{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .goal-card{ grid-template-columns:1fr; text-align:left; }
  .where-grid{ grid-template-columns:1fr; }
}
@media (max-width:860px){ .posters{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:720px){
  .menu{ display:none; }
  .menu-btn{ display:inline-grid; }
  .nav-cta .btn-text{ display:none; }
}
@media (max-width:480px){
  .team-grid{ grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce){ *{ animation:none !important; } .reveal{ opacity:1; transform:none; } }
