/* ============================================================
   Caring Humanity Trust
   Warm Editorial Humanism — paper · evergreen · clay
   ============================================================ */

:root{
  /* palette */
  --paper:#f4efe4;          /* warm cream canvas */
  --paper-2:#ece5d5;        /* deeper section tone */
  --card:#f9f4ea;           /* raised surface */
  --ink:#18201a;            /* dark green-charcoal */
  --ink-soft:#556059;       /* muted body */
  --forest:#2a6440;         /* logo green (primary) */
  --forest-deep:#163a24;    /* darkest logo green */
  --green:#49a05d;          /* bright logo green */
  --clay:#c6912f;           /* logo amber (accent) */
  --clay-deep:#7e5a11;      /* deep amber — text on cream */
  --clay-soft:#ecd193;      /* light gold — on dark */
  /* logo "people" accents */
  --yellow:#e0b24e;
  --pink:#cf6f96;
  --blue:#5a9bcb;
  --lgreen:#a6cf5b;
  /* soft tints for card/section backgrounds */
  --tint-yellow:#f7ecca;
  --tint-pink:#f7e5eb;
  --tint-blue:#e6eef7;
  --tint-green:#eaf2da;
  --tint-purple:#ece6f5;
  --purple:#7d5faf;
  --purple-deep:#66499a;
  --tint-red:#f9e2dd;
  --red:#cb503a;
  --red-deep:#a63a27;
  --line:rgba(24,32,26,.14);
  --line-soft:rgba(24,32,26,.08);

  /* type */
  --display:"Bricolage Grotesque", "Segoe UI", sans-serif;
  --serif:"Newsreader", Georgia, serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;

  --ease:cubic-bezier(.2,.8,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --r:18px;
  --pad:clamp(20px,5vw,64px);
  --maxw:1280px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--clay);color:var(--paper)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);position:relative;z-index:1}
.display{font-family:var(--display);font-weight:600;letter-spacing:-.03em;line-height:1.02}
.ital{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:-.01em}

/* ---------- Labels ---------- */
.label{
  display:inline-flex;align-items:center;gap:11px;
  font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--clay-deep);margin-bottom:26px;
}
.label.light{color:var(--clay-soft)}
.tick{width:26px;height:1px;background:currentColor;display:inline-block;opacity:.7}

/* ---------- Buttons ---------- */
.pill{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:13px 24px;border-radius:999px;font-weight:500;font-size:.95rem;
  transition:transform .5s var(--ease-out),background .35s,color .35s,box-shadow .45s,border-color .35s;
  will-change:transform;
}
.pill svg{width:17px;height:17px;transition:transform .5s var(--ease-out)}
.pill-solid{position:relative;overflow:hidden;background:var(--purple);color:#fff;box-shadow:0 10px 26px -12px rgba(125,95,175,.6)}
.pill-solid::after{content:"";position:absolute;top:0;left:-45%;width:40%;height:100%;background:linear-gradient(115deg,transparent,rgba(255,255,255,.42),transparent);transform:skewX(-18deg);pointer-events:none}
.pill-solid:hover{background:var(--purple-deep);box-shadow:0 18px 40px -12px rgba(125,95,175,.72)}
.pill-solid:hover::after{animation:pillShine .85s var(--ease)}
.pill-solid:hover svg{transform:translateX(4px)}
@keyframes pillShine{from{left:-45%}to{left:135%}}
.pill-line{border:1.4px solid currentColor;color:var(--paper)}
.pill-line:hover{background:var(--paper);color:var(--forest-deep)}
.pill-line:hover svg{transform:translateX(4px)}
.pill-lg{padding:16px 30px;font-size:1rem}
.pill-block{width:100%}

.link-underline{
  position:relative;font-weight:500;font-size:.98rem;padding-bottom:3px;width:max-content;
}
.link-underline::after{
  content:"";position:absolute;left:0;bottom:0;height:1.4px;width:100%;
  background:currentColor;transform:scaleX(1);transform-origin:right;
  transition:transform .5s var(--ease-out);
}
.link-underline:hover::after{transform:scaleX(0);transform-origin:right}
.link-underline::before{
  content:"";position:absolute;left:0;bottom:0;height:1.4px;width:100%;
  background:var(--clay);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease-out) .05s;
}
.link-underline:hover::before{transform:scaleX(1)}

/* ---------- Loader ---------- */
.loader{
  position:fixed;inset:0;z-index:300;background:var(--paper);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;
  transition:opacity .8s var(--ease),visibility .8s;
}
.loader.done{opacity:0;visibility:hidden}
.loader-logo{width:min(210px,52vw);height:auto;opacity:0;transform:scale(.92);animation:loaderIn .9s var(--ease-out) forwards}
@keyframes loaderIn{to{opacity:1;transform:scale(1)}}
.loader-bar{width:min(200px,52vw);height:2px;background:rgba(25,27,23,.14);border-radius:2px;overflow:hidden}
.loader-bar i{display:block;height:100%;width:0;background:var(--clay);animation:lbar 1.3s var(--ease) forwards .1s}
@keyframes lbar{to{width:100%}}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:transform .5s var(--ease)}
.nav-row{
  max-width:var(--maxw);margin:0 auto;padding:22px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  border:1px solid transparent;border-radius:0;
  transition:max-width .55s var(--ease),margin .55s var(--ease),padding .55s var(--ease),
    background .5s var(--ease),border-radius .55s var(--ease),border-color .5s,box-shadow .5s var(--ease);
}
.nav.scrolled .nav-row{
  max-width:min(1140px,calc(100% - 26px));
  margin:12px auto 0;
  padding:10px 12px 10px 26px;
  background:rgba(242,237,226,.82);
  backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);
  border-color:var(--line-soft);
  border-radius:999px;
  box-shadow:0 16px 44px -20px rgba(21,42,32,.34);
}
.nav.hide{transform:translateY(-115%)}

.wordmark{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:600;font-size:1.08rem;letter-spacing:-.02em;line-height:1;transition:color .4s var(--ease)}
.nav-mark{height:34px;width:auto;flex-shrink:0;transition:transform .45s var(--ease-out)}
.wordmark:hover .nav-mark{transform:rotate(-6deg) scale(1.06)}
.wordmark-text{display:flex;align-items:baseline;gap:.4ch}
.wordmark em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--clay-deep);font-size:1.05rem}
.nav.scrolled .nav-mark{height:30px}

.nav-links{display:flex;gap:6px}
.nav-links a{
  position:relative;display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px;border-radius:999px;font-size:.9rem;font-weight:500;color:var(--ink);
  transition:background .35s,color .35s;
}
.nav-idx{font-family:var(--display);font-size:.66rem;opacity:.45;letter-spacing:0}
.nav-links a:hover,.nav-links a.active{background:var(--hc,rgba(25,27,23,.06));color:var(--ink)}
.hv-yellow{--hc:#f0d585}
.hv-blue{--hc:#a6c9e5}
.hv-pink{--hc:#ecb0c6}
.hv-green{--hc:#c1df8c}
.hv-purple{--hc:#c2afe0}
.nav-links a.active .nav-idx{color:var(--clay);opacity:1}

.nav-end{display:flex;align-items:center;gap:14px}
.nav-end .pill{padding:11px 22px;font-size:.9rem}
.burger{display:none;width:44px;height:44px;flex-direction:column;justify-content:center;align-items:center;gap:6px}
.burger span{width:22px;height:1.6px;background:var(--ink);transition:.4s var(--ease)}

/* nav goes light over the hero photo when at the top (before the pill forms) */
.nav:not(.scrolled) .wordmark{color:var(--paper)}
.nav:not(.scrolled) .wordmark em{color:var(--clay-soft)}
.nav:not(.scrolled) .nav-links a{color:rgba(242,237,226,.92)}
.nav:not(.scrolled) .nav-links a:hover,.nav:not(.scrolled) .nav-links a.active{background:var(--hc);color:var(--ink)}
.nav:not(.scrolled) .burger span{background:var(--paper)}

/* ---------- Hero ---------- */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:120px 0 40px;position:relative;overflow:hidden}

/* hero photo background + cursor node field */
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;background:#24163a}
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;animation:heroZoom 18s var(--ease-out) forwards}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:
  linear-gradient(90deg, rgba(42,26,62,.92) 0%, rgba(42,26,62,.66) 46%, rgba(42,26,62,.34) 100%),
  linear-gradient(180deg, rgba(42,26,62,.4) 0%, transparent 26%, rgba(42,26,62,.55) 100%);}
.node-canvas{position:absolute;inset:0;width:100%;height:100%}

.hero-grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);width:100%;position:relative;z-index:1;
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(30px,5vw,70px);align-items:center}
.hero-grid.hero-single{grid-template-columns:1fr}
.hero-single .hero-lead{max-width:840px}
.hero-head{font-size:clamp(2.7rem,7vw,5.6rem);margin:8px 0 30px;color:var(--paper)}
.hero-head .ln{display:block;overflow:hidden;padding-bottom:.04em}
.hero-head .ln>span{display:block;transform:translateY(105%);animation:lineUp 1s var(--ease-out) forwards}
.hero-head .ln:nth-child(1)>span{animation-delay:.5s}
.hero-head .ln:nth-child(2)>span{animation-delay:.62s}
.hero-head .ln:nth-child(3)>span{animation-delay:.74s}
@keyframes lineUp{to{transform:translateY(0)}}
.hero-head .ital{color:var(--clay)}
.hero-sub{font-size:clamp(1.02rem,1.5vw,1.18rem);color:rgba(242,237,226,.84);max-width:40ch;margin-bottom:36px}
.hero-cta{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.hero .link-underline{color:var(--paper)}

.hero-media{position:relative}
.arch{
  position:relative;overflow:hidden;
  border-radius:clamp(120px,20vw,220px) clamp(120px,20vw,220px) var(--r) var(--r);
  background:linear-gradient(160deg,var(--forest),var(--clay-deep));
  box-shadow:0 40px 80px -40px rgba(21,42,32,.5);
  aspect-ratio:4/5;
}
.arch img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease-out),opacity .4s;transform:scale(1.04)}
.arch img.is-broken{opacity:0}
.hero-media:hover .arch img{transform:scale(1.09)}
.hero-tag{
  position:absolute;left:-14px;bottom:34px;display:flex;align-items:center;gap:11px;
  background:var(--card);padding:12px 18px 12px 14px;border-radius:14px;
  box-shadow:0 20px 40px -20px rgba(21,42,32,.4);animation:floaty 5s ease-in-out infinite;
}
.hero-tag .dot{width:9px;height:9px;border-radius:50%;background:var(--clay);position:relative}
.hero-tag .dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--clay);animation:ping 1.8s var(--ease) infinite}
.hero-tag strong{display:block;font-size:.92rem;font-weight:600}
.hero-tag small{color:var(--ink-soft);font-size:.78rem}
@keyframes floaty{50%{transform:translateY(-12px)}}
@keyframes ping{to{transform:scale(2.6);opacity:0}}

.hero-foot{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);width:100%;position:relative;z-index:1;
  display:flex;align-items:flex-end;justify-content:space-between;margin-top:clamp(30px,5vw,56px);gap:20px}
.scroll-cue{display:inline-flex;align-items:center;gap:12px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(242,237,226,.72)}
.scroll-cue span{width:34px;height:34px;border:1px solid rgba(242,237,226,.35);border-radius:50%;position:relative;flex-shrink:0}
.scroll-cue span::after{content:"";position:absolute;left:50%;top:11px;width:1px;height:8px;background:var(--clay);transform:translateX(-50%);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{opacity:1;top:11px}70%{opacity:0;top:19px}100%{opacity:0}}
.hero-strip{list-style:none;display:flex;gap:0;flex-wrap:wrap;text-align:right}
.hero-strip li{font-family:var(--display);font-size:clamp(.9rem,1.3vw,1.05rem);font-weight:500;color:var(--paper);padding-left:22px;position:relative}
.hero-strip li+li::before{content:"";position:absolute;left:11px;top:50%;width:3px;height:3px;border-radius:50%;background:var(--clay);transform:translateY(-50%)}

/* ---------- Belt ---------- */
.belt{background:var(--forest);color:var(--paper);overflow:hidden;padding:16px 0}
.belt-track{display:flex;align-items:center;gap:26px;width:max-content;animation:belt 34s linear infinite}
.belt-track span{font-family:var(--display);font-weight:500;font-size:1.15rem;white-space:nowrap}
.belt-track b{color:var(--clay-soft)}
@keyframes belt{to{transform:translateX(-50%)}}

/* ---------- Sections ---------- */
.section{padding:clamp(52px,6.5vw,92px) 0;position:relative}
.section-head{max-width:720px;margin-bottom:clamp(26px,3.6vw,44px)}
.section-head.row{max-width:none;display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.section-title{font-size:clamp(2rem,5vw,3.6rem)}
.section-title .ital,.mission-head .ital,.donate-head .ital{color:var(--forest)}
.section-head.light .label{color:var(--clay-soft)}
.section-head.light .section-title{color:var(--paper)}
.section-head.light .section-title .ital{color:var(--clay-soft)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);filter:blur(6px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out),filter .9s var(--ease-out);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none;filter:none}

/* ---------- Mission ---------- */
.mission{background:var(--tint-yellow)}
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:start}
.mission-head{font-size:clamp(2.2rem,4.6vw,4rem)}
.mission-left{position:sticky;top:120px}
.lede{font-size:clamp(1.15rem,1.8vw,1.4rem);color:var(--ink);margin-bottom:24px;line-height:1.5}
.mission-right>p{color:var(--ink-soft);font-size:1.02rem;margin-bottom:22px}
.mission-facts{display:flex;flex-direction:column;gap:0;margin-top:34px;border-top:1px solid var(--line)}
.fact{display:grid;grid-template-columns:130px 1fr;gap:20px;padding:20px 0;border-bottom:1px solid var(--line);align-items:baseline}
.fact strong{font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--forest)}
.fact span{color:var(--ink-soft);font-size:.95rem}

/* ---------- Programs / Index ---------- */
.programs{background:var(--tint-blue);overflow:hidden}
.index{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);border-top:1px solid var(--line);position:relative;z-index:1}
.index-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:clamp(20px,4vw,60px);align-items:center;
  padding:clamp(26px,3.6vw,44px) 8px;border-bottom:1px solid var(--line);
  position:relative;transition:padding-left .55s var(--ease-out),color .4s;
}
.index-row::before{
  content:"";position:absolute;inset:0;background:var(--rc,var(--forest));border-radius:14px;
  transform:scaleY(.3);opacity:0;transition:transform .55s var(--ease-out),opacity .45s;z-index:0;transform-origin:center;
}
.index-row>*{position:relative;z-index:1}
.index-row.hot{padding-left:clamp(20px,3vw,40px);color:var(--forest-deep)}
.index-row.hot::before{transform:scaleY(1);opacity:1}
.row-num{font-family:var(--display);font-size:1rem;font-weight:500;color:var(--ink-soft);transition:color .4s}
.tone-yellow{--rc:var(--yellow)}
.tone-pink{--rc:var(--pink)}
.tone-blue{--rc:var(--blue)}
.tone-lgreen{--rc:var(--lgreen)}
.index-row.hot .row-num{color:rgba(22,58,36,.7)}
.row-main h3{font-size:clamp(1.7rem,4vw,3rem);line-height:1;transition:transform .55s var(--ease-out)}
.index-row.hot .row-main h3{transform:translateX(10px)}
.row-main p{color:var(--ink-soft);font-size:.98rem;margin-top:8px;max-width:52ch;transition:color .4s,transform .55s var(--ease-out)}
.index-row.hot .row-main p{color:rgba(22,58,36,.78);transform:translateX(10px)}
.row-unit{color:var(--clay-deep);font-weight:500}
.index-row.hot .row-unit{color:var(--forest-deep)}
.row-go{width:54px;height:54px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);flex-shrink:0;transition:background .4s,color .4s,border-color .4s,transform .55s var(--ease-out)}
.row-go svg{width:20px;height:20px}
.index-row.hot .row-go{background:transparent;border-color:rgba(22,58,36,.4);color:var(--forest-deep);transform:rotate(0) scale(1.05)}
.index-row:not(.hot) .row-go:hover{background:var(--ink);border-color:var(--ink);color:var(--paper)}

.index-preview{
  position:fixed;top:0;left:0;width:230px;height:290px;border-radius:130px 130px 14px 14px;overflow:hidden;
  pointer-events:none;z-index:60;opacity:0;transform:translate(-50%,-50%) scale(.8) rotate(-4deg);
  transition:opacity .4s var(--ease),transform .5s var(--ease-out);box-shadow:0 30px 60px -25px rgba(21,42,32,.5);
}
.index-preview.show{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(-4deg)}
.index-preview img{width:100%;height:100%;object-fit:cover}

/* ---------- Impact (bento) ---------- */
.impact{background:var(--tint-pink);color:var(--ink);overflow:hidden}
.impact .section-title .ital{color:var(--pink)}
.impact .bento-tile{box-shadow:0 16px 36px -24px rgba(90,30,60,.4)}
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(158px,auto);gap:14px}
.bento-tile{position:relative;border:1px solid rgba(242,237,226,.14);border-radius:var(--r);padding:26px;
  background:rgba(242,237,226,.045);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .55s var(--ease-out),background .4s,border-color .4s}
.bento-tile:hover{transform:translateY(-6px);border-color:rgba(242,237,226,.3)}
.tile-body{margin-top:auto}

.tile-ic{width:46px;height:46px;border-radius:13px;background:rgba(242,237,226,.08);color:var(--clay-soft);
  display:grid;place-items:center;transition:transform .55s var(--ease-out)}
.tile-ic svg{width:23px;height:23px}
.bento-tile:hover .tile-ic{transform:rotate(-6deg) scale(1.06)}
.tile-fig{display:flex;align-items:flex-start;gap:2px}
.tile-fig .count{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.4vw,2.7rem);line-height:.9;color:var(--paper);letter-spacing:-.03em}
.tile-fig .plus{font-family:var(--display);font-size:1.3rem;color:var(--clay-soft)}
.tile-label{color:rgba(242,237,226,.72);font-size:.92rem;margin-top:9px}
.impact .stat-pink,.impact .stat-blue,.impact .stat-lgreen{background:transparent;border-color:transparent;box-shadow:none}
.stat-pink .count,.stat-pink .plus{color:#bb4470}
.stat-blue .count,.stat-blue .plus{color:#3d7fb2}
.stat-lgreen .count,.stat-lgreen .plus{color:#5f8a25}
.stat-pink .tile-label,.stat-blue .tile-label,.stat-lgreen .tile-label{color:var(--ink-soft)}
.impact .stat-pink:hover,.impact .stat-blue:hover,.impact .stat-lgreen:hover{transform:translateY(-4px);box-shadow:none}

/* feature tile — photo background + clay wash */
.tile-feature{grid-column:span 2;grid-row:span 2;background:var(--forest);border-color:transparent;justify-content:flex-end;color:var(--paper)}
.tile-feature:hover{transform:translateY(-6px)}
.tile-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform 1.3s var(--ease-out),opacity .4s}
.tile-photo.is-broken{opacity:0}
.tile-feature:hover .tile-photo{transform:scale(1.06)}
.tile-feature::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(150deg, rgba(198,145,47,.86) 0%, rgba(150,105,20,.72) 46%, rgba(20,52,32,.93) 100%)}
.tile-feature .tile-body{position:relative;z-index:2;margin-top:0}
.tile-feature .tile-fig .count{font-size:clamp(3.2rem,7vw,5.6rem);color:var(--paper)}
.tile-feature .tile-fig .plus{font-size:2rem;color:rgba(242,237,226,.7)}
.tile-feature .tile-label{color:rgba(242,237,226,.92);font-size:1.08rem;font-weight:500;max-width:24ch;margin-top:14px}

/* image tile */
.tile-img{grid-column:span 2;grid-row:span 2;padding:0}
.tile-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease-out),opacity .4s;filter:saturate(.92)}
.tile-img img.is-broken{opacity:0}
.tile-img:hover img{transform:scale(1.06)}
.tile-img figcaption{position:absolute;left:0;right:0;bottom:0;z-index:1;padding:48px 24px 22px;
  background:linear-gradient(transparent,rgba(14,27,20,.88));color:var(--paper);font-size:.92rem;font-weight:500;
  display:flex;align-items:center;gap:10px}
.tile-img .pulse{width:8px;height:8px;border-radius:50%;background:var(--clay);position:relative;flex-shrink:0}
.tile-img .pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--clay);animation:ping 1.9s var(--ease) infinite}

/* note tile */
.tile-note{justify-content:space-between;gap:16px;background:var(--card);border-color:var(--line-soft)}
.tile-note p{font-family:var(--serif);font-style:italic;font-size:1.08rem;line-height:1.4;color:var(--ink)}
.tile-link{display:inline-flex;align-items:center;gap:8px;color:var(--purple-deep);font-weight:600;font-size:.92rem;width:max-content}
.tile-link svg{width:16px;height:16px;transition:transform .45s var(--ease-out)}
.tile-note:hover .tile-link svg{transform:translate(3px,-3px)}

/* ---------- Campaigns ---------- */
.campaigns{background:var(--paper);overflow:hidden}
.camp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.camp{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;transition:transform .55s var(--ease-out),box-shadow .55s}
.camp-yellow{background:var(--tint-yellow)}
.camp-blue{background:var(--tint-blue)}
.camp-green{background:var(--tint-green)}
.camp:hover{transform:translateY(-8px);box-shadow:0 30px 60px -30px rgba(21,42,32,.3)}
.camp-img{aspect-ratio:16/11;overflow:hidden;background:linear-gradient(160deg,var(--forest),var(--clay-deep))}
.camp-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03);transition:transform 1.1s var(--ease-out),filter .7s var(--ease-out),opacity .4s}
.camp-img img.is-broken{opacity:0}
.camp:hover .camp-img img{transform:scale(1.07);filter:grayscale(0) contrast(1)}
.camp-body{padding:24px 24px 26px}
.camp-cat{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-deep);background:rgba(198,145,47,.16)}
.cat-food{color:#8a6412;background:rgba(224,178,78,.22)}
.cat-edu{color:#2f6d99;background:rgba(90,155,203,.2)}
.cat-water{color:#5a7a1e;background:rgba(166,207,91,.26)}
.camp-body h3{font-size:1.5rem;margin:10px 0 8px}
.camp-body>p{color:var(--ink-soft);font-size:.94rem;margin-bottom:22px}
.meter{height:5px;border-radius:5px;background:rgba(25,27,23,.1);overflow:hidden}
.meter i{display:block;height:100%;width:0;border-radius:5px;background:linear-gradient(90deg,var(--forest),var(--clay));transition:width 1.6s var(--ease-out) .2s}
.camp-meta{display:flex;justify-content:space-between;margin-top:12px;font-size:.86rem;color:var(--ink-soft)}
.camp-meta b{color:var(--forest);font-size:.98rem}

/* ---------- Quote ---------- */
.quote{background:var(--tint-green);text-align:center}
.quote-inner{max-width:900px;margin:0 auto}
.quote-text{font-family:var(--serif);font-weight:400;font-size:clamp(1.6rem,4vw,2.9rem);line-height:1.28;letter-spacing:-.01em}
.quote-text .ital{color:var(--forest)}
.quote-by{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:44px}
.quote-sig{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,3.4vw,2.3rem);color:var(--ink);line-height:1;position:relative;padding-bottom:16px}
.quote-sig::after{content:"";position:absolute;left:50%;bottom:0;width:72px;height:1.6px;background:var(--clay);transform:translateX(-50%) scaleX(0);transform-origin:center;transition:transform .85s var(--ease-out) .35s}
.quote-inner.in .quote-sig::after{transform:translateX(-50%) scaleX(1)}
.quote-role{font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}

/* ---------- Donate ---------- */
.donate{background:var(--tint-red);color:var(--ink)}
.donate .label.light{color:var(--red-deep)}
.donate-grid{display:grid;grid-template-columns:1fr .85fr;gap:clamp(34px,5vw,80px);align-items:center}
.donate-head{font-size:clamp(2rem,4.4vw,3.6rem);color:var(--ink)}
.donate-head .ital{color:var(--red)}
.donate-copy>p{color:var(--ink-soft);font-size:1.05rem;margin:22px 0 26px;max-width:44ch}
.donate-list{list-style:none;display:flex;flex-direction:column;gap:13px}
.donate-list li{display:flex;align-items:center;gap:12px;color:var(--ink);font-size:.98rem}
.donate-list i{width:7px;height:7px;border-radius:50%;background:var(--red);flex-shrink:0}

.give-card{background:var(--card);color:var(--ink);border-radius:24px;padding:30px 28px;box-shadow:0 40px 90px -40px rgba(0,0,0,.6)}
.give-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.give-head>span:first-child{font-family:var(--display);font-weight:600;font-size:1.15rem}
.give-secure{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;color:var(--ink-soft)}
.give-secure svg{width:15px;height:15px}
.amounts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.amt{border:1.4px solid var(--line);border-radius:14px;padding:14px 12px;text-align:left;transition:border-color .35s,background .35s,transform .4s var(--ease-out),color .35s}
.amt b{font-family:var(--display);font-weight:600;font-size:1.15rem;display:block}
.amt span{font-size:.76rem;color:var(--ink-soft);transition:color .35s}
.amt:hover{transform:translateY(-3px);border-color:var(--forest)}
.amt.is-on{background:var(--forest);border-color:var(--forest);color:var(--paper)}
.amt.is-on span{color:rgba(242,237,226,.72)}
.custom{display:flex;align-items:center;gap:8px;border:1.4px solid var(--line);border-radius:14px;padding:0 16px;margin-bottom:16px;transition:border-color .35s}
.custom:focus-within{border-color:var(--forest)}
.custom span{font-family:var(--display);font-weight:600;color:var(--ink-soft)}
.custom input{border:none;outline:none;background:none;width:100%;padding:14px 0;font:inherit;font-weight:500;color:var(--ink)}
.custom input::-webkit-inner-spin-button,.custom input::-webkit-outer-spin-button{-webkit-appearance:none}
#giveBtn svg{width:19px;height:19px}
#giveBtn b,#giveLabel{font-weight:600}
.give-fine{margin-top:14px;font-size:.76rem;color:var(--ink-soft);text-align:center;line-height:1.5}

/* ---------- Footer ---------- */
.footer{background:var(--tint-purple);color:var(--ink-soft);padding:clamp(48px,6vw,72px) 0 34px;overflow:hidden}
.foot-top{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(34px,5vw,70px);padding-bottom:clamp(38px,5vw,60px)}
.foot-lede{font-size:clamp(1.8rem,3.6vw,3rem);color:var(--ink);margin:14px 0 30px;max-width:16ch}
.foot-lede .ital{color:var(--purple)}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.foot-col h4{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--purple-deep);margin-bottom:16px;font-weight:600}
.foot-col a{display:block;padding:6px 0;font-size:.95rem;transition:color .3s,transform .4s var(--ease-out);width:max-content}
.foot-col a:hover{color:var(--ink);transform:translateX(4px)}
.foot-col p{font-size:.92rem;line-height:1.55;margin-bottom:12px}
.foot-mark{font-size:clamp(2.4rem,8.3vw,9rem);line-height:.92;letter-spacing:-.045em;text-align:center;padding:clamp(20px,4vw,44px) 0;border-top:1px solid rgba(24,32,26,.12);white-space:nowrap;
  --mx:-9999px;--my:-9999px;
  color:rgba(125,95,175,.34);
  background:radial-gradient(circle 115px at var(--mx) var(--my), var(--purple) 0, var(--purple) 100%, rgba(125,95,175,.34) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.foot-base{display:flex;justify-content:space-between;align-items:center;gap:12px 24px;flex-wrap:wrap;padding-top:26px;border-top:1px solid rgba(24,32,26,.12);font-size:.84rem}
.foot-credit{color:rgba(24,32,26,.5)}
@media(min-width:641px){.foot-base{padding-right:72px}}
.foot-credit a{color:var(--ink-soft);border-bottom:1px solid rgba(125,95,175,.4);transition:color .3s,border-color .3s}
.foot-credit a:hover{color:var(--purple);border-color:var(--purple)}
.footer .label.light{color:var(--purple-deep)}
.footer .pill-line{color:var(--ink)}
.footer .pill-line:hover{background:var(--ink);color:var(--tint-purple)}

/* ---------- Floating ---------- */
.wa{position:fixed;right:22px;bottom:22px;z-index:80;width:56px;height:56px;border-radius:50%;background:#1f8a4c;color:#fff;display:grid;place-items:center;box-shadow:0 16px 34px -12px rgba(31,138,76,.6);transition:transform .45s var(--ease-out)}
.wa:hover{transform:scale(1.08) rotate(6deg)}
.wa svg{width:27px;height:27px}
.wa::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid rgba(31,138,76,.5);animation:ping 2.2s var(--ease) infinite}
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--clay);z-index:200}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,340px);background:var(--forest-deep);
    flex-direction:column;justify-content:center;gap:6px;padding:80px 40px;transform:translateX(100%);
    transition:transform .55s var(--ease-out);box-shadow:-30px 0 80px rgba(0,0,0,.35)}
  .nav-links.open{transform:none}
  .nav-links a{color:var(--paper);font-family:var(--display);font-size:1.5rem;padding:12px 0}
  .nav-links a .nav-idx{color:var(--clay-soft)}
  .burger{display:flex;z-index:110}
  body.menu-open .burger span:nth-child(1){transform:translateY(3.8px) rotate(45deg);background:var(--paper)}
  body.menu-open .burger span:nth-child(2){transform:translateY(-3.8px) rotate(-45deg);background:var(--paper)}
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero-media{max-width:420px}
  .mission-grid{grid-template-columns:1fr;gap:30px}
  .mission-left{position:static}
  .camp-grid{grid-template-columns:1fr 1fr}
  .donate-grid{grid-template-columns:1fr;gap:40px}
  .foot-top{grid-template-columns:1fr}
  .bento{grid-template-columns:repeat(2,1fr)}
  .tile-feature{grid-column:span 2;grid-row:span 1}
  .tile-img{grid-column:span 2;grid-row:span 1;min-height:240px}
}
@media(max-width:640px){
  .nav-end .pill-solid{display:none}
  .hero-foot{flex-direction:column;align-items:flex-start;gap:24px}
  .hero-strip{text-align:left}
  .camp-grid{grid-template-columns:1fr;max-width:460px}
  .foot-cols{grid-template-columns:1fr 1fr;gap:24px}
  .foot-mark{white-space:normal;font-size:clamp(2rem,12vw,3.4rem);line-height:1}
  .foot-base{flex-direction:column;align-items:flex-start;gap:10px}
  .fact{grid-template-columns:100px 1fr;gap:14px}
  .index-row{grid-template-columns:auto 1fr;gap:16px}
  .row-go{grid-column:2;justify-self:start;margin-top:4px;width:46px;height:46px}
  .index-preview{display:none}
  .bento{grid-template-columns:1fr}
  .tile-feature,.tile-img{grid-column:span 1}
  .tile-img{min-height:210px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.2s!important;scroll-behavior:auto}
  .reveal{opacity:1!important;transform:none!important;filter:none!important}
  .hero-head .ln>span{transform:none!important;animation:none!important}
  .loader-logo{opacity:1!important;transform:none!important;animation:none!important}
}
