/* ============================================================
   GREEN TREES OF HOPE FOUNDATION — style.css
   ============================================================ */
:root {
  --clr-forest:      #1b4332;
  --clr-forest-mid:  #2d6a4f;
  --clr-forest-lt:   #40916c;
  --clr-sage:        #74c69d;
  --clr-cream:       #f8faf7;
  --clr-cream-dk:    #edf3eb;
  --clr-warm-white:  #fdfffc;
  --clr-earth:       #6b4226;
  --clr-gold:        #e9c46a;
  --clr-gold-lt:     #f4d35e;
  --clr-ink:         #1a2e1f;
  --clr-ink-mid:     #344e38;
  --clr-ink-lt:      #5a7a5f;
  --clr-border:      #d4e6d1;
  --clr-border-dk:   #b8d4b3;
  --ff-display: 'Playfair Display', Georgia, serif;
  --ff-body:    'Lato', system-ui, sans-serif;
  --ff-ui:      'Lato', system-ui, sans-serif;
  --r-sm:4px; --r-md:12px; --r-lg:20px; --r-xl:32px; --r-full:9999px;
  --shadow-sm:0 1px 3px rgba(27,67,50,.08);
  --shadow-md:0 4px 16px rgba(27,67,50,.10);
  --shadow-lg:0 12px 40px rgba(27,67,50,.14);
  --shadow-xl:0 24px 64px rgba(27,67,50,.18);
  --t-fast:.15s ease; --t-mid:.3s ease;
  --container-max:1200px; --container-pad:1.5rem; --header-h:80px;
  --sp-sm:1rem; --sp-md:1.5rem; --sp-lg:2.5rem; --sp-xl:4rem; --sp-2xl:6rem; --sp-3xl:9rem;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);font-size:1rem;line-height:1.7;color:var(--clr-ink);background:var(--clr-cream);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--clr-forest-lt);text-decoration:underline;text-underline-offset:3px;transition:color var(--t-fast)}
a:hover{color:var(--clr-forest-mid)}
h1,h2,h3,h4,h5,h6{font-family:var(--ff-display);font-weight:700;line-height:1.2;color:var(--clr-ink)}
address{font-style:normal}

.skip-link{position:absolute;top:-100%;left:1rem;z-index:9999;padding:.75rem 1.5rem;background:var(--clr-forest);color:var(--clr-cream);text-decoration:none;border-radius:0 0 var(--r-md) var(--r-md)}
.skip-link:focus{top:0}
.container{max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-pad)}
.section-padding{padding-block:var(--sp-3xl)}
@media(max-width:768px){.section-padding{padding-block:var(--sp-2xl)}}
.section-dark{background:var(--clr-forest);color:var(--clr-cream)}
.section-warm{background:var(--clr-cream-dk)}
.section-eyebrow{display:inline-block;font-family:var(--ff-ui);font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--clr-forest-lt);margin-bottom:.75rem}
.section-eyebrow.light{color:var(--clr-sage)}
.section-headline{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15;margin-bottom:1.25rem}
.section-headline em{font-style:italic;color:var(--clr-forest-lt)}
.section-headline.light{color:var(--clr-cream)}
.section-headline.light em{color:var(--clr-gold)}
.section-intro{font-size:1.125rem;color:var(--clr-ink-lt);max-width:620px;line-height:1.75}
.section-intro.light{color:rgba(248,250,247,.8)}
.body-text{font-size:1.0625rem;color:var(--clr-ink-mid);line-height:1.8;margin-bottom:1.25rem}
.section-header.centered{text-align:center;display:flex;flex-direction:column;align-items:center;margin-bottom:var(--sp-xl)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;border:2px solid transparent;border-radius:var(--r-full);font-family:var(--ff-ui);font-size:.9375rem;font-weight:700;text-decoration:none;cursor:pointer;transition:all var(--t-mid);white-space:nowrap}
.btn-primary{background:var(--clr-forest-lt);color:#fff;border-color:var(--clr-forest-lt)}
.btn-primary:hover{background:var(--clr-forest-mid);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(64,145,108,.35)}
.btn-secondary{background:transparent;color:var(--clr-forest-lt);border-color:var(--clr-forest-lt)}
.btn-secondary:hover{background:var(--clr-forest-lt);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--clr-cream);border-color:rgba(248,250,247,.6)}
.btn-ghost:hover{background:rgba(248,250,247,.15);color:var(--clr-cream)}
.btn-gold{background:var(--clr-gold);color:var(--clr-forest);border-color:var(--clr-gold);font-weight:700}
.btn-gold:hover{background:var(--clr-gold-lt);transform:translateY(-2px);box-shadow:0 8px 24px rgba(233,196,106,.45)}
.btn-full{width:100%}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal:nth-child(2){transition-delay:.1s}
.reveal:nth-child(3){transition-delay:.2s}
.reveal:nth-child(4){transition-delay:.3s}
.reveal:nth-child(5){transition-delay:.4s}
.reveal:nth-child(6){transition-delay:.5s}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-h);background:rgba(248,250,247,.96);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color var(--t-mid),box-shadow var(--t-mid)}
.site-header.scrolled{border-bottom-color:var(--clr-border);box-shadow:var(--shadow-md)}
.nav-container{max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-pad);height:100%;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.logo-img{height:48px;width:auto;display:block}



.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}
.nav-link{font-family:var(--ff-ui);font-size:.875rem;color:var(--clr-ink-mid);text-decoration:none;padding:.5rem .75rem;border-radius:var(--r-sm);transition:color var(--t-fast),background var(--t-fast)}
.nav-link:hover{color:var(--clr-forest);background:rgba(27,67,50,.06)}
.nav-link.nav-cta{background:var(--clr-forest-lt);color:#fff;padding:.5rem 1.25rem;border-radius:var(--r-full);margin-left:.5rem}
.nav-link.nav-cta:hover{background:var(--clr-forest-mid);color:#fff}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--r-sm)}
.hamburger-line{display:block;width:100%;height:2px;background:var(--clr-ink);border-radius:2px;transition:all var(--t-mid);transform-origin:center}
.nav-toggle[aria-expanded="true"] .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .hamburger-line:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:var(--header-h);background-color:var(--clr-forest);background-image:url('images/forest-hero.jpg');background-size:cover;background-position:center;background-attachment:fixed}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(27,67,50,.92) 0%,rgba(27,67,50,.65) 55%,rgba(27,67,50,.3) 100%);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:680px;padding-inline:var(--container-pad);padding-block:var(--sp-2xl);padding-left:max(var(--container-pad),6vw);margin-inline:auto}
.hero-eyebrow{display:inline-block;font-family:var(--ff-ui);font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(248,250,247,.7);margin-bottom:1.25rem}
.hero-headline{font-family:var(--ff-display);font-size:clamp(2.75rem,6.5vw,5rem);font-weight:900;line-height:1.05;color:var(--clr-cream);margin-bottom:1.5rem;letter-spacing:-.02em}
.hero-headline em{font-style:italic;color:var(--clr-gold);font-weight:400}
.hero-sub{font-size:1.125rem;color:rgba(248,250,247,.85);line-height:1.75;margin-bottom:2.5rem;max-width:500px}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.75rem}
.trust-badge{font-family:var(--ff-ui);font-size:.75rem;font-weight:600;color:rgba(248,250,247,.7);letter-spacing:.05em}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;text-decoration:none;opacity:.5;transition:opacity var(--t-mid)}
.hero-scroll:hover{opacity:1}
.scroll-line{display:block;width:1px;height:60px;background:linear-gradient(to bottom,transparent,var(--clr-cream));animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}

/* IMPACT BAR */
.impact-bar{background:var(--clr-forest-mid);padding-block:var(--sp-lg)}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;list-style:none}
.impact-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--sp-sm);border-right:1px solid rgba(248,250,247,.15)}
.impact-item:last-child{border-right:none}
.impact-number{font-family:var(--ff-display);font-size:clamp(2.5rem,4vw,3.5rem);font-weight:900;color:var(--clr-gold);line-height:1;margin-bottom:.5rem}
.impact-label{font-family:var(--ff-ui);font-size:.8125rem;letter-spacing:.05em;color:rgba(248,250,247,.65);text-transform:uppercase}

/* ABOUT */
.about{background:var(--clr-warm-white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2xl);align-items:center}
.about-image{position:relative}
.about-img{width:100%;height:500px;object-fit:cover;border-radius:var(--r-xl);display:block}
.img-placeholder{background:var(--clr-cream-dk);border:2px dashed var(--clr-border-dk);border-radius:var(--r-md);width:100%;min-height:360px;display:flex;align-items:center;justify-content:center}
.img-placeholder-inner{display:flex;flex-direction:column;align-items:center;gap:.75rem;opacity:.5}
.img-placeholder-icon{font-size:3rem}
.img-placeholder-text{font-family:var(--ff-ui);font-size:.8125rem;color:var(--clr-ink-lt)}
.about-badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--clr-forest-lt);color:#fff;border-radius:var(--r-lg);padding:1.25rem 1.5rem;text-align:center;box-shadow:var(--shadow-lg);min-width:120px}
.badge-year{display:block;font-family:var(--ff-ui);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;opacity:.8}
.badge-num{display:block;font-family:var(--ff-display);font-size:2.5rem;font-weight:900;line-height:1;margin-block:.25rem}
.badge-label{display:block;font-family:var(--ff-ui);font-size:.65rem;letter-spacing:.06em;opacity:.8}
.about-content{padding-left:var(--sp-sm)}
.about-cta{margin-top:var(--sp-md)}

/* PROGRAMS */
.programs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-md)}
.program-card{background:rgba(248,250,247,.06);border:1px solid rgba(248,250,247,.12);border-radius:var(--r-lg);padding:var(--sp-lg);transition:all var(--t-mid)}
.program-card:hover{background:rgba(248,250,247,.1);transform:translateY(-4px)}
.program-card-icon{font-size:2.25rem;margin-bottom:1rem;display:block}
.program-card-title{font-family:var(--ff-display);font-size:1.25rem;font-weight:600;color:var(--clr-cream);margin-bottom:.75rem}
.program-card-text{font-size:.9375rem;color:rgba(248,250,247,.72);line-height:1.75}

/* STORIES */
.stories{background:var(--clr-cream)}
.stories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-md)}
.story-card{background:var(--clr-warm-white);border:1px solid var(--clr-border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all var(--t-mid)}
.story-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-6px)}
.story-card-image{position:relative;height:240px;overflow:hidden}
.story-card-image img{width:100%;height:100%;object-fit:cover;display:block}
.story-card-image .img-placeholder{height:100%;min-height:unset;border-radius:0;border:none}
.story-card-tag{position:absolute;bottom:1rem;left:1rem;font-family:var(--ff-ui);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--clr-forest-lt);padding:.35rem .75rem;border-radius:var(--r-full)}
.story-card-body{padding:var(--sp-md)}
.story-card-name{font-family:var(--ff-display);font-size:1.375rem;font-weight:700;color:var(--clr-forest);margin-bottom:.25rem}
.story-card-location{font-family:var(--ff-ui);font-size:.8125rem;color:var(--clr-ink-lt);margin-bottom:.875rem}
.story-card-text{font-size:.9375rem;color:var(--clr-ink-mid);line-height:1.75;margin-bottom:1rem}
.story-outcome{display:inline-block;font-family:var(--ff-ui);font-size:.75rem;font-weight:700;color:var(--clr-forest-mid);background:rgba(45,106,79,.1);border:1px solid rgba(45,106,79,.25);padding:.35rem .875rem;border-radius:var(--r-full)}

/* GET INVOLVED */
.get-involved{background:var(--clr-warm-white)}
.involve-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-md)}
.involve-card{background:var(--clr-cream);border:1px solid var(--clr-border);border-radius:var(--r-lg);padding:var(--sp-lg);display:flex;flex-direction:column;gap:.875rem;transition:all var(--t-mid);box-shadow:var(--shadow-sm)}
.involve-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.involve-card--primary{background:var(--clr-forest);border-color:var(--clr-forest-mid)}
.involve-card-icon{font-size:2.5rem}
.involve-card-title{font-family:var(--ff-display);font-size:1.5rem;font-weight:700}
.involve-card--primary .involve-card-title{color:var(--clr-cream)}
.involve-card-text{font-size:.9375rem;line-height:1.75;flex:1}
.involve-card--primary .involve-card-text{color:rgba(248,250,247,.8)}

/* DONATION GRID */
.donate-section{background:var(--clr-cream)}
.donation-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:960px;margin:0 auto var(--sp-lg)}
.donation-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;padding:2.75rem 1.75rem 2rem;background:var(--clr-warm-white);border:1.5px solid var(--clr-border);border-radius:22px;transition:box-shadow var(--t-mid),transform var(--t-mid)}
.donation-card:hover{box-shadow:0 16px 48px rgba(27,67,50,.13);transform:translateY(-5px)}
.donation-card--featured{background:var(--clr-forest);border-color:var(--clr-forest)}
.donation-card--patron{background:var(--clr-cream-dk);border-color:var(--clr-border-dk)}
.donation-badge{position:absolute;top:-15px;left:50%;transform:translateX(-50%);white-space:nowrap;background:var(--clr-gold);color:var(--clr-forest);font-family:var(--ff-ui);font-size:.625rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:5px 16px;border-radius:var(--r-full)}
.donation-badge--patron{background:var(--clr-forest);color:#fff}
.donation-tier{font-family:var(--ff-ui);font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--clr-ink-lt);margin-bottom:1.375rem}
.donation-card--featured .donation-tier{color:rgba(248,250,247,.5)}
.donation-price{display:flex;align-items:flex-start;line-height:1;margin-bottom:1rem;color:var(--clr-ink)}
.donation-card--featured .donation-price{color:var(--clr-cream)}
.price-sup{font-family:var(--ff-display);font-size:1.5rem;font-weight:400;margin-top:.625rem;margin-right:2px;line-height:1}
.price-int{font-family:var(--ff-display);font-size:clamp(3.25rem,5.5vw,4.75rem);font-weight:400;font-style:italic;line-height:.88;letter-spacing:-.02em}
.price-dec{font-family:var(--ff-display);font-size:1.375rem;font-weight:400;margin-top:.625rem;color:var(--clr-ink-lt);line-height:1}
.donation-card--featured .price-dec{color:rgba(248,250,247,.55)}
.donation-desc{font-family:var(--ff-body);font-size:.9375rem;color:var(--clr-ink-lt);line-height:1.5;margin-bottom:1.75rem;flex:1}
.donation-card--featured .donation-desc{color:rgba(248,250,247,.6)}
.donation-btn{width:100%;padding:.875rem 1.25rem;border-radius:11px;background:var(--clr-forest);color:#fff;border:2px solid var(--clr-forest);font-family:var(--ff-ui);font-size:.8125rem;font-weight:800;letter-spacing:.14em;cursor:pointer;transition:all var(--t-mid);line-height:1}
.donation-btn:hover{background:var(--clr-forest-mid);transform:translateY(-2px);box-shadow:0 8px 20px rgba(27,67,50,.28)}
.donation-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.donation-btn--featured{background:transparent;border-color:rgba(255,255,255,.7);color:#fff}
.donation-btn--featured:hover{background:rgba(255,255,255,.12);border-color:#fff;box-shadow:none}
.donate-trust{display:flex;justify-content:center;flex-wrap:wrap;gap:.75rem 2rem;padding-top:var(--sp-md);border-top:1px solid var(--clr-border)}
.dtrust-item{font-family:var(--ff-ui);font-size:.8125rem;color:var(--clr-ink-lt);font-weight:500}

/* CHECKOUT OVERLAY */
.gt-overlay{display:none;position:fixed;inset:0;z-index:9990;background:rgba(10,20,12,.72);backdrop-filter:blur(6px);align-items:flex-start;justify-content:center;padding:calc(var(--header-h) + 1.5rem) 1rem 2rem;overflow-y:auto}
.gt-overlay.open{display:flex}
.gt-modal{background:#fff;border-radius:24px;width:100%;max-width:480px;flex-shrink:0;box-shadow:0 32px 80px rgba(0,0,0,.28);overflow:hidden;animation:gtIn .32s cubic-bezier(.2,.9,.3,1)}
@keyframes gtIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
.gt-header{background:var(--clr-forest);padding:1.25rem 1.375rem 1.125rem;display:flex;align-items:center;gap:.875rem}
.gt-header-info{flex:1;min-width:0}
.gt-org{font-family:var(--ff-ui);font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(248,250,247,.5);margin-bottom:.2rem}
.gt-desc{font-family:var(--ff-display);font-size:1rem;font-weight:700;color:var(--clr-cream)}
.gt-price{font-family:var(--ff-display);font-size:1.625rem;font-weight:900;color:var(--clr-gold);white-space:nowrap;flex-shrink:0}
.gt-close{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:rgba(248,250,247,.1);border:none;color:rgba(248,250,247,.75);font-size:1.25rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t-fast)}
.gt-close:hover{background:rgba(248,250,247,.22)}
.gt-body{padding:1.5rem}
.gt-step{display:none}
.gt-step.active{display:block}
.gt-step-title{font-family:var(--ff-display);font-size:1.125rem;color:var(--clr-forest);margin-bottom:1.125rem}
.gt-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.gt-field{display:flex;flex-direction:column;gap:5px}
.gt-label{font-family:var(--ff-ui);font-size:.75rem;font-weight:700;color:var(--clr-ink-mid);letter-spacing:.02em}
.gt-input{padding:.75rem 1rem;border:1.5px solid var(--clr-border);border-radius:10px;font-family:var(--ff-body);font-size:.9375rem;color:var(--clr-ink);background:var(--clr-cream);width:100%;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.gt-input:focus{outline:none;border-color:var(--clr-forest-lt);box-shadow:0 0 0 3px rgba(64,145,108,.12)}
.gt-input::placeholder{color:var(--clr-ink-lt);opacity:.65}
.gt-error{display:none;background:rgba(192,57,43,.08);border:1px solid rgba(192,57,43,.25);color:#c0392b;font-family:var(--ff-ui);font-size:.8125rem;font-weight:500;padding:.75rem 1rem;border-radius:10px;margin-bottom:1rem}
.gt-btn-main{width:100%;padding:.9375rem;background:var(--clr-forest);color:#fff;border:none;border-radius:12px;font-family:var(--ff-ui);font-size:1rem;font-weight:700;cursor:pointer;margin-top:4px;transition:background var(--t-fast),transform var(--t-fast)}
.gt-btn-main:hover{background:var(--clr-forest-mid);transform:translateY(-1px)}
.gt-btn-main:disabled{opacity:.6;cursor:not-allowed;transform:none}
.gt-note{text-align:left;margin-top:.875rem;font-family:var(--ff-ui);font-size:.75rem;color:var(--clr-ink-lt);line-height:1.5}
.gt-note--center{text-align:center}
.gt-buyer-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--clr-cream);border:1px solid var(--clr-border);border-radius:10px;padding:.75rem 1rem;margin-bottom:1.25rem;flex-wrap:wrap}
.gt-buyer-name{font-family:var(--ff-ui);font-size:.875rem;font-weight:600;color:var(--clr-ink)}
.gt-change{background:none;border:none;font-family:var(--ff-ui);font-size:.8rem;color:var(--clr-forest-lt);cursor:pointer;text-decoration:underline;padding:0}
#gt-elements{background:var(--clr-cream);border:1.5px solid var(--clr-border);border-radius:12px;padding:1rem;margin-bottom:1rem;min-height:60px}
.gt-btn-pay{width:100%;padding:1rem;background:var(--clr-forest-lt);color:#fff;border:none;border-radius:12px;font-family:var(--ff-ui);font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background var(--t-fast),transform var(--t-fast)}
.gt-btn-pay:hover{background:var(--clr-forest-mid);transform:translateY(-1px)}
.gt-btn-pay:disabled{opacity:.6;cursor:not-allowed;transform:none}
.gt-success{text-align:center;padding:1rem 0}
.gt-success-icon{font-size:3.5rem;margin-bottom:1rem}
.gt-success-title{font-family:var(--ff-display);font-size:1.75rem;color:var(--clr-forest);margin-bottom:.875rem}
.gt-success-text{font-size:.9375rem;color:var(--clr-ink-mid);line-height:1.75;margin-bottom:1.5rem}
.gt-btn-close-success{padding:.75rem 2rem;background:var(--clr-forest);color:#fff;border:none;border-radius:var(--r-full);font-family:var(--ff-ui);font-size:.9375rem;font-weight:600;cursor:pointer;transition:background var(--t-fast)}
.gt-btn-close-success:hover{background:var(--clr-forest-mid)}

/* FAQ */
.faq-list{max-width:780px;margin-inline:auto;display:flex;flex-direction:column;gap:.5rem}
.faq-item{background:var(--clr-warm-white);border:1px solid var(--clr-border);border-radius:var(--r-md);overflow:hidden}
.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:none;border:none;cursor:pointer;font-family:var(--ff-display);font-size:1.0625rem;font-weight:600;color:var(--clr-ink);text-align:left;transition:color var(--t-fast)}
.faq-question:hover{color:var(--clr-forest)}
.faq-icon{font-size:1.375rem;color:var(--clr-forest-lt);transition:transform var(--t-mid);flex-shrink:0}
.faq-question[aria-expanded="true"] .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;padding:0 1.5rem}
.faq-answer.open{max-height:400px;padding:0 1.5rem 1.25rem}
.faq-answer p{font-size:.9375rem;color:var(--clr-ink-mid);line-height:1.8;border-top:1px solid var(--clr-border);padding-top:1rem}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--sp-2xl);align-items:start}
.contact-info{display:flex;flex-direction:column;gap:var(--sp-md)}
.contact-block{padding:var(--sp-md);background:rgba(248,250,247,.05);border:1px solid rgba(248,250,247,.1);border-radius:var(--r-md)}
.contact-block-title{font-family:var(--ff-ui);font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--clr-gold);margin-bottom:.75rem}
.contact-address{font-size:.9375rem;line-height:1.8;color:rgba(248,250,247,.7)}
.legal-details{display:grid;grid-template-columns:auto 1fr;gap:.35rem 1rem;font-size:.875rem}
.legal-details dt{font-family:var(--ff-ui);font-size:.75rem;font-weight:700;text-transform:uppercase;color:rgba(248,250,247,.45)}
.legal-details dd{color:rgba(248,250,247,.8)}
.contact-form-wrap{background:rgba(248,250,247,.05);border:1px solid rgba(248,250,247,.1);border-radius:var(--r-xl);padding:var(--sp-xl);box-shadow:var(--shadow-md)}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.5rem}
.form-group--full{grid-column:1/-1}
.form-label{font-family:var(--ff-ui);font-size:.8125rem;font-weight:600;color:rgba(248,250,247,.8)}
.form-label span{color:var(--clr-gold)}
.form-input{width:100%;padding:.875rem 1rem;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.14);border-radius:var(--r-md);font-family:var(--ff-body);font-size:.9375rem;color:var(--clr-cream);transition:border-color var(--t-fast),box-shadow var(--t-fast);appearance:none}
.form-input:focus{outline:none;border-color:var(--clr-gold);box-shadow:0 0 0 3px rgba(233,196,106,.18)}
.form-input::placeholder{color:rgba(248,250,247,.35)}
.form-textarea{min-height:140px;resize:vertical}
.form-message{padding:.875rem 1rem;border-radius:var(--r-md);font-family:var(--ff-ui);font-size:.875rem;font-weight:500;display:none}
.form-message.success{display:block;background:rgba(64,145,108,.15);border:1px solid rgba(64,145,108,.4);color:var(--clr-sage)}
.form-message.error{display:block;background:rgba(192,57,43,.1);border:1px solid rgba(192,57,43,.3);color:#e57373}

/* FOOTER */
.site-footer{background:var(--clr-forest);color:rgba(248,250,247,.75)}
.footer-top{padding-block:var(--sp-3xl);border-bottom:1px solid rgba(248,250,247,.08)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:var(--sp-xl)}
.footer-logo-img{height:42px;width:auto;display:block;margin-bottom:1rem}
.footer-tagline{font-family:var(--ff-body);font-style:italic;font-size:.9375rem;color:rgba(248,250,247,.55);margin-bottom:1.25rem}
.footer-legal{font-family:var(--ff-ui);font-size:.8125rem;color:rgba(248,250,247,.5);line-height:1.75}
.footer-legal strong{color:var(--clr-gold)}
.footer-nav-title{font-family:var(--ff-ui);font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--clr-gold);margin-bottom:1.25rem}
.footer-nav ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.625rem}
.footer-nav a{font-family:var(--ff-ui);font-size:.875rem;color:rgba(248,250,247,.65);text-decoration:none;transition:color var(--t-fast)}
.footer-nav a:hover{color:var(--clr-cream)}
.footer-contact address{font-size:.875rem;line-height:1.8;color:rgba(248,250,247,.6);margin-bottom:.875rem}
.footer-email{font-family:var(--ff-ui);font-size:.875rem;color:var(--clr-gold);text-decoration:none}
.footer-email:hover{color:var(--clr-gold-lt)}
.footer-bottom{padding-block:1.5rem}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer-copy{font-family:var(--ff-ui);font-size:.8125rem;color:rgba(248,250,247,.4)}
.footer-legal-links{display:flex;gap:1.5rem}
.footer-legal-links a{font-family:var(--ff-ui);font-size:.8125rem;color:rgba(248,250,247,.4);text-decoration:none;transition:color var(--t-fast)}
.footer-legal-links a:hover{color:rgba(248,250,247,.75)}
.back-to-top{position:fixed;bottom:2rem;right:2rem;width:48px;height:48px;border-radius:50%;background:var(--clr-forest-lt);color:#fff;border:none;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(12px);transition:all var(--t-mid);z-index:900}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--clr-forest-mid);transform:translateY(-3px)}

/* RESPONSIVE */
@media(max-width:1100px){.footer-grid{grid-template-columns:1fr 1fr;gap:var(--sp-lg)}}
@media(max-width:900px){
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .about-badge{bottom:-1rem;right:-.5rem}
  .about-content{padding-left:0}
  .programs-grid{grid-template-columns:repeat(2,1fr)}
  .stories-grid{grid-template-columns:1fr}
  .involve-grid{grid-template-columns:1fr}
  .impact-grid{grid-template-columns:repeat(2,1fr)}
  .donation-grid{grid-template-columns:repeat(2,1fr);max-width:640px}
}
@media(max-width:768px){
  :root{--header-h:68px}
  .nav-toggle{display:flex}
  .nav-links{position:fixed;top:var(--header-h);left:0;right:0;background:var(--clr-warm-white);border-top:1px solid var(--clr-border);flex-direction:column;align-items:stretch;padding:1rem var(--container-pad) 1.5rem;gap:.25rem;transform:translateY(-100%);opacity:0;visibility:hidden;transition:transform .35s ease,opacity .35s ease,visibility .35s ease;box-shadow:var(--shadow-lg);z-index:999}
  .nav-links.open{transform:translateY(0);opacity:1;visibility:visible}
  .nav-link{padding:.75rem 1rem;font-size:1rem}
  .nav-link.nav-cta{margin-left:0;text-align:center;margin-top:.5rem}
  .hero-content{padding-left:var(--container-pad)}
  .hero-actions{flex-direction:column}
  .programs-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom-inner{flex-direction:column;text-align:center}
  .footer-legal-links{justify-content:center}
  .form-row{grid-template-columns:1fr}
  .contact-form-wrap{padding:var(--sp-md)}
  .gt-row{grid-template-columns:1fr}
  .gt-body{padding:1.25rem}
}
@media(max-width:560px){
  .donation-grid{grid-template-columns:1fr;max-width:380px}
  .impact-grid{grid-template-columns:1fr 1fr}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}