/* =====================================================================
   TRANQUIL MINDS — "Warm Sanctuary" design system
   Pine green anchor · honey-amber hope accent · cream canvas
   Display: Fraunces (soft optical serif) · Body: Plus Jakarta Sans
   ===================================================================== */

/* ---------- Self-hosted fonts (variable) ---------- */
@font-face{font-family:'Fraunces';font-style:normal;font-weight:300 700;font-display:swap;
  src:url('../fonts/fraunces-normal.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:300 700;font-display:swap;
  src:url('../fonts/fraunces-italic.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400 700;font-display:swap;
  src:url('../fonts/jakarta-normal.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-style:italic;font-weight:400 700;font-display:swap;
  src:url('../fonts/jakarta-italic.woff2') format('woff2')}

/* ---------- Tokens ---------- */
:root {
  /* Primitives */
  --pine-900:#16312a;
  --pine-800:#1d3a30;
  --pine-700:#244c3e;
  --pine-600:#2c5a49;
  --pine-500:#3a715c;
  --sage-200:#dbe7e0;
  --sage-100:#e9f0eb;
  --amber-600:#b46c14;
  --amber-500:#d98324;
  --amber-400:#e6a34a;
  --amber-100:#f7e7cf;
  --cream:#f6f2e8;
  --cream-card:#fffdf7;
  --ink:#1b231e;
  --ink-soft:#4c574f;
  --muted:#7d887f;
  --line:#e4ddcd;
  --white:#ffffff;

  /* Semantic */
  --bg-base:var(--cream);
  --bg-surface:var(--cream-card);
  --bg-deep:var(--pine-800);
  --text-primary:var(--ink);
  --text-secondary:var(--ink-soft);
  --text-muted:var(--muted);
  --text-on-dark:#eef3ee;
  --text-on-dark-soft:#b9c8bf;
  --border:var(--line);
  --accent:var(--amber-500);
  --accent-ink:var(--amber-600);

  /* Spacing (4px scale) */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px;
  --s-6:24px; --s-8:32px; --s-10:40px; --s-12:48px; --s-16:64px;
  --s-20:80px; --s-24:96px; --s-32:128px;

  /* Radius */
  --r-sm:8px; --r-md:14px; --r-lg:24px; --r-xl:32px; --r-full:9999px;
  --arch:200px; /* signature doorway top radius */

  /* Elevation (warm, soft) */
  --sh-sm:0 1px 2px rgba(28,45,38,.06);
  --sh-md:0 8px 24px rgba(28,45,38,.08), 0 2px 6px rgba(28,45,38,.05);
  --sh-lg:0 24px 60px rgba(28,45,38,.14), 0 8px 18px rgba(28,45,38,.08);

  /* Layout widths */
  --w-narrow:640px; --w-content:760px; --w-wide:1080px; --w-full:1240px;

  /* Motion */
  --dur-fast:140ms; --dur:240ms; --dur-slow:520ms;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.4,.5,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--bg-base);color:var(--text-primary);
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,sans-serif;
  font-size:17px;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
h1,h2,h3,h4{margin:0;font-family:"Fraunces",Georgia,serif;font-weight:500;
  line-height:1.08;letter-spacing:-.015em;color:var(--text-primary);
  font-optical-sizing:auto;}
p{margin:0}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:4px}

.container{width:100%;max-width:var(--w-full);margin-inline:auto;padding-inline:24px}
.section{padding-block:var(--s-24)}
.section--tight{padding-block:var(--s-16)}
.bleed{max-width:var(--w-content);margin-inline:auto}

/* ---------- Type helpers ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-ink);margin:0 0 18px;
}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--accent);display:inline-block}
.eyebrow--light{color:var(--amber-400)}
.eyebrow--center{justify-content:center}
.display{font-size:clamp(2.6rem,6vw,4.4rem)}
.h2{font-size:clamp(2rem,4vw,3rem);letter-spacing:-.02em}
.h3{font-size:clamp(1.35rem,2.2vw,1.7rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);line-height:1.6;color:var(--text-secondary)}
.muted{color:var(--text-muted)}
.serif-i{font-family:"Fraunces",serif;font-style:italic;font-weight:400}
.center{text-align:center}
.measure{max-width:60ch}
.measure-center{max-width:62ch;margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 26px;border-radius:var(--r-full);font-weight:600;font-size:15.5px;
  border:1.5px solid transparent;transition:transform var(--dur-fast) var(--ease-out),
  background var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out),color var(--dur);
  white-space:nowrap;line-height:1;
}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--accent);color:#3a2406;box-shadow:var(--sh-sm)}
.btn--primary:hover{background:var(--amber-400);transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn--primary:active{transform:translateY(0) scale(.985)}
.btn--secondary{background:transparent;color:var(--pine-700);border-color:var(--pine-600)}
.btn--secondary:hover{background:var(--pine-800);color:#fff;border-color:var(--pine-800);transform:translateY(-2px)}
.btn--light{background:#fff;color:var(--pine-800)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost-light:hover{background:rgba(255,255,255,.12);border-color:#fff;transform:translateY(-2px)}
.btn--lg{padding:16px 32px;font-size:16.5px}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;transition:background var(--dur),box-shadow var(--dur),border-color var(--dur);
  border-bottom:1px solid transparent}
.site-header[data-scrolled="true"]{background:rgba(246,242,232,.86);backdrop-filter:saturate(1.4) blur(14px);
  border-bottom-color:var(--line);box-shadow:0 1px 0 rgba(28,45,38,.02)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:78px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Fraunces",serif;font-weight:600;font-size:20px;letter-spacing:-.02em;color:var(--pine-800)}
.brand__mark{width:48px;height:44px;flex:none;display:grid;place-items:center;background:transparent;border-radius:0}
.brand__mark img{width:100%;height:100%;object-fit:contain;display:block}
.brand small{display:block;font-family:"Plus Jakarta Sans";font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin-top:1px}
.nav__links{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav__links a{padding:9px 14px;border-radius:var(--r-full);font-size:15px;font-weight:500;color:var(--text-secondary);transition:color var(--dur),background var(--dur)}
.nav__links a:hover{color:var(--pine-800);background:rgba(44,90,73,.07)}
.nav__links a[aria-current="page"]{color:var(--pine-800);font-weight:600}
.nav__cta{display:flex;align-items:center;gap:10px}
.nav__drawer{display:none}
.nav__toggle{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:var(--cream-card);align-items:center;justify-content:center}
.nav__toggle span,.nav__toggle span::before,.nav__toggle span::after{content:"";display:block;width:20px;height:2px;background:var(--pine-800);border-radius:2px;transition:transform var(--dur),opacity var(--dur)}
.nav__toggle span{position:relative}
.nav__toggle span::before{position:absolute;top:-6px}
.nav__toggle span::after{position:absolute;top:6px}
.nav__toggle[aria-expanded="true"] span{background:transparent}
.nav__toggle[aria-expanded="true"] span::before{transform:translateY(6px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span::after{transform:translateY(-6px) rotate(-45deg)}

/* ---------- Hero (split) ---------- */
.hero{position:relative}

/* ---------- Hero (scroll-tilt, Aceternity-style) ---------- */
.shero{position:relative;min-height:72rem;display:flex;align-items:center;justify-content:center;
  padding:24px 0 72px;overflow:hidden}
.shero__inner{width:100%;perspective:1400px}
.shero__title{max-width:900px;margin:0 auto;text-align:center;padding:0 24px;will-change:transform}
.shero__title .eyebrow{margin-bottom:18px}
.shero__title h1{font-size:clamp(2.7rem,5.6vw,4.8rem);font-weight:480;letter-spacing:-.028em;line-height:1.04}
.shero__title h1 em{font-style:italic;color:var(--pine-600);font-weight:420}
.shero__sub{margin:22px auto 0;max-width:48ch;font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--text-secondary)}
.shero__cta{margin-top:32px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.shero__trust{margin-top:26px;color:var(--text-muted);font-size:14.5px}
.shero__trust strong{color:var(--pine-700);font-weight:700}
.shero__cardwrap{margin:48px auto 0;max-width:1060px;width:100%;padding:0 16px}
.shero__card{position:relative;height:40rem;border-radius:30px;background:var(--pine-900);
  border:4px solid var(--pine-700);padding:18px;
  box-shadow:0 9px 20px rgba(0,0,0,.28),0 37px 50px rgba(0,0,0,.20),0 90px 64px rgba(0,0,0,.12);
  transform-origin:50% 50%;transform:rotateX(18deg) scale(1.05);
  will-change:transform;transition:transform .1s linear}
.shero__screen{height:100%;width:100%;overflow:hidden;border-radius:18px;background:var(--pine-800)}
.shero__screen img{width:100%;height:100%;object-fit:cover;object-position:center 28%;display:block;user-select:none}
@media (max-width:768px){
  .shero{min-height:42rem;padding-top:8px}
  .shero__cardwrap{margin-top:32px;padding:0 8px}
  .shero__card{height:22rem;border-radius:22px;padding:8px;border-width:3px}
  .shero__screen{border-radius:15px}
}
@media (prefers-reduced-motion:reduce){
  .shero{min-height:0;padding-block:48px 64px}
  .shero__card{transform:none!important;height:30rem}
  .shero__cardwrap{margin-top:40px}
}
.hero__copy{max-width:560px}
.hero h1{font-size:clamp(2.7rem,5.4vw,4.5rem);font-weight:480;letter-spacing:-.025em}
.hero h1 em{font-style:italic;color:var(--pine-600);font-weight:420}
.hero__sub{margin-top:22px;font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--text-secondary);max-width:44ch}
.hero__cta{margin-top:34px}
.hero__trust{margin-top:30px;display:flex;align-items:center;gap:14px;color:var(--text-muted);font-size:14px}
.hero__trust strong{color:var(--pine-700);font-weight:700}
.hero__media{position:relative}
.hero__img{width:100%;aspect-ratio:4/4.6;object-fit:cover;object-position:center 30%;
  border-radius:var(--arch) var(--arch) var(--r-lg) var(--r-lg);box-shadow:var(--sh-lg)}
.hero__chip{position:absolute;left:-18px;bottom:34px;background:var(--cream-card);border:1px solid var(--line);
  border-radius:var(--r-md);padding:14px 18px;box-shadow:var(--sh-md);max-width:230px}
.hero__chip b{font-family:"Fraunces",serif;font-size:18px;color:var(--pine-800);display:block}
.hero__chip span{font-size:13px;color:var(--text-muted)}
.hero__leaf{position:absolute;top:-26px;right:-10px;color:var(--sage-200);opacity:.9}

/* ---------- Stats ---------- */
.stats{background:var(--pine-800);color:var(--text-on-dark);border-radius:var(--r-xl);
  padding:54px clamp(24px,4vw,64px);box-shadow:var(--sh-lg);position:relative;overflow:hidden}
.stats::after{content:"";position:absolute;inset:auto -80px -120px auto;width:320px;height:320px;
  background:radial-gradient(circle,rgba(230,163,74,.16),transparent 70%);}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;position:relative}
.stat__num{font-family:"Fraunces",serif;font-size:clamp(2.4rem,4vw,3.3rem);font-weight:500;color:var(--amber-400);line-height:1}
.stat__label{margin-top:10px;font-size:14.5px;color:var(--text-on-dark-soft);line-height:1.4}
.stat{border-left:1px solid rgba(255,255,255,.12);padding-left:22px}
.stat:first-child{border-left:0;padding-left:0}

/* ---------- Section heading block ---------- */
.shead{max-width:680px;margin-bottom:54px}
.shead--center{margin-inline:auto;text-align:center}
.shead p{margin-top:16px;font-size:1.08rem;color:var(--text-secondary)}

/* ---------- Stories (alternating feature) ---------- */
.story{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(32px,5vw,72px);align-items:center}
.story + .story{margin-top:var(--s-24)}
.story--flip .story__media{order:2}
.story__media{position:relative}
.story__frame{position:relative;width:100%;aspect-ratio:4/4.7;overflow:hidden;
  border-radius:var(--arch) var(--arch) var(--r-lg) var(--r-lg);box-shadow:var(--sh-lg);
  transition:box-shadow .6s var(--ease-out)}
.story__img{width:100%;height:100%;object-fit:cover;object-position:center 25%;
  transition:transform .85s var(--ease-out)}
.story:hover .story__frame{box-shadow:0 32px 72px rgba(28,45,38,.20),0 10px 22px rgba(28,45,38,.10)}
.story:hover .story__img{transform:scale(1.06)}
.story__tag{position:absolute;top:18px;left:18px;z-index:3;background:var(--amber-500);color:#3a2406;font-weight:700;
  font-size:12.5px;letter-spacing:.04em;padding:7px 14px;border-radius:var(--r-full);box-shadow:var(--sh-sm);
  transition:transform .4s var(--ease-spring)}
.story:hover .story__tag{transform:translateY(-2px)}
.story h3{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:18px}
.story p{color:var(--text-secondary);margin-bottom:16px}
.quote{margin:24px 0;padding:22px 26px;background:var(--sage-100);border-left:4px solid var(--pine-500);
  border-radius:var(--r-sm);font-family:"Fraunces",serif;font-style:italic;font-size:1.18rem;color:var(--pine-800);line-height:1.5}
.wins{list-style:none;margin:22px 0 0;padding:0;display:grid;gap:11px}
.wins li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;color:var(--text-secondary)}
.wins svg{flex:none;width:21px;height:21px;color:var(--pine-500);margin-top:1px}

/* ---------- Feature band (life skills, full width) ---------- */
.band{position:relative;border-radius:var(--r-xl);overflow:hidden;color:#fff;box-shadow:var(--sh-lg)}
.band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.band__veil{position:absolute;inset:0;background:linear-gradient(100deg,rgba(22,49,42,.94) 0%,rgba(22,49,42,.78) 42%,rgba(22,49,42,.18) 100%)}
.band__inner{position:relative;padding:clamp(40px,6vw,84px);max-width:620px}
.band h2{color:#fff}
.band p{color:var(--text-on-dark-soft);margin-top:18px;font-size:1.08rem}
.band .wins{margin-top:26px}
.band .wins li{color:var(--text-on-dark-soft)}
.band .wins svg{color:var(--amber-400)}

/* ---------- Services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{background:var(--bg-surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;
  transition:transform var(--dur) var(--ease-out),box-shadow var(--dur),border-color var(--dur);position:relative}
.svc:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--sage-200)}
.svc__icon{width:54px;height:54px;border-radius:14px;background:var(--sage-100);color:var(--pine-600);
  display:grid;place-items:center;margin-bottom:20px}
.svc__icon svg{width:27px;height:27px}

/* ---- Premium service-card interactions ---- */
.svc::before{content:"";position:absolute;top:0;left:30px;right:30px;height:3px;border-radius:0 0 4px 4px;
  background:linear-gradient(90deg,var(--pine-500),var(--amber-500));
  transform:scaleX(0);transform-origin:left center;transition:transform .55s var(--ease-out)}
.svc{transition:transform .5s var(--ease-out),box-shadow .5s var(--ease-out),border-color .4s var(--ease-out),background .4s}
.svc:hover{transform:translateY(-8px);box-shadow:var(--sh-lg);border-color:var(--sage-200)}
.svc:hover::before{transform:scaleX(1)}
.svc h3{transition:color .35s var(--ease-out)}
.svc:hover h3{color:var(--pine-700)}
.svc__icon{transition:background .45s var(--ease-out),color .45s var(--ease-out),
  transform .55s var(--ease-spring),box-shadow .45s var(--ease-out)}
.svc__icon svg{overflow:visible}
.svc__icon svg path,.svc__icon svg circle,.svc__icon svg rect{stroke-dasharray:150;stroke-dashoffset:0}
.svc:hover .svc__icon{background:var(--pine-700);color:var(--amber-400);
  transform:translateY(-3px) scale(1.09);box-shadow:0 14px 26px rgba(28,45,38,.24)}
.svc:hover .svc__icon svg path,.svc:hover .svc__icon svg circle,.svc:hover .svc__icon svg rect{
  animation:svcDraw .85s var(--ease-out) forwards}
@keyframes svcDraw{from{stroke-dashoffset:150}to{stroke-dashoffset:0}}
.svc h3{font-size:1.3rem;margin-bottom:9px}
.svc p{font-size:15px;color:var(--text-secondary)}

/* ---------- Video ---------- */
.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.vid{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/11;
  background:linear-gradient(150deg,var(--pine-700),var(--pine-900));box-shadow:var(--sh-md);
  display:flex;flex-direction:column;justify-content:flex-end;padding:22px;color:#fff;
  transition:transform var(--dur) var(--ease-out)}
.vid:hover{transform:translateY(-4px)}
.vid::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(230,163,74,.22),transparent 55%)}
.vid__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;
  background:rgba(255,255,255,.16);backdrop-filter:blur(6px);border:1.5px solid rgba(255,255,255,.5);display:grid;place-items:center;
  transition:transform var(--dur) var(--ease-spring),background var(--dur)}
.vid:hover .vid__play{transform:translate(-50%,-50%) scale(1.08);background:rgba(255,255,255,.26)}
.vid__play svg{width:24px;height:24px;color:#fff;margin-left:3px}
.vid__label{position:relative;font-weight:600;font-size:15.5px}
.vid__meta{position:relative;font-size:12.5px;color:var(--text-on-dark-soft);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}

/* ---------- Partners ---------- */
.partners{text-align:center}
.partners__row{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 14px;margin-top:8px}
.partner{display:inline-flex;align-items:center;gap:10px;background:var(--bg-surface);border:1px solid var(--line);
  border-radius:var(--r-full);padding:12px 22px;font-weight:600;color:var(--pine-700);font-size:15px}
.partner svg{width:18px;height:18px;color:var(--pine-500)}

/* ---------- News ---------- */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.news{background:var(--bg-surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  transition:transform var(--dur) var(--ease-out),box-shadow var(--dur)}
.news:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.news__body{padding:26px}
.news__cat{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-ink)}
.news h3{font-size:1.22rem;margin:10px 0 9px}
.news p{font-size:14.5px;color:var(--text-secondary)}
.news__top{height:8px;background:linear-gradient(90deg,var(--pine-600),var(--amber-500))}

/* ---------- CTA band ---------- */
.cta{background:var(--pine-800);color:var(--text-on-dark);border-radius:var(--r-xl);text-align:center;
  padding:clamp(48px,7vw,88px) 32px;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:-40% 60% 50% -10%;background:radial-gradient(circle,rgba(230,163,74,.14),transparent 65%)}
.cta h2{color:#fff;font-size:clamp(2rem,4vw,3rem);position:relative}
.cta p{color:var(--text-on-dark-soft);margin:18px auto 30px;max-width:54ch;position:relative}
.cta .btn-row{justify-content:center;position:relative}

/* ---------- Footer ---------- */
.footer{background:var(--pine-900);color:var(--text-on-dark-soft);margin-top:var(--s-24)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-block:64px 40px}
.footer .brand{color:#fff}
.footer .brand small{color:var(--text-on-dark-soft)}
.footer__about{margin-top:18px;font-size:14.5px;max-width:30ch;line-height:1.6}
.footer h4{font-family:"Plus Jakarta Sans";font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-400);margin-bottom:16px;font-weight:700}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.footer a{font-size:14.5px;transition:color var(--dur)}
.footer a:hover{color:#fff}
.footer__contact li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px}
.footer__contact svg{flex:none;width:17px;height:17px;color:var(--amber-400);margin-top:3px}
.footer__social{display:flex;gap:10px;margin-top:6px}
.footer__social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.16);border-radius:11px;display:grid;place-items:center}
.footer__social a:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.4)}
.footer__social svg{width:18px;height:18px}
.footer__bar{border-top:1px solid rgba(255,255,255,.1);padding-block:22px;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:10px;font-size:13px;color:rgba(185,200,191,.8)}
.footer__bar a{text-decoration:underline;text-underline-offset:3px}

/* ---------- Page hero (inner pages) ---------- */
.phero{padding-block:64px 28px}
.phero .eyebrow{margin-bottom:14px}
.phero h1{font-size:clamp(2.4rem,5vw,3.8rem)}
.phero p{margin-top:18px;font-size:1.12rem;color:var(--text-secondary);max-width:60ch}
.crumb{font-size:13.5px;color:var(--text-muted);margin-bottom:22px}
.crumb a:hover{color:var(--pine-700)}

/* ---------- Forms ---------- */
.form{background:var(--bg-surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:clamp(28px,4vw,44px);box-shadow:var(--sh-md)}
.field{margin-bottom:20px}
.field label{display:block;font-weight:600;font-size:14.5px;margin-bottom:8px;color:var(--pine-800)}
.field .req{color:var(--amber-600)}
.field input,.field textarea,.field select{
  width:100%;background:var(--cream);border:1.5px solid var(--line);border-radius:var(--r-md);
  padding:13px 15px;color:var(--ink);font-family:inherit;font-size:15.5px;transition:border-color var(--dur),box-shadow var(--dur)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--pine-500);
  box-shadow:0 0 0 4px rgba(58,113,92,.14)}
.field textarea{min-height:130px;resize:vertical}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form__note{font-size:13px;color:var(--text-muted);margin-top:6px}

/* ---------- Generic content / cards ---------- */
.prose{max-width:var(--w-content);font-size:1.05rem;color:var(--text-secondary)}
.prose h2{margin:40px 0 16px;font-size:1.9rem;color:var(--ink)}
.prose h3{margin:28px 0 12px;font-size:1.4rem;color:var(--ink)}
.prose p{margin-bottom:18px}
.prose ul{margin:0 0 18px;padding-left:22px;display:grid;gap:8px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--bg-surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px}
.card h3{font-size:1.25rem;margin-bottom:10px}
.card p{color:var(--text-secondary);font-size:15px}

/* ---- Unified premium hover across all cards & icons ---- */
.card,.news{position:relative;
  transition:transform .5s var(--ease-out),box-shadow .5s var(--ease-out),border-color .4s var(--ease-out),background .4s}
.card::before{content:"";position:absolute;top:0;left:28px;right:28px;height:3px;border-radius:0 0 4px 4px;
  background:linear-gradient(90deg,var(--pine-500),var(--amber-500));
  transform:scaleX(0);transform-origin:left center;transition:transform .55s var(--ease-out);z-index:2}
.card:hover,.news:hover{transform:translateY(-8px);box-shadow:var(--sh-lg);border-color:var(--sage-200)}
.card:hover::before{transform:scaleX(1)}
.card h3,.news h3{transition:color .35s var(--ease-out)}
.card:hover h3,.news:hover h3{color:var(--pine-700)}
/* extend the self-drawing icon effect to any card that contains an icon tile */
.card:hover .svc__icon{background:var(--pine-700);color:var(--amber-400);
  transform:translateY(-3px) scale(1.09);box-shadow:0 14px 26px rgba(28,45,38,.24)}
.card:hover .svc__icon svg path,.card:hover .svc__icon svg circle,.card:hover .svc__icon svg rect{
  animation:svcDraw .85s var(--ease-out) forwards}
/* premium micro-interaction on partner pills */
.partner{transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s,color .35s}
.partner:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:var(--sage-200);color:var(--pine-800)}
.partner:hover svg{color:var(--amber-500)}
.partner svg{transition:color .35s var(--ease-out)}
/* tier price cards: add the same gradient accent sweep */
.tier{position:relative;overflow:hidden}
.tier::before{content:"";position:absolute;top:0;left:34px;right:34px;height:3px;border-radius:0 0 4px 4px;
  background:linear-gradient(90deg,var(--pine-500),var(--amber-500));
  transform:scaleX(0);transform-origin:center;transition:transform .55s var(--ease-out)}
.tier:hover::before{transform:scaleX(1)}

/* Steps (referral journey) */
.steps{display:grid;gap:18px;counter-reset:step}
.step{display:grid;grid-template-columns:auto 1fr;gap:20px;background:var(--bg-surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:26px 30px}
.step__n{counter-increment:step;width:46px;height:46px;border-radius:50%;background:var(--pine-800);color:var(--amber-400);
  font-family:"Fraunces",serif;font-size:20px;font-weight:600;display:grid;place-items:center}
.step__n::before{content:counter(step)}
.step h3{font-size:1.2rem;margin-bottom:6px}
.step p{color:var(--text-secondary);font-size:15px}

/* Gallery */
.gallery{columns:3;column-gap:18px}
.gallery figure{margin:0 0 18px;break-inside:avoid;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);position:relative}
.gallery img{width:100%;transition:transform var(--dur-slow) var(--ease-out)}
.gallery figure:hover img{transform:scale(1.04)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;font-size:13.5px;
  background:linear-gradient(transparent,rgba(22,49,42,.82));opacity:0;transition:opacity var(--dur)}
.gallery figure:hover figcaption{opacity:1}

/* Donation tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tier{background:var(--bg-surface);border:1.5px solid var(--line);border-radius:var(--r-lg);padding:30px;text-align:center;
  transition:transform var(--dur) var(--ease-out),border-color var(--dur),box-shadow var(--dur)}
.tier:hover{transform:translateY(-4px);border-color:var(--amber-400);box-shadow:var(--sh-md)}
.tier--feat{border-color:var(--pine-600);background:var(--sage-100)}
.tier__amt{font-family:"Fraunces",serif;font-size:2.4rem;color:var(--pine-800);font-weight:600}
.tier p{color:var(--text-secondary);font-size:15px;margin:10px 0 20px}

.note{background:var(--amber-100);border:1px solid var(--amber-400);border-radius:var(--r-md);padding:16px 20px;font-size:14.5px;color:#6b4410}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}
.reveal.is-visible{opacity:1;transform:none}
[data-delay="1"]{transition-delay:.08s}[data-delay="2"]{transition-delay:.16s}
[data-delay="3"]{transition-delay:.24s}[data-delay="4"]{transition-delay:.32s}[data-delay="5"]{transition-delay:.4s}

/* ---------- Responsive ---------- */
@media (max-width:1000px){
  .hero__grid{grid-template-columns:1fr;gap:36px;padding-block:40px 56px}
  .hero__media{max-width:480px;margin-inline:auto}
  .hero__copy{max-width:none}
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px}
  .gallery{columns:2}
}
@media (max-width:860px){
  .nav__links,.nav__cta .btn{display:none}
  .nav__toggle{display:flex}
  .nav__drawer{position:fixed;inset:78px 0 auto 0;background:var(--cream-card);border-bottom:1px solid var(--line);
    box-shadow:var(--sh-lg);padding:18px 24px 26px;display:none;z-index:55}
  .nav__drawer.open{display:block;animation:slidedown var(--dur) var(--ease-out)}
  .nav__drawer ul{list-style:none;margin:0;padding:0;display:grid;gap:4px}
  .nav__drawer a{display:block;padding:14px 12px;border-radius:12px;font-weight:500;font-size:16px;color:var(--pine-800)}
  .nav__drawer a:hover{background:var(--sage-100)}
  .nav__drawer .btn{margin-top:12px;width:100%}
  .stats__grid{grid-template-columns:1fr 1fr;gap:28px 20px}
  .stat{border-left:0;padding-left:0}
  .stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.12)}
  .story,.story--flip .story__media{grid-template-columns:1fr;order:0}
  .story__media{max-width:480px;margin-inline:auto}
  .svc-grid,.vid-grid,.news-grid,.grid-3,.tiers{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  body{font-size:16px}
  .section{padding-block:var(--s-16)}
  .svc-grid,.vid-grid,.news-grid,.grid-2,.grid-3,.tiers,.form__row{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:1fr 1fr}
  .gallery{columns:1}
  .footer__grid{grid-template-columns:1fr}
  .hero__chip{left:8px}
}
@keyframes slidedown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   PREMIUM PASS — Apple-grade typography, rhythm, depth, motion
   (appended last so it refines the system cohesively)
   ============================================================ */
:root{
  --cream-card:#fffdfa;              /* crisper surface for depth on cream */
  --line:#e7e0d0;                    /* refined hairline */
  --sh-sm:0 1px 2px rgba(28,45,38,.05);
  --sh-md:0 18px 40px -18px rgba(28,45,38,.16), 0 4px 12px -8px rgba(28,45,38,.07);
  --sh-lg:0 52px 92px -30px rgba(28,45,38,.22), 0 16px 38px -18px rgba(28,45,38,.12);
  --ease-out:cubic-bezier(.22,1,.36,1);
}
/* Global polish */
html{scroll-padding-top:96px}
::selection{background:var(--pine-800);color:#fbf6ea}
body{letter-spacing:-.004em}
h1,h2,h3,.display,.h2,.shero__title h1,.story h3,.cta h2,.band h2{text-wrap:balance}
p,li,.lead,.hero__sub,.shero__sub{text-wrap:pretty}

/* Type — larger, tighter, more confident */
.shero__title h1{font-size:clamp(2.9rem,6.1vw,5.5rem);letter-spacing:-.037em;line-height:1.01}
.h2{font-size:clamp(2.15rem,3.8vw,3.35rem);letter-spacing:-.028em;line-height:1.04}
.display{font-size:clamp(2.8rem,6vw,4.7rem);letter-spacing:-.03em}
.lead{font-size:clamp(1.08rem,1.6vw,1.3rem);line-height:1.62}
.shead p{font-size:1.13rem;line-height:1.6}
.story h3{font-size:clamp(1.8rem,3.1vw,2.55rem);letter-spacing:-.022em}
.cta h2{font-size:clamp(2.2rem,4.2vw,3.4rem);letter-spacing:-.025em}
.eyebrow{letter-spacing:.2em;font-size:12px}
.phero h1{font-size:clamp(2.5rem,5.2vw,4rem);letter-spacing:-.03em}

/* Rhythm — generous, consistent whitespace */
.section{padding-block:120px}
.section--tight{padding-block:82px}
.shead{margin-bottom:62px}
.story + .story{margin-top:120px}

/* Buttons — refined presence */
.btn{letter-spacing:-.01em}
.btn--lg{padding:17px 34px;font-size:16px}
.btn--primary{box-shadow:0 8px 20px -8px rgba(217,131,36,.5)}
.btn--primary:hover{box-shadow:0 14px 30px -10px rgba(217,131,36,.55);transform:translateY(-2px) scale(1.015)}

/* Header — condense on scroll, refined translucency */
.site-header[data-scrolled="true"]{background:rgba(246,242,232,.72);backdrop-filter:saturate(1.6) blur(20px);-webkit-backdrop-filter:saturate(1.6) blur(20px)}
.nav{transition:height .38s var(--ease-out)}
.brand__mark{transition:transform .38s var(--ease-out)}
.site-header.is-condensed .nav{height:62px}
.site-header.is-condensed .brand__mark{transform:scale(.88)}

/* Motion — refined reveal easing & travel */
.reveal{opacity:0;transform:translateY(30px);
  transition:opacity .85s var(--ease-out),transform .85s var(--ease-out)}
.reveal.is-visible{opacity:1;transform:none}
[data-delay="1"]{transition-delay:.09s}[data-delay="2"]{transition-delay:.18s}
[data-delay="3"]{transition-delay:.27s}[data-delay="4"]{transition-delay:.36s}[data-delay="5"]{transition-delay:.45s}

/* Full-bleed band parallax (extra height for drift room) */
.band img{top:-14%;left:0;right:auto;bottom:auto;width:100%;height:128%;will-change:transform}

/* Hero scroll cue */
.shero__cue{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);display:flex;flex-direction:column;
  align-items:center;gap:9px;color:var(--muted);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;pointer-events:none}
.shero__cue i{width:22px;height:34px;border:1.5px solid var(--muted);border-radius:12px;position:relative;display:block}
.shero__cue i::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:6px;border-radius:3px;background:var(--muted);
  transform:translateX(-50%);animation:cue 1.7s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.25;transform:translate(-50%,0)}50%{opacity:1;transform:translate(-50%,8px)}}

/* Mobile rhythm */
@media(max-width:768px){
  .section{padding-block:82px}.section--tight{padding-block:58px}.shead{margin-bottom:44px}
  .story + .story{margin-top:78px}.shero__cue{display:none}
}
/* Respect reduced motion */
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  .shero__cue i::after{animation:none}
  .band img{transform:none!important}
}

/* ============================================================
   HOMEPAGE full-bleed hero + overlay header (scoped to .home)
   ============================================================ */
.home .site-header{position:fixed;top:0;left:0;right:0;background:transparent;
  border-bottom-color:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}
.home .site-header .brand{color:#fff}
.home .site-header .brand small{color:rgba(255,255,255,.82)}
.home .site-header .nav__links a{color:rgba(255,255,255,.9)}
.home .site-header .nav__links a:hover{color:#fff;background:rgba(255,255,255,.14)}
.home .site-header .nav__links a[aria-current="page"]{color:#fff}
.home .site-header .nav__toggle{border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.12)}
.home .site-header .nav__toggle span,
.home .site-header .nav__toggle span::before,
.home .site-header .nav__toggle span::after{background:#fff}
/* solid cream header once scrolled */
.home .site-header[data-scrolled="true"]{background:rgba(246,242,232,.85);
  -webkit-backdrop-filter:saturate(1.6) blur(20px);backdrop-filter:saturate(1.6) blur(20px);
  border-bottom-color:var(--line)}
.home .site-header[data-scrolled="true"] .brand{color:var(--pine-800)}
.home .site-header[data-scrolled="true"] .brand small{color:var(--text-muted)}
.home .site-header[data-scrolled="true"] .nav__links a{color:var(--text-secondary)}
.home .site-header[data-scrolled="true"] .nav__links a:hover{color:var(--pine-800);background:rgba(44,90,73,.07)}
.home .site-header[data-scrolled="true"] .nav__links a[aria-current="page"]{color:var(--pine-800)}
.home .site-header[data-scrolled="true"] .nav__toggle{border-color:var(--line);background:var(--cream-card)}
.home .site-header[data-scrolled="true"] .nav__toggle span,
.home .site-header[data-scrolled="true"] .nav__toggle span::before,
.home .site-header[data-scrolled="true"] .nav__toggle span::after{background:var(--pine-800)}

.hero-full{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-full__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.hero-full__veil{position:absolute;inset:0;
  background:linear-gradient(95deg,rgba(15,35,28,.94) 0%,rgba(15,35,28,.80) 34%,rgba(15,35,28,.55) 64%,rgba(15,35,28,.40) 100%),
             linear-gradient(to top,rgba(15,35,28,.74) 0%,rgba(15,35,28,.34) 50%,rgba(15,35,28,.20) 100%)}
.hero-full__inner{position:relative;z-index:2;width:100%;padding-top:120px;padding-bottom:84px;color:#fff}
.hero-full .eyebrow{color:var(--amber-400)}
.hero-full h1{font-size:clamp(2.9rem,7vw,5.7rem);line-height:1.0;letter-spacing:-.035em;color:#fff;font-weight:480}
.hero-full h1 em{font-style:italic;color:var(--amber-400);font-weight:420}
.hero-full__sub{margin-top:24px;max-width:60ch;font-size:clamp(1.05rem,1.6vw,1.26rem);line-height:1.6;color:rgba(255,255,255,.92)}
.hero-full__cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
@media (max-width:768px){
  .hero-full{min-height:90vh}
  .hero-full__inner{padding-top:104px;padding-bottom:56px}
}

/* hero trust line + checkmark indicators */
.hero-full__trustline{display:inline-flex;align-items:center;gap:8px;margin-top:26px;
  font-size:14px;color:rgba(255,255,255,.84);font-weight:500}
.hero-full__trustline svg{width:17px;height:17px;color:var(--amber-400);flex:none}
.hero-full__checks{list-style:none;margin:20px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:12px 28px}
.hero-full__checks li{display:inline-flex;align-items:center;gap:9px;font-size:14.5px;
  color:rgba(255,255,255,.93);font-weight:500}
.hero-full__checks svg{width:19px;height:19px;color:var(--amber-400);flex:none}
@media (max-width:768px){.hero-full__checks{gap:10px 18px}.hero-full__checks li{font-size:13.5px}}

/* "Who we support" badge strip (under hero, cream theme) */
.audience{padding:56px 0;border-bottom:1px solid var(--line)}
.audience__lead{text-align:center;font-family:'Fraunces',Georgia,serif;font-style:italic;
  font-size:clamp(1.1rem,1.7vw,1.4rem);color:var(--pine-700);margin:0 0 24px}
.audience__row{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.audience__pill{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border-radius:999px;
  border:1px solid var(--line);background:var(--cream-card);color:var(--pine-800);font-weight:600;font-size:14px;
  box-shadow:var(--sh-sm);transition:transform .25s var(--ease-out),box-shadow .25s,border-color .25s}
.audience__pill:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:rgba(217,131,36,.45)}
.audience__pill svg{width:20px;height:20px;color:var(--pine-600);flex:none}
@media (max-width:768px){.audience{padding:42px 0}.audience__pill{font-size:13px;padding:10px 15px;gap:8px}.audience__pill svg{width:18px;height:18px}}
