:root{
  --paper:#faf9f5; --paper-2:#f1eee4; --ink:#16140f; --black:#100f0c;
  --gold:#edc553; --gold-ink:#8a6c11; --tan:#8c8270;
  --line:#e4dfd1; --muted:#56514593; --muted-s:#5b5648;
  --maxw:1320px;
  --display:"Cinzel",Georgia,serif; --body:"Josefin Sans",-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.7;font-weight:400;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.eyebrow{font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;font-weight:600;color:var(--gold-ink)}
.gold{color:var(--gold-ink)}
.center{text-align:center;margin-left:auto;margin-right:auto}
em{font-style:italic}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;padding:18px 34px;border-radius:0;transition:.3s cubic-bezier(.2,.8,.2,1);cursor:pointer;border:1px solid transparent}
.btn-gold{background:var(--ink);color:var(--paper)}
.btn-gold:hover{background:var(--gold);color:var(--ink)}
.btn-line{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-line:hover{background:var(--ink);color:var(--paper)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* NAV, light, sticky, hairline */
header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.4s;background:rgba(250,249,245,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:16px 0}
header.top{background:rgba(250,249,245,.6);border-color:transparent;padding:24px 0}
.nav{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:14px;color:var(--ink)}
.brand img{width:48px;height:48px;object-fit:contain}
.brand .logo-mark{width:42px;height:42px;flex:none}
.foot .brand .logo-mark{width:40px;height:40px}
.brand b{font-family:var(--display);font-size:1.15rem;font-weight:700;letter-spacing:.04em;display:block;line-height:1}
.brand small{display:block;font-family:var(--body);font-size:.56rem;letter-spacing:.42em;text-transform:uppercase;color:var(--tan);font-weight:600;margin-top:4px}
.navlinks{display:flex;gap:34px;align-items:center}
.navlinks>a:not(.btn),.has-drop>a{color:var(--ink);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;position:relative;padding:6px 0;cursor:pointer}
.navlinks>a:not(.btn)::after,.has-drop>a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold-ink);transition:.3s}
.navlinks>a:not(.btn):hover::after,.has-drop:hover>a::after{width:100%}
.navlinks .btn{padding:13px 24px}
.has-drop{position:relative}
.drop{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(12px);background:var(--paper);border:1px solid var(--line);box-shadow:0 20px 50px -30px rgba(0,0,0,.4);padding:10px;min-width:248px;opacity:0;visibility:hidden;transition:.25s;display:flex;flex-direction:column;gap:1px}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(8px)}
.drop a{color:var(--ink);font-size:.82rem;font-family:var(--body);letter-spacing:.02em;text-transform:none;font-weight:400;padding:10px 14px;transition:.2s}
.drop a:hover{background:var(--paper-2);color:var(--gold-ink)}
.burger{display:none;flex-direction:column;gap:6px;cursor:pointer;z-index:60}
.burger span{width:28px;height:1.5px;background:var(--ink);transition:.3s}

/* HOME HERO, exaggerated minimalism */
.hero{padding:170px 0 0}
.hero-inner{display:flex;flex-direction:column}
.hero .eyebrow{margin-bottom:24px}
.hero h1{font-size:clamp(2.4rem,6vw,4.8rem);font-weight:800;line-height:1;letter-spacing:-.02em;text-transform:none}
.hero h1 em{color:var(--gold-ink);font-style:italic}
.hero-meta{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end;margin:48px 0 60px;padding-top:36px;border-top:1px solid var(--line)}
.hero-meta .lead{font-size:1.1rem;max-width:46ch;color:var(--muted-s);font-weight:300}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-shot{position:relative;width:100%;aspect-ratio:21/9;overflow:hidden}
.hero-shot img{width:100%;height:100%;object-fit:cover}
.hero-shot figcaption{position:absolute;left:40px;bottom:30px;color:#fff;font-family:var(--display);font-style:italic;font-size:clamp(1rem,2vw,1.5rem);text-shadow:0 2px 20px rgba(0,0,0,.5)}

/* reveal */
.reveal{opacity:0;transform:translateY(30px);transition:.9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}
@media(prefers-reduced-motion:reduce){.reveal{transition:none;opacity:1;transform:none}*{animation:none!important}}

/* inner page hero */
.phero{position:relative;padding:190px 0 90px;background:var(--paper);overflow:hidden;border-bottom:1px solid var(--line)}
.phero::before{content:attr(data-ghost);position:absolute;right:-1%;top:46%;transform:translateY(-50%);font-family:var(--display);font-weight:900;font-size:30vw;color:rgba(237,197,83,.12);line-height:1;pointer-events:none;white-space:nowrap}
.phero .wrap{position:relative;z-index:2}
.crumb{font-size:.74rem;letter-spacing:.1em;color:var(--tan);margin-bottom:22px;text-transform:uppercase}
.crumb a:hover{color:var(--gold-ink)}
.phero .eyebrow{display:block;margin-bottom:16px}
.phero h1{font-size:clamp(2.2rem,5vw,4.2rem);font-weight:800;letter-spacing:-.02em;max-width:18ch;line-height:1}
.phero h1 em{color:var(--gold-ink);font-style:italic}
.phero p.sub{font-size:1.15rem;color:var(--muted-s);max-width:56ch;margin-top:22px;font-weight:300}
.phero .pcta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap}

/* strip */
.strip{background:var(--ink);color:var(--paper);padding:18px 0;overflow:hidden;white-space:nowrap}
.strip-track{display:inline-flex;gap:44px;animation:scroll 34s linear infinite}
.strip-track span{color:var(--tan)}.strip-track b{color:var(--gold);font-family:var(--body);font-weight:600;font-size:.76rem;letter-spacing:.24em;text-transform:uppercase}
@keyframes scroll{to{transform:translateX(-50%)}}

/* sections */
section{padding:130px 0}
.sec-head{max-width:760px;margin-bottom:70px}
.sec-head h2{font-size:clamp(2.2rem,5vw,4rem);font-weight:700;letter-spacing:-.02em;margin:16px 0;line-height:1}
.sec-head p{font-size:1.1rem;color:var(--muted-s);font-weight:300}

/* problem */
.problem{background:var(--paper)}
.problem .grid{display:grid;grid-template-columns:1.3fr 1fr;gap:90px;align-items:center}
.problem blockquote{font-family:var(--display);font-size:clamp(1.9rem,3.6vw,3.4rem);line-height:1.08;font-weight:600;letter-spacing:-.02em}
.problem blockquote em{font-style:italic;color:var(--gold-ink)}
.problem .body p{margin-bottom:18px;color:var(--muted-s);font-weight:300;font-size:1.05rem}

/* 3-step process, oversized numerals */
.process{background:var(--paper-2)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--ink)}
.step{padding:50px 40px 46px;border-right:1px solid var(--line);position:relative;transition:.4s}
.step:last-child{border-right:none}
.step:hover{background:var(--paper)}
.step .n{font-family:var(--display);font-size:7rem;font-weight:900;color:var(--gold-ink);line-height:.8;letter-spacing:-.04em}
.step h3{font-size:1.5rem;font-weight:700;margin:20px 0 12px}
.step p{font-size:.98rem;color:var(--muted-s);font-weight:300}
.step .tag{position:absolute;top:54px;right:36px;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--tan);font-weight:600}

/* services / cards, minimal hairline grid */
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.card{background:transparent;padding:46px 34px 40px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);transition:.35s;display:flex;flex-direction:column}
.card:nth-child(3n){border-right:none}
.card:hover{background:var(--paper-2)}
.card .ic{font-family:var(--display);font-size:1.4rem;color:var(--gold-ink);margin-bottom:22px;font-weight:600}
.card h3{font-size:1.45rem;font-weight:700;margin-bottom:12px;letter-spacing:-.01em}
.card p{font-size:.96rem;color:var(--muted-s);flex:1;font-weight:300}
.card .more{margin-top:20px;font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-ink);transition:.3s}
.card:hover .more{color:var(--ink);letter-spacing:.24em}
.cgrid.four{grid-template-columns:repeat(4,1fr)}
.cgrid.four .card:nth-child(3n){border-right:1px solid var(--line)}
.cgrid.four .card:nth-child(4n){border-right:none}

/* prose (guides) */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-family:var(--display);font-size:1.9rem;font-weight:700;margin:48px 0 16px;letter-spacing:-.01em}
.prose h3{font-family:var(--display);font-size:1.3rem;margin:30px 0 10px}
.prose p{margin-bottom:18px;color:#34302a;font-size:1.1rem;font-weight:300}
.prose ul,.prose ol{margin:0 0 20px 22px;color:#34302a;font-weight:300}
.prose li{margin-bottom:10px}
.prose .lead{font-family:var(--display);font-size:1.4rem;color:var(--ink);font-weight:600;font-style:italic;line-height:1.3;border:none;padding:0;margin:34px 0}
.prose a{color:var(--gold-ink);text-decoration:underline;text-underline-offset:3px}
.prose a:hover{color:var(--ink)}
.tldr{border-top:2px solid var(--ink);border-bottom:1px solid var(--line);padding:26px 0 28px;margin-bottom:40px}
.tldr h4{font-family:var(--body);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-ink);margin-bottom:12px;font-weight:600}
.tldr p{font-family:var(--display);font-size:1.25rem;color:var(--ink);margin:0;font-weight:500;line-height:1.4}

/* split (location/service) */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center}
.split img{width:100%;filter:grayscale(.1) contrast(1.03)}
.split h2{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:22px;letter-spacing:-.02em;line-height:1.02}
.split p{color:var(--muted-s);margin-bottom:16px;font-weight:300;font-size:1.05rem}
.checklist{list-style:none;margin:26px 0}
.checklist li{padding:14px 0 14px 30px;position:relative;border-top:1px solid var(--line);color:#34302a;font-weight:300}
.checklist li::before{content:"✦";position:absolute;left:0;color:var(--gold-ink);font-weight:600;font-size:.85rem;top:15px}

/* stats, gold band */
.stats{background:var(--gold);color:var(--ink);padding:80px 0}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stats .n{font-family:var(--display);font-size:2.9rem;font-weight:800;line-height:1;letter-spacing:-.02em}
.stats .l{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;margin-top:10px;color:#5c4a0f}

/* vision, single dark drama band */
.vision{background:var(--black);color:var(--paper);position:relative;overflow:hidden}
.vision::before{content:"369";position:absolute;right:-3%;top:50%;transform:translateY(-50%);font-family:var(--display);font-size:34vw;font-weight:900;color:rgba(237,197,83,.05);pointer-events:none;line-height:1}
.vision .grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;position:relative;z-index:2}
.vision .eyebrow{color:var(--gold)}
.vision h2{font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:700;color:#fff;margin-bottom:24px;letter-spacing:-.02em;line-height:1}
.vision h2 em{font-style:italic;color:var(--gold)}
.vision p{color:#d7d2c4;margin-bottom:16px;font-weight:300}
.pillars{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.pillars span{border:1px solid rgba(237,197,83,.45);color:var(--gold);padding:9px 16px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.vision img{width:100%;filter:grayscale(.15) contrast(1.05)}

/* sister (climate hope) */
.sister{background:var(--ink);color:var(--paper);padding:54px;display:grid;grid-template-columns:auto 1fr auto;gap:38px;align-items:center;border-left:4px solid #9fe6b0}
.sister .badge{width:150px;display:grid;place-items:center}
.sister .badge img{width:100%;height:auto}
.sister h3{font-family:var(--display);font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:10px;letter-spacing:-.01em}
.sister p{color:#cfcabd;font-size:.98rem;font-weight:300}
.sister .btn{background:#9fe6b0;color:#10261a;border-color:#9fe6b0;white-space:nowrap}
.sister .btn:hover{background:#fff;border-color:#fff}

/* CTA band, light statement */
.ctaband{background:var(--paper-2);text-align:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ctaband h2{font-size:clamp(2.4rem,6vw,5rem);font-weight:800;margin-bottom:20px;letter-spacing:-.025em;line-height:.98}
.ctaband h2 em{color:var(--gold-ink);font-style:italic}
.ctaband p{color:var(--muted-s);max-width:52ch;margin:0 auto 32px;font-weight:300;font-size:1.08rem}

/* contact */
.contact{background:var(--paper)}
.contact .grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px}
.contact h2{font-size:clamp(2.2rem,4.5vw,3.4rem);font-weight:700;margin:16px 0 20px;letter-spacing:-.02em;line-height:1}
.contact .lead{font-size:1.05rem;color:var(--muted-s);margin-bottom:30px;font-weight:300}
.ctline{display:flex;align-items:center;gap:16px;padding:17px 0;border-top:1px solid var(--line);font-size:1.04rem}
.ctline b{font-family:var(--display);font-size:1.2rem;font-weight:600}
.ctline .k{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--tan);font-weight:600;width:62px}
form{background:transparent;padding:0}
.field{margin-bottom:26px}
label{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--gold-ink);margin-bottom:10px}
input,select,textarea{width:100%;padding:12px 0;border:none;border-bottom:1px solid var(--ink);border-radius:0;font-family:var(--body);font-size:1.05rem;background:transparent;transition:.25s;color:var(--ink)}
input::placeholder{color:#a8a293}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold-ink)}
form .btn-gold{width:100%;justify-content:center;margin-top:10px}
.formnote{font-size:.78rem;color:var(--tan);margin-top:16px;text-align:center;letter-spacing:.05em}

/* faq */
.faq{max-width:840px;margin:0 auto}
.faq details{border-top:1px solid var(--line);padding:20px 0}
.faq summary{font-family:var(--display);font-size:1.2rem;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-ink);font-size:1.4rem;transition:.3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin-top:12px;color:var(--muted-s);font-weight:300}

/* related links */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:34px;border-top:1px solid var(--line)}
.related a{padding:26px 24px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);transition:.3s}
.related a:nth-child(3n){border-right:none}
.related a:hover{background:var(--paper-2)}
.related a b{font-family:var(--display);font-size:1.1rem;font-weight:600;display:block;margin-bottom:6px}
.related a span{font-size:.86rem;color:var(--muted-s);font-weight:300}

/* proudly supporting */
.supporters{background:var(--paper-2)}
.supporters .sgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.supporters .sup{display:flex;flex-direction:column;padding:40px 30px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:.3s;cursor:pointer}
.supporters .sup:nth-child(3n){border-right:none}
.supporters .sup:hover{background:var(--paper)}
.supporters .sup:hover h3{color:var(--gold-ink)}
.supporters .sup .cat{font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-ink);font-weight:600;margin-bottom:14px}
.supporters .sup h3{font-family:var(--display);font-size:1.3rem;font-weight:700;margin-bottom:8px;letter-spacing:-.01em;transition:.3s}
.supporters .sup p{font-size:.94rem;color:var(--muted-s);font-weight:300;flex:1}
.supporters .sup .visit{margin-top:18px;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-ink);font-weight:600;transition:.3s}
.supporters .sup:hover .visit{letter-spacing:.24em}

/* footer, dark */
footer{background:var(--black);color:#928d80;padding:80px 0 32px}
.foot{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot .brand{margin-bottom:18px;color:#fff;align-items:flex-start}
.foot .brand b{color:#fff}
.foot p{font-size:.92rem;font-weight:300;max-width:32ch}
.foot h4{color:#fff;font-family:var(--body);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:16px;font-weight:600}
.foot a{display:block;font-size:.92rem;padding:6px 0;transition:.2s;font-weight:300}
.foot a:hover{color:var(--gold)}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;color:#cfcabd;transition:.3s;font-size:.85rem}
.socials a:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.copy{padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.8rem;font-weight:300}

@media(max-width:920px){
  .wrap{padding:0 22px}
  .navlinks{position:fixed;top:0;left:0;right:0;bottom:0;height:100vh;height:100dvh;background:var(--paper);flex-direction:column;justify-content:flex-start;align-items:flex-start;padding:96px 28px 44px;transform:translateX(100%);transition:.4s;gap:2px;overflow-y:auto}
  .navlinks.open{transform:none}.burger{display:flex}
  .navlinks>a,.has-drop{width:100%}
  .navlinks>a,.has-drop>a{font-size:1rem;padding:14px 0;border-bottom:1px solid var(--line)}
  .navlinks .btn{margin-top:18px;justify-content:center;width:100%;border-bottom:none}
  .has-drop>a{color:var(--gold-ink)!important}
  .has-drop .drop{position:static;transform:none;opacity:1;visibility:visible;background:transparent;border:none;box-shadow:none;padding:2px 0 10px 16px;min-width:0;gap:0}
  .has-drop .drop a{font-size:.9rem;padding:9px 0}
  section{padding:80px 0}
  .hero{padding:140px 0 0}
  .hero-meta{grid-template-columns:1fr;gap:28px}
  .hero-shot{aspect-ratio:4/3}
  .hero-shot figcaption{left:22px;font-size:1rem}
  .problem .grid,.vision .grid,.contact .grid,.split{grid-template-columns:1fr;gap:40px}
  .steps,.cgrid,.related,.cgrid.four{grid-template-columns:1fr}
  .step,.card,.related a,.cgrid.four .card{border-right:none}
  .supporters .sup{border-right:none}
  .stats .grid{grid-template-columns:1fr 1fr;gap:34px}
  .foot{grid-template-columns:1fr 1fr}
  .sister{grid-template-columns:1fr;text-align:center;gap:22px}.sister .badge{margin:0 auto}.sister{border-left:none;border-top:4px solid #9fe6b0}
  .vision::before,.phero::before{font-size:62vw}
}
