/* ============================================================
   MOMDAD Foundation — Site stylesheet
   Tokens · base · chrome · components · page styles
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --teal:#137A86; --teal-deep:#0C4A52; --teal-tint:#E4EFF0;
  --amber:#F0A33C; --amber-deep:#C9781F;
  --paper:#FAF7F2; --surface:#FFFFFF; --ink:#1C1A17; --stone:#6E6A62; --line:#E7E1D7;
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --maxw:1180px; --r:16px;
  --shadow-sm:0 2px 8px -4px rgba(28,26,23,.18);
  --shadow-md:0 22px 40px -28px rgba(28,26,23,.35);
  --shadow-lg:0 40px 80px -40px color-mix(in srgb,var(--teal-deep) 80%,transparent);
}
html[data-palette="teal-coral"]{--teal:#157D78;--teal-deep:#0B463F;--teal-tint:#E6F0EE;--amber:#FB7A6B;--amber-deep:#D24B38;}
html[data-palette="ocean-amber"]{--teal:#1E5FA8;--teal-deep:#123E73;--teal-tint:#E7EEF8;--amber:#F0A33C;--amber-deep:#C9781F;}
html[data-fonts="clean"]{--display:"Schibsted Grotesk",system-ui,sans-serif;}
html[data-fonts="serif"]{--display:"Lora",Georgia,serif;}

/* ---------- BASE ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-.02em;line-height:1.05;margin:0}
p{margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;font-family:var(--body);font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal)}
.eyebrow.wrap-ok{white-space:normal}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--amber);flex:none}
.center{margin-left:auto;margin-right:auto;text-align:center}
.muted{color:var(--stone)}
.ph{font-style:normal;color:var(--stone);opacity:.85}

/* ---------- LOGO SLOTS ---------- */
.logo-slot{display:inline-block;line-height:0}
.logo-slot svg{width:100%;height:100%;display:block}
.tone-color .lp-f{fill:var(--teal)} .tone-color .la-f{fill:var(--amber)}
.tone-color .lp-s{stroke:var(--teal)} .tone-color .la-s{stroke:var(--teal)}
.tone-rev .lp-f,.tone-rev .la-f{fill:#fff}
.tone-rev .lp-s,.tone-rev .la-s{stroke:#fff}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--body);font-weight:700;font-size:15px;border:none;border-radius:999px;padding:14px 26px;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,border-color .2s,color .2s;text-align:center}
.btn:active{transform:translateY(1px)}
.btn-amber{background:var(--amber);color:#3a2708;box-shadow:0 8px 20px -8px color-mix(in srgb,var(--amber) 70%,transparent)}
.btn-amber:hover{box-shadow:0 12px 26px -8px color-mix(in srgb,var(--amber) 80%,transparent)}
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{background:var(--teal-deep)}
.btn-ghost{background:transparent;color:var(--teal-deep);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-white{background:#fff;color:var(--teal-deep)}
.btn-white:hover{background:#fff;box-shadow:var(--shadow-sm)}
.btn-sm{padding:10px 18px;font-size:14px}
.btn svg{width:18px;height:18px}
.btn-block{width:100%}

/* ---------- HEADER ---------- */
header.site{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo-slot{width:40px;height:40px}
.brand .wm{font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:.005em;white-space:nowrap}
.brand .wm .sub{color:var(--teal)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-weight:500;font-size:15px;color:var(--stone);position:relative;padding:4px 0}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;border-radius:2px;background:var(--amber)}
.nav-actions{display:flex;align-items:center;gap:14px}
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--ink);padding:6px}
.menu-btn svg{width:26px;height:26px}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:70;display:none}
.drawer.open{display:block}
.drawer .scrim{position:absolute;inset:0;background:rgba(28,26,23,.42);backdrop-filter:blur(2px)}
.drawer .sheet{position:absolute;top:0;right:0;height:100%;width:min(82vw,340px);background:var(--surface);box-shadow:-20px 0 60px -30px rgba(0,0,0,.4);padding:24px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1)}
.drawer.open .sheet{transform:translateX(0)}
.drawer .sheet .x{align-self:flex-end;background:none;border:none;cursor:pointer;color:var(--ink);padding:6px;margin-bottom:8px}
.drawer .sheet a{font-family:var(--display);font-weight:600;font-size:20px;padding:12px 6px;border-bottom:1px solid var(--line);color:var(--ink)}
.drawer .sheet a.active{color:var(--teal)}
.drawer .sheet .btn{margin-top:18px}

/* ---------- PAGE BANNER (interior pages) ---------- */
.page-banner{background:radial-gradient(120% 120% at 85% 0%,var(--teal-tint),var(--paper) 62%);border-bottom:1px solid var(--line)}
.page-banner .wrap{padding:54px 28px 58px}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--stone);margin-bottom:18px}
.crumbs a:hover{color:var(--teal)}
.crumbs svg{width:14px;height:14px;opacity:.6}
.page-banner h1{font-size:clamp(34px,4.6vw,54px);text-wrap:balance;margin-top:14px}
.page-banner p{color:var(--stone);font-size:18px;margin-top:16px;max-width:56ch}

/* ---------- SECTION SCAFFOLD ---------- */
section{padding:88px 0}
.sec-head{max-width:640px}
.sec-head h2{font-size:clamp(30px,3.4vw,42px);margin-top:14px;text-wrap:balance}
.sec-head p{color:var(--stone);font-size:17px;margin-top:16px}
.surface{background:var(--surface)}

/* ---------- HERO (home) ---------- */
.hero{position:relative;overflow:hidden;background:radial-gradient(120% 90% at 85% 0%,var(--teal-tint),var(--paper) 60%);padding:0}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding-top:74px;padding-bottom:84px}
.hero h1{font-size:clamp(40px,5.2vw,66px);text-wrap:balance;margin:22px 0 0}
.hero h1 .hl{color:var(--teal)}
.hero .lead{font-size:clamp(17px,1.5vw,20px);color:var(--stone);max-width:46ch;margin-top:22px}
.hero .cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.hero .trust{display:flex;align-items:center;gap:10px;margin-top:26px;color:var(--stone);font-size:14px}
.hero .trust svg{width:18px;height:18px;color:var(--teal);flex:none}
.emblem{position:relative;aspect-ratio:1/1;border-radius:28px;background:linear-gradient(160deg,var(--teal),var(--teal-deep));display:grid;place-items:center;overflow:hidden;box-shadow:var(--shadow-lg)}
.emblem .ring{position:absolute;border:1.5px solid rgba(255,255,255,.13);border-radius:50%}
.emblem .ring.r1{inset:8%} .emblem .ring.r2{inset:20%} .emblem .ring.r3{inset:32%}
.emblem .core{position:relative;text-align:center;color:#fff;padding:0 24px}
.emblem .core .logo-slot{width:128px;height:128px;margin:0 auto}
.emblem .core .name{font-family:var(--display);font-weight:700;font-size:30px;margin-top:18px}
.emblem .core .name .sub{color:var(--amber)}
.emblem .core .tag{font-size:12.5px;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-top:8px}

/* ---------- VALUES ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.lede{font-family:var(--display);font-weight:600;font-size:clamp(22px,2.6vw,30px);line-height:1.3;letter-spacing:-.01em;text-wrap:balance}
.values{display:grid;gap:20px}
.value{display:flex;gap:16px;padding:22px;border:1px solid var(--line);border-radius:var(--r);background:var(--paper)}
.value .ic{flex:none;width:46px;height:46px;border-radius:12px;background:var(--teal-tint);color:var(--teal);display:grid;place-items:center}
.value .ic svg{width:23px;height:23px}
.value h3{font-size:18px}
.value p{color:var(--stone);font-size:14.5px;margin-top:5px}

/* ---------- WORK / PROGRAM GRID ---------- */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:52px}
.work{display:block;padding:26px 24px 28px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);transition:transform .18s ease,box-shadow .25s ease,border-color .2s ease;color:inherit}
.work:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--teal) 35%,var(--line))}
.work .ic{width:50px;height:50px;border-radius:14px;background:var(--teal-tint);color:var(--teal);display:grid;place-items:center;margin-bottom:18px}
.work .ic svg{width:25px;height:25px}
.work:nth-child(3n+2) .ic{background:color-mix(in srgb,var(--amber) 18%,#fff);color:var(--amber-deep)}
.work h3{font-size:18px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.work h3 .arr{opacity:0;transform:translateX(-4px);transition:.2s;color:var(--teal)}
.work:hover h3 .arr{opacity:1;transform:translateX(0)}
.work h3 .arr svg{width:18px;height:18px}
.work p{color:var(--stone);font-size:14px;margin-top:7px}

/* ---------- STATS / IMPACT ---------- */
.band-teal{background:linear-gradient(165deg,var(--teal-deep),var(--teal));color:#fff}
.band-teal .sec-head h2{color:#fff}
.band-teal .sec-head p{color:rgba(255,255,255,.78)}
.band-teal .eyebrow{color:#fff}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.stat{padding:34px 30px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:var(--r)}
.stat .num{font-family:var(--display);font-weight:700;font-size:clamp(44px,5.5vw,64px);line-height:1;letter-spacing:-.03em}
.stat .num .u{color:var(--amber)}
.stat .lab{margin-top:12px;font-size:15px;color:rgba(255,255,255,.82)}
.stat .note{margin-top:6px;font-size:12.5px;color:rgba(255,255,255,.5)}

/* ---------- GET INVOLVED ---------- */
.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.inv{display:flex;flex-direction:column;padding:34px 30px;border-radius:var(--r);border:1px solid var(--line);background:var(--paper)}
.inv.feature{background:linear-gradient(160deg,var(--teal),var(--teal-deep));border:none;color:#fff}
.inv .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:var(--teal-tint);color:var(--teal);margin-bottom:20px}
.inv.feature .ic{background:rgba(255,255,255,.16);color:#fff}
.inv .ic svg{width:26px;height:26px}
.inv h3{font-size:22px}
.inv p{font-size:14.5px;color:var(--stone);margin-top:9px;flex:1}
.inv.feature p{color:rgba(255,255,255,.85)}
.inv .btn{margin-top:22px;align-self:flex-start}

/* ---------- CTA STRIP ---------- */
.cta-strip{background:linear-gradient(160deg,var(--teal),var(--teal-deep));color:#fff;border-radius:24px;padding:54px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;box-shadow:var(--shadow-lg)}
.cta-strip h2{font-size:clamp(26px,3vw,38px);text-wrap:balance;max-width:18ch}
.cta-strip p{color:rgba(255,255,255,.82);margin-top:12px;max-width:44ch}
.cta-strip .acts{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- FOOTER ---------- */
footer.site{background:var(--ink);color:#cfcabf;padding:72px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
.foot-brand .brand{align-items:center}
.foot-brand .brand .wm{color:#fff;white-space:nowrap}
.foot-brand .brand .logo-slot{width:38px;height:38px}
.foot-brand p{margin-top:18px;font-size:14px;max-width:32ch;color:#a7a299}
.foot-social{display:flex;gap:12px;margin-top:22px}
.foot-social a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.07);color:#cfcabf;transition:background .2s,color .2s}
.foot-social a:hover{background:var(--teal);color:#fff}
.foot-social svg{width:18px;height:18px}
.foot-col h4{font-family:var(--display);font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.foot-col a,.foot-col p{display:block;font-size:14px;color:#a7a299;margin-bottom:11px}
.foot-col a:hover{color:#fff}
.transparency{margin-top:50px;padding:22px 24px;border:1px solid rgba(255,255,255,.12);border-radius:var(--r);display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.03)}
.transparency svg{width:22px;height:22px;color:var(--amber);flex:none;margin-top:2px}
.transparency p{font-size:13.5px;color:#a7a299;line-height:1.6}
.foot-bottom{margin-top:36px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#7d786f}

/* ---------- PROGRAM DETAIL ---------- */
.prog-hero{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.prog-hero .ic-xl{width:84px;height:84px;border-radius:20px;background:var(--teal-tint);color:var(--teal);display:grid;place-items:center;margin-bottom:24px}
.prog-hero .ic-xl svg{width:42px;height:42px}
.prog-figure{aspect-ratio:4/3;border-radius:24px;background:linear-gradient(160deg,var(--teal),var(--teal-deep));display:grid;place-items:center;color:rgba(255,255,255,.5);box-shadow:var(--shadow-lg);overflow:hidden;position:relative}
.prog-figure .ph-img{display:flex;flex-direction:column;align-items:center;gap:10px;font-size:13px;letter-spacing:.1em;text-transform:uppercase}
.prog-figure .ph-img svg{width:40px;height:40px;opacity:.7}
.prose{max-width:64ch}
.prose p{font-size:16.5px;color:#3a3833;margin-top:18px}
.prose h3{font-size:22px;margin-top:36px}
.feature-list{display:grid;gap:14px;margin-top:22px}
.feature-list li{list-style:none;display:flex;gap:13px;align-items:flex-start;font-size:15.5px;color:#3a3833}
.feature-list svg{width:22px;height:22px;color:var(--teal);flex:none;margin-top:1px}
.prog-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}
.prog-stat{padding:24px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r)}
.prog-stat .n{font-family:var(--display);font-weight:700;font-size:34px;color:var(--teal-deep);line-height:1}
.prog-stat .l{font-size:13.5px;color:var(--stone);margin-top:8px}

/* ---------- DONATE FLOW ---------- */
.donate-shell{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:start}
.donate-card{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:40px;box-shadow:var(--shadow-md)}
.steps{display:flex;align-items:center;gap:8px;margin-bottom:30px}
.step-pip{display:flex;align-items:center;gap:10px;flex:1}
.step-pip .dot{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:14px;background:var(--paper);border:1.5px solid var(--line);color:var(--stone);flex:none;transition:.2s}
.step-pip .dot svg{width:16px;height:16px}
.step-pip .lab{font-size:13px;font-weight:600;color:var(--stone);white-space:nowrap}
.step-pip .line{flex:1;height:2px;background:var(--line);border-radius:2px}
.step-pip.active .dot{background:var(--teal);border-color:var(--teal);color:#fff}
.step-pip.active .lab{color:var(--ink)}
.step-pip.done .dot{background:var(--teal-deep);border-color:var(--teal-deep);color:#fff}
.step-pip.done .lab{color:var(--ink)}
.step-panel{display:none;animation:fade .3s ease}
.step-panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.freq-toggle{display:inline-flex;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:5px;gap:4px;margin-bottom:24px}
.freq-toggle button{border:none;background:none;cursor:pointer;font-family:var(--body);font-weight:600;font-size:14px;color:var(--stone);padding:9px 20px;border-radius:999px;transition:.2s}
.freq-toggle button.on{background:var(--surface);color:var(--teal-deep);box-shadow:var(--shadow-sm)}
.amount-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.amount-grid button{padding:18px 0;border:1.5px solid var(--line);background:var(--surface);border-radius:14px;cursor:pointer;font-family:var(--display);font-weight:700;font-size:22px;color:var(--ink);transition:.18s}
.amount-grid button .sub{display:block;font-family:var(--body);font-weight:500;font-size:12px;color:var(--stone);margin-top:4px}
.amount-grid button:hover{border-color:var(--teal)}
.amount-grid button.on{border-color:var(--teal);background:var(--teal-tint)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:7px}
.field .req{color:var(--amber-deep)}
.input{width:100%;font-family:var(--body);font-size:15px;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;background:var(--surface);color:var(--ink);transition:border-color .18s}
.input:focus{outline:none;border-color:var(--teal)}
.input.err{border-color:#c8442e;background:#fdf3f1}
.input-prefix{position:relative}
.input-prefix span{position:absolute;left:15px;top:50%;transform:translateY(-50%);font-weight:700;color:var(--stone)}
.input-prefix .input{padding-left:32px}
.err-msg{color:#c8442e;font-size:13px;margin-top:6px;display:none}
.err-msg.show{display:block}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.flow-actions{display:flex;justify-content:space-between;gap:14px;margin-top:28px}
.summary-card{position:sticky;top:96px;background:linear-gradient(160deg,var(--teal),var(--teal-deep));color:#fff;border-radius:24px;padding:32px;box-shadow:var(--shadow-lg)}
.summary-card h3{font-size:20px}
.summary-card .big{font-family:var(--display);font-weight:700;font-size:46px;margin:18px 0 4px;line-height:1}
.summary-card .freq-note{font-size:14px;color:rgba(255,255,255,.78)}
.summary-card .impact-line{display:flex;gap:11px;align-items:flex-start;font-size:14px;color:rgba(255,255,255,.9);margin-top:22px;padding-top:22px;border-top:1px solid rgba(255,255,255,.16)}
.summary-card .impact-line svg{width:20px;height:20px;color:var(--amber);flex:none;margin-top:1px}
.review-row{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-size:15px}
.review-row:last-child{border-bottom:none}
.review-row .k{color:var(--stone)}
.review-row .v{font-weight:600}
.confirm{text-align:center;max-width:560px;margin:0 auto;padding:20px 0}
.confirm .check{width:88px;height:88px;border-radius:50%;background:var(--teal-tint);color:var(--teal);display:grid;place-items:center;margin:0 auto 26px;animation:pop .4s cubic-bezier(.3,1.5,.5,1)}
.confirm .check svg{width:44px;height:44px}
@keyframes pop{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.confirm h1{font-size:clamp(30px,4vw,44px)}
.confirm p{color:var(--stone);font-size:17px;margin-top:16px}
.confirm .ref{display:inline-block;margin-top:24px;padding:12px 22px;background:var(--paper);border:1px dashed var(--line);border-radius:12px;font-family:ui-monospace,monospace;font-size:15px}
.confirm .acts{display:flex;gap:14px;justify-content:center;margin-top:32px;flex-wrap:wrap}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-info .info-item{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.contact-info .info-item:last-child{border-bottom:none}
.contact-info .ic{width:46px;height:46px;border-radius:12px;background:var(--teal-tint);color:var(--teal);display:grid;place-items:center;flex:none}
.contact-info .ic svg{width:22px;height:22px}
.contact-info h4{font-size:16px}
.contact-info p,.contact-info a{color:var(--stone);font-size:14.5px;margin-top:4px;display:block}
.contact-info a:hover{color:var(--teal)}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:38px;box-shadow:var(--shadow-md)}
textarea.input{resize:vertical;min-height:130px}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%236E6A62' stroke-width='2'%3E%3Cpath d='M5 8l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:42px}
.form-ok{display:none;text-align:center;padding:30px 10px}
.form-ok.show{display:block;animation:fade .4s ease}
.form-ok .check{width:72px;height:72px;border-radius:50%;background:var(--teal-tint);color:var(--teal);display:grid;place-items:center;margin:0 auto 20px}
.form-ok .check svg{width:36px;height:36px}
.form-ok h3{font-size:24px}
.form-ok p{color:var(--stone);margin-top:10px}

/* ---------- NEWS ---------- */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.news-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .18s,box-shadow .25s}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.news-card .thumb{aspect-ratio:16/10;background:linear-gradient(160deg,var(--teal-tint),#fff);display:grid;place-items:center;color:var(--teal);border-bottom:1px solid var(--line)}
.news-card .thumb svg{width:34px;height:34px;opacity:.55}
.news-card .body{padding:24px;display:flex;flex-direction:column;flex:1}
.news-card .tag{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--amber-deep)}
.news-card .date{font-size:13px;color:var(--stone)}
.news-card .meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.news-card h3{font-size:19px;line-height:1.2}
.news-card p{color:var(--stone);font-size:14px;margin-top:10px;flex:1}
.news-card .more{margin-top:16px;font-weight:600;font-size:14px;color:var(--teal);display:inline-flex;align-items:center;gap:6px}
.news-card .more svg{width:16px;height:16px}
.featured-story{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:var(--surface);margin-bottom:56px}
.featured-story .fig{background:linear-gradient(160deg,var(--teal),var(--teal-deep));min-height:340px;display:grid;place-items:center;color:rgba(255,255,255,.45)}
.featured-story .fig svg{width:46px;height:46px}
.featured-story .body{padding:48px}
.featured-story .tag{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--amber-deep)}
.featured-story h2{font-size:clamp(26px,3vw,36px);margin-top:14px;text-wrap:balance}
.featured-story p{color:var(--stone);font-size:16px;margin-top:16px}

/* ---------- NEWSLETTER ---------- */
.newsletter{background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:44px;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.newsletter form{display:flex;gap:12px}
.newsletter .input{flex:1}

/* ---------- TWEAKS (vanilla) ---------- */
#tweaks-fab{position:fixed;right:20px;bottom:20px;z-index:80;width:50px;height:50px;border-radius:50%;background:var(--ink);color:#fff;border:none;cursor:pointer;display:grid;place-items:center;box-shadow:0 12px 30px -10px rgba(0,0,0,.5);transition:transform .2s}
#tweaks-fab:hover{transform:rotate(20deg)}
#tweaks-fab svg{width:22px;height:22px}
#tweaks-pop{position:fixed;right:20px;bottom:82px;z-index:80;width:290px;background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:0 30px 60px -25px rgba(0,0,0,.4);padding:20px;display:none}
#tweaks-pop.open{display:block;animation:fade .2s ease}
#tweaks-pop h4{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin:0 0 8px;font-family:var(--body);font-weight:700}
#tweaks-pop h4:not(:first-child){margin-top:18px}
#tweaks-pop .tw-row{display:flex;gap:8px;flex-wrap:wrap}
#tweaks-pop .tw-row button{flex:1;min-width:64px;font-family:var(--body);font-size:12.5px;font-weight:600;padding:9px 8px;border:1.5px solid var(--line);background:var(--paper);border-radius:10px;cursor:pointer;color:var(--stone);transition:.15s}
#tweaks-pop .tw-row button.on{border-color:var(--teal);background:var(--teal-tint);color:var(--teal-deep)}
#tweaks-pop .tw-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
#tweaks-pop .tw-title b{font-family:var(--display);font-size:16px}
#tweaks-pop .tw-title button{background:none;border:none;cursor:pointer;color:var(--stone)}

/* ---------- REVEAL ON SCROLL (gated by .js so content never stays hidden) ---------- */
html.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
html.js .reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .donate-shell{grid-template-columns:1fr}
  .summary-card{position:static;order:-1}
}
@media(max-width:900px){
  .nav-links{display:none}
  .menu-btn{display:grid;place-items:center}
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .emblem{max-width:420px;margin:0 auto;width:100%}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .work-grid{grid-template-columns:repeat(2,1fr)}
  .stat-grid{grid-template-columns:1fr}
  .inv-grid{grid-template-columns:1fr}
  .prog-hero{grid-template-columns:1fr;gap:32px}
  .prog-figure{order:-1}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .featured-story{grid-template-columns:1fr}
  .featured-story .fig{min-height:220px}
  .newsletter{grid-template-columns:1fr;gap:20px}
  .cta-strip{padding:40px}
  section{padding:68px 0}
}
@media(max-width:560px){
  .work-grid{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .prog-stats{grid-template-columns:1fr}
  .amount-grid{grid-template-columns:1fr 1fr}
  .donate-card,.form-card{padding:26px}
  .step-pip .lab{display:none}
  .foot-grid{grid-template-columns:1fr}
  .hero .cta .btn{flex:1}
}
