/* ============================================================================
   Їжа Життя — shared stylesheet (multi-page)
   Brand: #F18708 → #D92414 · Comfortaa / Manrope / Nunito Sans
   ========================================================================== */
:root{
  --red:#D92414; --orange:#F18708; --amber:#F6A600; --yellow:#FFD23F;
  --ink:#231405; --muted:#8c7c6d; --faint:#b3a597;
  --cream:#fff9f3; --soft:#fff5ec; --soft2:#fff0e2; --line:#f0e4d6; --line2:#efe2d2;
  --white:#ffffff; --dark:#1c1102; --dark2:#2a1606;
  --grad:linear-gradient(135deg,#F18708 0%,#D92414 100%);
  --grad-soft:linear-gradient(135deg,#fff3e3,#ffe7d4);
  --sun:linear-gradient(180deg,#FFD23F 0%,#F6A600 46%,#EB680F 74%,#D92414 100%);
  --shadow-s:0 4px 14px -8px rgba(80,30,0,.25);
  --shadow-m:0 22px 48px -28px rgba(160,40,10,.45), 0 6px 18px -12px rgba(0,0,0,.10);
  --shadow-l:0 40px 90px -40px rgba(160,40,10,.55), 0 10px 28px -16px rgba(0,0,0,.12);
  --r-card:26px; --r-lg:32px; --maxw:1180px;
  --h:"Comfortaa",system-ui,sans-serif; --ui:"Manrope",system-ui,sans-serif; --body:"Nunito Sans",system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; background:var(--cream); color:var(--ink); font-family:var(--body); font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h3,h4{font-family:var(--h); font-weight:700; line-height:1.12; letter-spacing:-.01em; margin:0}
p{margin:0}
.container{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px}
section{scroll-margin-top:84px}

/* helpers */
.eyebrow{display:inline-flex; align-items:center; gap:8px; font-family:var(--ui); font-weight:800; font-size:12px; letter-spacing:.13em; text-transform:uppercase; color:var(--orange); background:var(--soft); border:1px solid var(--line); padding:7px 15px; border-radius:999px}
.eyebrow .dot{width:6px; height:6px; border-radius:50%; background:var(--grad); flex-shrink:0}
.lead{font-size:clamp(17px,2.1vw,19px); color:var(--muted); line-height:1.6}
.grad-text{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family:var(--ui); font-weight:800; font-size:16px; padding:15px 26px; border-radius:14px; border:0; cursor:pointer; transition:transform .16s ease, box-shadow .25s ease, filter .2s; white-space:nowrap}
.btn svg{width:18px; height:18px}
.btn-primary{background:linear-gradient(135deg,#F18708,#E11D0C); color:#fff; box-shadow:0 16px 32px -16px rgba(217,36,20,.85)}
.btn-primary:hover{transform:translateY(-2px); filter:brightness(1.05); box-shadow:0 22px 40px -16px rgba(217,36,20,.95)}
.btn-ghost{background:var(--white); color:var(--ink); border:1.6px solid var(--line)}
.btn-ghost:hover{transform:translateY(-2px); border-color:var(--orange); box-shadow:var(--shadow-s)}
.btn-lg{padding:18px 32px; font-size:17px}
.section-pad{padding:clamp(64px,9vw,110px) 0}
.section-head{max-width:680px; margin:0 auto 52px; text-align:center}
.section-head h2{font-size:clamp(28px,4.4vw,46px); margin:16px 0 14px}

.reveal{opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1; transform:none; transition:none} html{scroll-behavior:auto}}

/* ============================== HEADER ============================== */
.hdr{position:sticky; top:0; z-index:60; transition:background .3s, box-shadow .3s}
.hdr-inner{display:flex; align-items:center; gap:20px; padding:16px 0; transition:padding .3s}
.hdr.scrolled{background:rgba(255,249,243,.85); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); box-shadow:0 1px 0 rgba(0,0,0,.05), 0 10px 30px -24px rgba(120,40,0,.5)}
.hdr.scrolled .hdr-inner{padding:10px 0}
.brand{display:flex; align-items:center; gap:11px; margin-right:auto}
.brand img{height:38px; width:auto}
.nav{display:flex; align-items:center; gap:2px}
.nav a{font-family:var(--ui); font-weight:700; font-size:15px; color:#5b4a3c; padding:9px 13px; border-radius:10px; transition:color .2s, background .2s}
.nav a:hover{color:var(--red); background:var(--soft)}
.nav a.active{color:var(--red); background:var(--soft)}
.hdr-cta{display:flex; align-items:center; gap:10px}
.nav-toggle{display:none; width:46px; height:46px; border:1.6px solid var(--line); background:var(--white); border-radius:13px; cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:5px}
.nav-toggle span{width:20px; height:2.2px; background:var(--ink); border-radius:2px; transition:.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7.2px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.2px) rotate(-45deg)}

/* ============================== HERO (home) ============================== */
.hero{position:relative; padding:clamp(40px,6vw,72px) 0 clamp(56px,8vw,96px); overflow:hidden}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,64px); align-items:center}
.hero h1{font-size:clamp(38px,7vw,76px); line-height:1.05; letter-spacing:-.025em}
.hero h1 .feed{display:block; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; padding-bottom:.1em; margin-bottom:-.06em}
.rotator{display:inline-flex; align-items:center; gap:.45em; margin-top:18px; font-family:var(--h); font-weight:600; font-size:clamp(20px,2.6vw,27px); color:var(--ink); flex-wrap:wrap}
.rotator .static{color:var(--faint); font-size:.7em; font-family:var(--ui); font-weight:700; text-transform:uppercase; letter-spacing:.12em}
.rword{position:relative; min-width:8.3em; height:1.45em; line-height:1.45em; display:inline-block; overflow:hidden; vertical-align:middle}
.rword span{position:absolute; left:0; top:0; line-height:1.45em; white-space:nowrap; color:var(--red); opacity:0; transform:translateY(100%); transition:opacity .5s, transform .5s}
.rword span.on{opacity:1; transform:none}
.rword span.out{opacity:0; transform:translateY(-100%)}
.hero p.lead{margin:26px 0 0; max-width:30em}
.hero-cta{display:flex; flex-wrap:wrap; gap:14px; margin-top:34px}
.hero-trust{display:flex; flex-wrap:wrap; gap:14px 30px; margin-top:38px; padding-top:30px; border-top:1px solid var(--line)}
.hero-trust .t{display:flex; flex-direction:column; gap:2px}
.hero-trust b{font-family:var(--h); font-weight:700; font-size:clamp(22px,3vw,29px); color:var(--ink); line-height:1}
.hero-trust span{font-family:var(--ui); font-weight:700; font-size:12.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--faint)}

.hero-media{position:relative}
.hero-photo{position:relative; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-l); aspect-ratio:4/4.4; z-index:2; transform:rotate(1.2deg)}
.hero-photo img{width:100%; height:100%; object-fit:cover}
.hero-photo::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(70,20,0,.30))}
.hero-badge{position:absolute; z-index:4; background:rgba(255,255,255,.88); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.7); border-radius:18px; padding:13px 17px; box-shadow:var(--shadow-m); display:flex; align-items:center; gap:12px}
.hero-badge .ico{width:42px; height:42px; border-radius:12px; background:var(--grad); display:flex; align-items:center; justify-content:center; flex-shrink:0}
.hero-badge .ico svg{width:24px; height:24px}
.hero-badge b{display:block; font-family:var(--h); font-weight:700; font-size:18px; line-height:1}
.hero-badge span{font-family:var(--ui); font-weight:700; font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.04em}
.hero-badge.b1{bottom:30px; left:-26px; transform:rotate(-2deg)}
.hero-badge.b2{bottom:104px; right:-22px; transform:rotate(2deg)}
.blob{position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; z-index:0; pointer-events:none}
.blob.o{width:340px; height:340px; background:radial-gradient(circle,#F6A600,transparent 70%); top:-60px; right:-40px; animation:float 12s ease-in-out infinite}
.blob.r{width:300px; height:300px; background:radial-gradient(circle,#D92414,transparent 70%); bottom:-80px; left:30%; animation:float 15s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(22px,18px) scale(1.08)}}

/* ---------- Sunrise (logo-themed animated sun) ---------- */
.hero>.container, .page-hero>.container{position:relative; z-index:1}
.sunrise{position:absolute; left:50%; bottom:-12%; transform:translateX(-50%); width:min(560px,52vw); aspect-ratio:1; z-index:0; pointer-events:none; opacity:0; animation:sun-in 2s ease-out .2s forwards}
.sun-orbit{position:absolute; inset:0; display:grid; place-items:center; animation:sun-bob 8s ease-in-out infinite}
.sun-orbit>span{grid-area:1/1; border-radius:50%; display:block}
.sunrise .glow{width:100%; height:100%; background:radial-gradient(circle, rgba(246,166,0,.45) 0%, rgba(241,135,8,.28) 30%, rgba(217,36,20,.12) 54%, transparent 70%); animation:sun-glow 6s ease-in-out infinite}
.sunrise .rays{width:115%; height:115%; background:conic-gradient(from 0deg, rgba(246,166,0,.22) 0 2.4deg, transparent 2.4deg 13deg); -webkit-mask:radial-gradient(circle, transparent 33%, #000 36%, #000 49%, transparent 55%); mask:radial-gradient(circle, transparent 33%, #000 36%, #000 49%, transparent 55%); animation:sun-spin 48s linear infinite}
.sunrise .disc{width:44%; height:44%; overflow:hidden; background:radial-gradient(circle at 50% 38%, #FFE7A0 0%, #FFD23F 16%, #F6A600 46%, #EB680F 72%, #D92414 100%); box-shadow:0 0 40px 2px rgba(241,135,8,.4)}
.sunrise .disc::after{content:""; position:absolute; inset:0; border-radius:50%; background:repeating-linear-gradient(180deg, transparent 0 13%, rgba(150,30,0,.12) 13% 15.5%)}
.hero .sunrise{left:auto; right:12%; bottom:-4%; transform:none; width:min(540px,48vw)}
.page-hero .sunrise{bottom:-40%; width:min(440px,60vw)}
@keyframes sun-in{to{opacity:.62}}
@keyframes sun-bob{0%,100%{transform:translateY(15px)} 50%{transform:translateY(-15px)}}
@keyframes sun-glow{0%,100%{opacity:.78; transform:scale(1)} 50%{opacity:1; transform:scale(1.08)}}
@keyframes sun-spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.sunrise{animation:none; opacity:.5} .sun-orbit,.sunrise .glow,.sunrise .rays{animation:none}}
@media (max-width:760px){.hero .sunrise{right:auto; left:50%; transform:translateX(-50%); bottom:-8%; width:min(420px,80vw)}}

/* ============================== PAGE HERO (inner pages) ============================== */
.page-hero{position:relative; overflow:hidden; padding:clamp(40px,6vw,72px) 0 clamp(40px,5vw,60px); text-align:center}
.page-hero .crumb{font-family:var(--ui); font-weight:700; font-size:13.5px; color:var(--faint); margin-bottom:16px}
.page-hero .crumb a:hover{color:var(--red)}
.page-hero h1{font-size:clamp(34px,5.6vw,60px); line-height:1.05; margin:0 auto 18px; max-width:16ch}
.page-hero p{max-width:640px; margin:0 auto; font-size:clamp(16px,2vw,19px); color:var(--muted); line-height:1.6}

/* ============================== TICKER ============================== */
.ticker{background:var(--grad); color:#fff; overflow:hidden; padding:14px 0}
.ticker-track{display:flex; gap:42px; white-space:nowrap; width:max-content; animation:scrollx 30s linear infinite; font-family:var(--h); font-weight:600; font-size:16px; align-items:center}
.ticker-track span{display:inline-flex; align-items:center; gap:42px; opacity:.96}
.ticker .sep{width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.7)}
@keyframes scrollx{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ticker-track{animation:none}}

/* ============================== LIVE COUNTER ============================== */
.counter{position:relative; background:linear-gradient(135deg,#2a1606,#3c1f08); color:#fff; border-radius:var(--r-lg); padding:clamp(34px,5vw,60px); overflow:hidden; box-shadow:var(--shadow-l); text-align:center}
.counter::before{content:""; position:absolute; inset:0; background:radial-gradient(700px 320px at 50% -10%, rgba(241,135,8,.45), transparent 60%), radial-gradient(600px 360px at 100% 120%, rgba(217,36,20,.4), transparent 60%)}
.counter>*{position:relative; z-index:1}
.live-pill{display:inline-flex; align-items:center; gap:9px; font-family:var(--ui); font-weight:800; font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; padding:8px 16px; border-radius:999px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); margin-bottom:22px}
.live-dot{width:9px; height:9px; border-radius:50%; background:#3ad17a; box-shadow:0 0 0 0 rgba(58,209,122,.7); animation:pulse 1.8s infinite}
.live-dot.off{background:#c98b3a; animation:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(58,209,122,.6)}70%{box-shadow:0 0 0 12px rgba(58,209,122,0)}100%{box-shadow:0 0 0 0 rgba(58,209,122,0)}}
.counter-num{font-family:var(--h); font-weight:700; font-size:clamp(52px,11vw,118px); line-height:.92; letter-spacing:-.03em; background:linear-gradient(135deg,#FFD23F,#F18708 55%,#ff6a3d); -webkit-background-clip:text; background-clip:text; color:transparent; font-variant-numeric:tabular-nums}
.counter-sub{font-family:var(--ui); font-weight:700; font-size:clamp(14px,2vw,17px); color:rgba(255,255,255,.82); margin-top:14px; letter-spacing:.02em}
.counter-meta{display:flex; flex-wrap:wrap; justify-content:center; gap:14px; margin-top:26px}
.counter-chip{background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14); border-radius:14px; padding:12px 18px; min-width:120px}
.counter-chip b{display:block; font-family:var(--h); font-weight:700; font-size:22px; color:#FFD23F; line-height:1}
.counter-chip span{font-family:var(--ui); font-weight:700; font-size:11.5px; text-transform:uppercase; letter-spacing:.05em; color:rgba(255,255,255,.65); margin-top:6px; display:block}
.day-bar{max-width:460px; margin:26px auto 0}
.day-bar-track{height:12px; border-radius:999px; background:rgba(255,255,255,.12); overflow:hidden}
.day-bar-fill{height:100%; width:0; border-radius:999px; background:linear-gradient(90deg,#F6A600,#ff6a3d); transition:width 1s linear}
.day-bar-label{display:flex; justify-content:space-between; font-family:var(--ui); font-weight:700; font-size:12.5px; color:rgba(255,255,255,.7); margin-top:10px}
.counter-note{font-size:12.5px; color:rgba(255,255,255,.5); margin-top:18px; line-height:1.5}

/* ============================== ABOUT cards ============================== */
.about-grid{display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(34px,5vw,64px); align-items:center}
.about-cards{display:grid; gap:18px}
.qa-card{background:var(--white); border:1px solid var(--line); border-radius:22px; padding:26px; box-shadow:var(--shadow-s)}
.qa-card .q{font-family:var(--h); font-weight:700; font-size:20px; margin-bottom:9px; display:flex; align-items:center; gap:11px}
.qa-card .q .mk{width:34px; height:34px; border-radius:10px; background:var(--soft); color:var(--orange); display:flex; align-items:center; justify-content:center; flex-shrink:0}
.qa-card .q .mk svg{width:20px;height:20px}
.qa-card p{color:var(--muted); font-size:16px}
.about-photo{position:relative; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-m); aspect-ratio:3/3.4}
.about-photo img{width:100%; height:100%; object-fit:cover}
.about-quote{position:absolute; left:20px; right:20px; bottom:20px; background:rgba(255,255,255,.92); backdrop-filter:blur(6px); border-radius:18px; padding:16px 18px; font-family:var(--h); font-weight:600; font-size:15.5px; line-height:1.4; box-shadow:var(--shadow-s)}

/* ============================== IMPACT band ============================== */
.impact{position:relative; background:linear-gradient(135deg,#2a1606,#3c1f08); color:#fff; border-radius:var(--r-lg); padding:clamp(40px,6vw,68px) clamp(28px,5vw,60px); overflow:hidden; box-shadow:var(--shadow-l)}
.impact::before{content:""; position:absolute; inset:0; background:radial-gradient(700px 320px at 85% 0%, rgba(241,135,8,.4), transparent 60%), radial-gradient(620px 360px at 0% 100%, rgba(217,36,20,.4), transparent 60%)}
.impact-inner{position:relative; display:grid; grid-template-columns:1.1fr 1fr; gap:40px; align-items:center}
.impact-num{font-family:var(--h); font-weight:700; font-size:clamp(58px,10vw,108px); line-height:.9; background:linear-gradient(135deg,#FFD23F,#F18708 55%,#ff6a3d); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:-.03em}
.impact-num small{font-size:.34em; -webkit-text-fill-color:#fff; color:#fff; font-family:var(--ui); font-weight:800; display:block; margin-top:6px; letter-spacing:.02em}
.impact-inner p{color:rgba(255,255,255,.82); font-size:18px; line-height:1.6}
.impact-inner h3{font-size:clamp(22px,3vw,30px); margin-bottom:14px}
.impact-mini{display:flex; gap:30px; margin-top:24px; flex-wrap:wrap}
.impact-mini b{font-family:var(--h); font-weight:700; font-size:26px; color:#FFD23F; display:block}
.impact-mini span{font-size:13.5px; color:rgba(255,255,255,.7); font-family:var(--ui); font-weight:700; text-transform:uppercase; letter-spacing:.05em}

/* ============================== WHAT WE DO ============================== */
.do-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.do-card{background:var(--white); border:1px solid var(--line); border-radius:var(--r-card); overflow:hidden; box-shadow:var(--shadow-s); display:flex; flex-direction:column; transition:transform .25s, box-shadow .25s}
.do-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-m)}
.do-card .ph{aspect-ratio:16/11; overflow:hidden; position:relative}
.do-card .ph img{width:100%; height:100%; object-fit:cover; transition:transform .5s}
.do-card:hover .ph img{transform:scale(1.05)}
.do-card .ph .tag{position:absolute; top:14px; left:14px; background:rgba(255,255,255,.92); backdrop-filter:blur(6px); border-radius:999px; padding:7px 14px; font-family:var(--ui); font-weight:800; font-size:12px; color:var(--red); display:flex; align-items:center; gap:7px}
.do-card .ph .tag svg{width:15px; height:15px}
.do-card .bd{padding:24px 24px 26px}
.do-card h3{font-size:21px; margin-bottom:10px}
.do-card p{color:var(--muted); font-size:15.5px}
.do-card .accent{margin-top:14px; font-family:var(--h); font-weight:600; font-size:15px; color:var(--red)}

/* ============================== STATS ============================== */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
.stat{background:var(--white); border:1px solid var(--line); border-radius:22px; padding:30px 22px; text-align:center; box-shadow:var(--shadow-s); position:relative; overflow:hidden}
.stat::before{content:""; position:absolute; top:0; left:0; right:0; height:4px; background:var(--grad)}
.stat b{font-family:var(--h); font-weight:700; font-size:clamp(34px,5vw,48px); display:block; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1}
.stat span{font-family:var(--ui); font-weight:700; font-size:14px; color:var(--muted); margin-top:8px; display:block}

/* ============================== HELP ============================== */
.help-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
.help-card{background:var(--white); border:1px solid var(--line); border-radius:var(--r-card); padding:30px 26px; box-shadow:var(--shadow-s); transition:transform .25s, box-shadow .25s, border-color .25s}
.help-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-m); border-color:#ffd9b0}
.help-card .ico{width:56px; height:56px; border-radius:16px; background:var(--grad-soft); display:flex; align-items:center; justify-content:center; margin-bottom:18px; color:var(--red)}
.help-card .ico svg{width:28px; height:28px}
.help-card h3{font-size:19px; margin-bottom:10px}
.help-card p{color:var(--muted); font-size:15px}
.help-card ul{margin:12px 0 0; padding-left:18px; color:var(--muted); font-size:14.5px}
.help-card li{margin:4px 0}

/* ============================== DONATE / CALC ============================== */
.donate{position:relative; overflow:hidden}
.donate-grid{display:grid; grid-template-columns:1fr 1.06fr; gap:clamp(28px,4vw,48px); align-items:start}
.donate-copy h2{font-size:clamp(28px,4.2vw,44px); margin:16px 0 16px}
.donate-copy .lead{margin-bottom:22px}
.req{background:var(--white); border:1px solid var(--line); border-radius:22px; padding:22px; box-shadow:var(--shadow-s)}
.req-h{display:flex; align-items:center; gap:10px; font-family:var(--h); font-weight:700; font-size:18px; margin-bottom:14px}
.req-h svg{width:20px; height:20px; color:var(--red)}
.req-row{display:flex; align-items:center; gap:10px; padding:11px 0; border-bottom:1px solid var(--soft2); font-size:15px; flex-wrap:wrap}
.req-row:last-child{border-bottom:0}
.req-row>span{flex:0 0 96px; color:var(--faint); font-size:11.5px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; font-family:var(--ui)}
.req-row>b{flex:1; min-width:140px; color:var(--ink); font-weight:700; font-family:var(--ui); font-size:14.5px; word-break:break-word}
.copy{flex:0 0 auto; border:1.5px solid var(--line); background:var(--white); color:var(--red); font-family:var(--ui); font-weight:800; font-size:12px; padding:7px 13px; border-radius:9px; cursor:pointer; transition:.18s}
.copy:hover{background:var(--soft); border-color:var(--orange)}
.copy.done{background:#1a7f37; border-color:#1a7f37; color:#fff}

.calc{position:relative; background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(24px,3vw,34px); box-shadow:var(--shadow-l); overflow:hidden}
.calc .aurora{position:absolute; inset:-40% -20% auto; height:120%; pointer-events:none; z-index:0; filter:blur(46px); opacity:.45}
.calc .aurora span{position:absolute; border-radius:50%; display:block}
.calc .aurora span:nth-child(1){width:240px; height:240px; left:-40px; top:-30px; background:radial-gradient(circle,#F18708,transparent 70%); animation:float 9s ease-in-out infinite}
.calc .aurora span:nth-child(2){width:220px; height:220px; right:-30px; top:0; background:radial-gradient(circle,#D92414,transparent 70%); animation:float 11s ease-in-out infinite reverse}
.calc>*:not(.aurora){position:relative; z-index:1}
.calc-head{text-align:center; margin-bottom:20px}
.calc-head h3{font-size:24px; margin-bottom:6px}
.calc-head p{color:var(--muted); font-size:15px}
.freq{position:relative; display:flex; background:var(--soft2); border:1.5px solid #f3ddc4; border-radius:15px; padding:5px; margin:0 auto 20px; max-width:300px; overflow:hidden}
.freq-btn{flex:1; z-index:2; border:0; background:transparent; cursor:pointer; padding:11px 8px; border-radius:11px; font-family:var(--ui); font-weight:800; font-size:14.5px; color:var(--muted); transition:color .25s}
.freq-btn.on{color:#fff}
.freq-pill{position:absolute; z-index:1; top:5px; bottom:5px; left:5px; width:calc(50% - 5px); background:var(--grad); border-radius:11px; box-shadow:0 6px 16px -6px rgba(217,36,20,.55); transition:transform .32s cubic-bezier(.3,1.2,.4,1)}
.freq[data-active="monthly"] .freq-pill{transform:translateX(100%)}
.presets{display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:18px}
.preset{border:1.5px solid var(--line); background:#fff; border-radius:13px; padding:13px 4px; cursor:pointer; font-family:var(--ui); font-weight:800; font-size:14.5px; color:var(--ink); transition:transform .15s, border-color .2s, background .2s, color .2s, box-shadow .2s}
.preset:hover{border-color:var(--orange); transform:translateY(-2px)}
.preset.on{background:var(--grad); border-color:transparent; color:#fff; box-shadow:0 10px 22px -10px rgba(217,36,20,.6)}
.amount-field{position:relative; display:flex; align-items:center; background:var(--soft); border:2px solid var(--line); border-radius:17px; padding:6px 18px; transition:border-color .2s, box-shadow .2s}
.amount-field:focus-within{border-color:var(--orange); box-shadow:0 0 0 4px rgba(241,135,8,.15)}
.amount-input{flex:1; border:0; background:transparent; outline:none; font-family:var(--h); font-weight:700; font-size:34px; color:var(--ink); width:100%; padding:8px 0}
.amount-cur{font-family:var(--h); font-weight:700; font-size:26px; color:var(--orange); padding-left:8px}
.slider{-webkit-appearance:none; appearance:none; width:100%; height:10px; margin-top:16px; border-radius:999px; outline:none; cursor:pointer; background:linear-gradient(90deg,var(--orange) 0%,var(--red) var(--pct,5%),#efe4d8 var(--pct,5%),#efe4d8 100%)}
.slider::-webkit-slider-thumb{-webkit-appearance:none; width:27px; height:27px; border-radius:50%; background:#fff; box-shadow:0 0 0 5px var(--red),0 6px 14px -3px rgba(217,36,20,.7); cursor:grab}
.slider::-moz-range-thumb{width:27px; height:27px; border-radius:50%; background:#fff; border:5px solid var(--red); box-shadow:0 6px 14px -3px rgba(217,36,20,.7); cursor:grab}
.impact-box{background:linear-gradient(135deg,#fff7f0,#ffeede); border:1px solid #ffe2c6; border-radius:20px; padding:20px; margin:18px 0}
.impact-top{display:flex; align-items:center; justify-content:space-between; gap:14px}
.meals{display:flex; flex-direction:column; line-height:1}
.meals-num{font-family:var(--h); font-weight:700; font-size:50px; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:-.02em}
.meals-label{font-family:var(--ui); font-weight:800; font-size:13.5px; text-transform:uppercase; letter-spacing:.07em; color:var(--red); margin-top:6px}
.bowls{--bsize:26px; display:flex; flex-wrap:wrap; gap:5px; max-width:54%; justify-content:flex-end; align-content:center}
.bowl{width:var(--bsize); height:var(--bsize); transform:scale(.4); opacity:0; transition:transform .3s cubic-bezier(.3,1.5,.4,1), opacity .3s, width .25s, height .25s}
.bowl svg{width:100%; height:100%; display:block}
.bowl.on{transform:scale(1); opacity:1}
.calc-msg{margin:14px 0 0; font-size:15px; font-weight:600; color:var(--ink); line-height:1.45; min-height:42px; transition:opacity .25s}
.calc-msg b{color:var(--red)}
.cta-pay{position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; gap:10px; width:100%; border:0; cursor:pointer; border-radius:16px; padding:19px 24px; background:linear-gradient(135deg,#E11D0C,#9E0606); color:#fff; font-family:var(--ui); font-weight:800; font-size:18.5px; box-shadow:0 14px 30px -13px rgba(180,0,0,.85); transition:transform .15s, filter .2s; text-shadow:0 1px 3px rgba(80,0,0,.5)}
.cta-pay:hover{transform:translateY(-2px) scale(1.01); filter:brightness(1.08)}
.cta-pay svg{width:20px; height:20px}
.cta-shine{position:absolute; top:0; left:-60%; width:45%; height:100%; background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent); transform:skewX(-18deg); animation:shine 3.6s ease-in-out infinite}
@keyframes shine{0%{left:-60%}55%,100%{left:130%}}
.calc-foot{text-align:center; font-size:12.5px; color:var(--faint); margin-top:14px; line-height:1.5}
.calc-trust{display:flex; align-items:center; justify-content:center; gap:7px; margin-top:12px; font-size:13px; font-weight:700; color:var(--muted)}
.calc-trust svg{width:15px; height:15px; color:#1a7f37}

/* ============================== BUDGET DONUT ============================== */
.budget-grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(34px,5vw,60px); align-items:center}
.donut-wrap{display:flex; justify-content:center}
.donut{position:relative; width:min(300px,72vw); aspect-ratio:1; border-radius:50%; background:conic-gradient(var(--orange) 0 62%, var(--red) 62% 86%, var(--amber) 86% 93%, #b07a3e 93% 100%); box-shadow:var(--shadow-m); display:flex; align-items:center; justify-content:center}
.donut::after{content:""; position:absolute; width:54%; height:54%; background:var(--cream); border-radius:50%}
.donut .mid{position:relative; z-index:2; text-align:center}
.donut .mid b{font-family:var(--h); font-weight:700; font-size:30px; display:block; line-height:1}
.donut .mid span{font-family:var(--ui); font-weight:700; font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.06em}
.legend{display:grid; gap:14px}
.legend-row{display:flex; align-items:flex-start; gap:14px; background:var(--white); border:1px solid var(--line); border-radius:16px; padding:16px 18px; box-shadow:var(--shadow-s)}
.legend-row .sw{width:16px; height:16px; border-radius:5px; margin-top:4px; flex-shrink:0}
.legend-row .pct{font-family:var(--h); font-weight:700; font-size:22px; margin-left:auto; flex-shrink:0}
.legend-row h4{font-size:16px; margin-bottom:3px}
.legend-row p{font-size:14px; color:var(--muted)}

/* ============================== INTERACTIVE MAP ============================== */
.regions-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,56px); align-items:start}
.map-stage{position:relative; background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(16px,3vw,28px); box-shadow:var(--shadow-m)}
.map-wrap{position:relative; width:100%}
.map-wrap svg{width:100%; height:auto; display:block}
.map-wrap svg path{fill:#f3e7d8; stroke:#e6d3bf; stroke-width:1; transition:fill .25s}
.map-pin{position:absolute; transform:translate(-50%,-50%); width:18px; height:18px; padding:0; border:0; cursor:pointer; border-radius:50%; background:transparent; z-index:3}
.map-pin .dot{position:absolute; inset:0; margin:auto; width:13px; height:13px; border-radius:50%; background:var(--grad); border:2px solid #fff; box-shadow:0 3px 8px -2px rgba(217,36,20,.7); transition:transform .2s}
.map-pin .ring{position:absolute; inset:-6px; border-radius:50%; border:2px solid rgba(217,36,20,.4); opacity:0; transition:opacity .2s, transform .2s}
.map-pin:hover .dot, .map-pin.active .dot{transform:scale(1.45)}
.map-pin.active .ring{opacity:1; animation:pinpulse 1.6s infinite}
.map-pin.main .dot{width:17px; height:17px; box-shadow:0 0 0 4px rgba(241,135,8,.25),0 4px 10px -2px rgba(217,36,20,.8)}
@keyframes pinpulse{0%{transform:scale(.7);opacity:.7}100%{transform:scale(1.5);opacity:0}}
.map-tip{position:absolute; transform:translate(-50%,-130%); background:var(--ink); color:#fff; font-family:var(--ui); font-weight:700; font-size:12px; padding:5px 10px; border-radius:8px; white-space:nowrap; pointer-events:none; opacity:0; transition:opacity .15s; z-index:5}
.map-tip.show{opacity:1}
.map-panel{background:var(--white); border:1px solid var(--line); border-radius:var(--r-card); padding:clamp(22px,3vw,30px); box-shadow:var(--shadow-s)}
.map-panel .city-name{font-family:var(--h); font-weight:700; font-size:clamp(24px,3.4vw,34px); display:flex; align-items:center; gap:12px}
.map-panel .city-name .badge{font-family:var(--ui); font-weight:800; font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:#1a7f37; background:#e7f6ec; padding:5px 11px; border-radius:999px}
.map-panel .city-contact{font-family:var(--ui); font-weight:700; font-size:16px; color:var(--red); margin-top:10px; display:inline-flex; align-items:center; gap:8px}
.panel-stats{display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:22px}
.panel-stat{background:var(--soft); border:1px solid var(--line); border-radius:16px; padding:16px 18px}
.panel-stat b{font-family:var(--h); font-weight:700; font-size:26px; display:block; color:var(--ink); line-height:1}
.panel-stat span{font-family:var(--ui); font-weight:700; font-size:12.5px; color:var(--muted); margin-top:6px; display:block}
.panel-note{font-size:13px; color:var(--faint); margin-top:16px; line-height:1.5}
.city-tabs{display:flex; flex-wrap:wrap; gap:8px; margin-top:22px}
.city-tab{border:1.5px solid var(--line); background:#fff; border-radius:999px; padding:9px 15px; font-family:var(--ui); font-weight:700; font-size:13.5px; color:#5b4a3c; cursor:pointer; transition:.18s}
.city-tab:hover{border-color:var(--orange)}
.city-tab.on{background:var(--grad); border-color:transparent; color:#fff}

/* ============================== ANALYTICS: CLOCK / TIMELINE / WHO ============================== */
.analytics-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:24px}
.an-card{background:var(--white); border:1px solid var(--line); border-radius:var(--r-card); padding:clamp(24px,3vw,32px); box-shadow:var(--shadow-s)}
.an-card h3{font-size:21px; margin-bottom:6px; display:flex; align-items:center; gap:10px}
.an-card h3 .ic{width:30px;height:30px;border-radius:9px;background:var(--soft);color:var(--red);display:flex;align-items:center;justify-content:center}
.an-card h3 .ic svg{width:18px;height:18px}
.an-card .sub{color:var(--muted); font-size:14.5px; margin-bottom:20px}
/* distribution clock */
.clock{display:flex; align-items:center; gap:24px; flex-wrap:wrap}
.clock-ring{position:relative; width:170px; height:170px; flex-shrink:0}
.clock-ring svg{width:100%; height:100%; transform:rotate(-90deg)}
.clock-ring .ctext{position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center}
.clock-ring .ctext b{font-family:var(--h); font-weight:700; font-size:30px; line-height:1; color:var(--ink)}
.clock-ring .ctext span{font-family:var(--ui); font-weight:700; font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); margin-top:4px}
.clock-info b{font-family:var(--h); font-weight:700; font-size:18px; display:block}
.clock-info p{color:var(--muted); font-size:14.5px; margin-top:4px}
.clock-info .state{display:inline-flex; align-items:center; gap:8px; font-family:var(--ui); font-weight:800; font-size:13px; padding:7px 13px; border-radius:999px; margin-bottom:12px}
.clock-info .state.on{background:#e7f6ec; color:#1a7f37}
.clock-info .state.off{background:var(--soft2); color:#b4540a}
/* timeline / bars */
.timeline{display:grid; gap:14px}
.tl-row{display:grid; grid-template-columns:62px 1fr auto; align-items:center; gap:14px}
.tl-row .yr{font-family:var(--h); font-weight:700; font-size:16px; color:var(--red)}
.tl-bar{height:14px; border-radius:999px; background:var(--soft2); overflow:hidden}
.tl-bar i{display:block; height:100%; width:0; border-radius:999px; background:var(--grad); transition:width 1.1s cubic-bezier(.2,.8,.2,1)}
.tl-row .val{font-family:var(--ui); font-weight:800; font-size:13.5px; color:var(--muted); white-space:nowrap}
.who{display:grid; gap:14px}
.who-row .who-top{display:flex; justify-content:space-between; font-family:var(--ui); font-weight:700; font-size:14.5px; margin-bottom:6px}
.who-row .who-top span:last-child{color:var(--red)}
.who-bar{height:12px; border-radius:999px; background:var(--soft2); overflow:hidden}
.who-bar i{display:block; height:100%; width:0; border-radius:999px; transition:width 1.1s cubic-bezier(.2,.8,.2,1)}

/* ============================== TESTIMONIAL ============================== */
.testi{background:linear-gradient(135deg,#fff3e3,#ffe8d6); border-radius:var(--r-lg); padding:clamp(34px,5vw,60px); display:grid; grid-template-columns:auto 1fr; gap:clamp(26px,4vw,48px); align-items:center; box-shadow:var(--shadow-m); position:relative; overflow:hidden}
.testi .ph{width:clamp(120px,18vw,190px); aspect-ratio:1; border-radius:24px; overflow:hidden; box-shadow:var(--shadow-m); flex-shrink:0}
.testi .ph img{width:100%; height:100%; object-fit:cover}
.testi blockquote{margin:0; font-family:var(--h); font-weight:500; font-size:clamp(20px,3vw,29px); line-height:1.4; color:var(--ink)}
.testi .quote-mark{font-family:var(--h); font-size:70px; color:var(--orange); line-height:.5; opacity:.35; display:block; height:30px}
.testi .who2{margin-top:18px; font-family:var(--ui)}
.testi .who2 b{font-weight:800; font-size:17px; display:block}
.testi .who2 span{color:var(--muted); font-size:14px}

/* ============================== GALLERY + LIGHTBOX ============================== */
.gallery{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.gallery .g-item{position:relative; border-radius:18px; overflow:hidden; aspect-ratio:3/4; cursor:pointer; box-shadow:var(--shadow-s)}
.gallery .g-item.wide{aspect-ratio:auto; grid-column:span 2}
.gallery img{width:100%; height:100%; object-fit:cover; transition:transform .5s}
.gallery .g-item:hover img{transform:scale(1.06)}
.gallery .g-item::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 60%,rgba(40,15,0,.25)); opacity:0; transition:opacity .3s}
.gallery .g-item:hover::after{opacity:1}
.lightbox{position:fixed; inset:0; z-index:999; display:none; align-items:center; justify-content:center; padding:24px; background:rgba(20,10,2,.86); backdrop-filter:blur(8px)}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw; max-height:86vh; border-radius:16px; box-shadow:0 40px 100px -30px rgba(0,0,0,.7)}
.lightbox .lb-close{position:absolute; top:22px; right:24px; width:48px; height:48px; border-radius:50%; border:0; background:rgba(255,255,255,.15); color:#fff; font-size:24px; cursor:pointer}
.lightbox .lb-nav{position:absolute; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; border:0; background:rgba(255,255,255,.15); color:#fff; font-size:26px; cursor:pointer}
.lightbox .lb-prev{left:18px} .lightbox .lb-next{right:18px}

/* ============================== FAQ ============================== */
.faq-wrap{max-width:820px; margin:0 auto; display:grid; gap:12px}
.faq-cat{font-family:var(--ui); font-weight:800; font-size:12.5px; text-transform:uppercase; letter-spacing:.1em; color:var(--orange); margin:22px 0 4px; padding-left:4px}
.faq-cat:first-child{margin-top:0}
details.faq{background:var(--white); border:1px solid var(--line); border-radius:16px; overflow:hidden; box-shadow:var(--shadow-s)}
details.faq summary{cursor:pointer; list-style:none; padding:20px 22px; font-family:var(--ui); font-weight:700; font-size:16.5px; display:flex; align-items:center; gap:14px; transition:color .2s}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary .chev{margin-left:auto; width:26px; height:26px; flex-shrink:0; border-radius:8px; background:var(--soft); display:flex; align-items:center; justify-content:center; transition:transform .3s, background .3s; color:var(--red)}
details.faq summary .chev svg{width:16px; height:16px}
details.faq[open] summary{color:var(--red)}
details.faq[open] summary .chev{transform:rotate(180deg); background:var(--grad); color:#fff}
details.faq .ans{padding:0 22px 22px; color:var(--muted); font-size:15.5px; line-height:1.6}

/* ============================== FORMS ============================== */
.form-card{background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,4vw,40px); box-shadow:var(--shadow-m)}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.field{display:flex; flex-direction:column; gap:7px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--ui); font-weight:700; font-size:13.5px; color:#5b4a3c}
.field label .req-star{color:var(--red)}
.field input, .field select, .field textarea{font-family:var(--body); font-size:16px; color:var(--ink); border:1.6px solid var(--line); border-radius:13px; padding:14px 16px; background:var(--soft); outline:none; transition:border-color .2s, box-shadow .2s; width:100%}
.field textarea{resize:vertical; min-height:120px}
.field input:focus, .field select:focus, .field textarea:focus{border-color:var(--orange); box-shadow:0 0 0 4px rgba(241,135,8,.13); background:#fff}
.form-note{font-size:13px; color:var(--faint); margin-top:14px; line-height:1.5}
.form-ok{margin-top:14px; padding:14px 16px; border-radius:13px; background:#e7f6ec; color:#1a7f37; font-weight:700; font-size:14.5px; display:none}
.form-ok.show{display:block}
.contact-cards{display:grid; gap:14px}
.contact-card{display:flex; align-items:center; gap:16px; background:var(--white); border:1px solid var(--line); border-radius:18px; padding:18px 20px; box-shadow:var(--shadow-s)}
.contact-card .ic{width:48px;height:48px;border-radius:13px;background:var(--grad-soft);color:var(--red);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-card .ic svg{width:24px;height:24px}
.contact-card .lbl{font-family:var(--ui);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint)}
.contact-card .val{font-family:var(--ui);font-weight:800;font-size:17px;color:var(--ink)}

/* ============================== NEWSLETTER ============================== */
.news{background:linear-gradient(135deg,#2a1606,#3c1f08); border-radius:var(--r-lg); padding:clamp(36px,5vw,60px); text-align:center; color:#fff; position:relative; overflow:hidden; box-shadow:var(--shadow-l)}
.news::before{content:""; position:absolute; inset:0; background:radial-gradient(600px 300px at 50% 0%, rgba(241,135,8,.4), transparent 60%)}
.news>*{position:relative}
.news h2{font-size:clamp(26px,4vw,40px); margin-bottom:14px}
.news p{color:rgba(255,255,255,.8); max-width:560px; margin:0 auto 28px; font-size:17px}
.news-form{display:flex; gap:12px; max-width:480px; margin:0 auto; flex-wrap:wrap; justify-content:center}
.news-form input{flex:1; min-width:200px; border:0; border-radius:14px; padding:16px 20px; font-family:var(--body); font-size:16px; outline:none}
.news-note{margin-top:16px; font-size:14px; color:rgba(255,255,255,.75); min-height:20px}

/* CTA band */
.cta-band{background:var(--grad); border-radius:var(--r-lg); padding:clamp(36px,5vw,56px); text-align:center; color:#fff; box-shadow:var(--shadow-l)}
.cta-band h2{font-size:clamp(26px,4vw,42px); margin-bottom:14px; color:#fff}
.cta-band p{max-width:560px; margin:0 auto 26px; color:rgba(255,255,255,.92); font-size:17px}
.cta-band .btn-white{background:#fff; color:var(--red)}
.cta-band .btn-white:hover{transform:translateY(-2px)}

/* ============================== FOOTER ============================== */
.footer{background:#1c1102; color:rgba(255,255,255,.7); padding:clamp(54px,7vw,84px) 0 30px; margin-top:clamp(60px,8vw,100px)}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand img{height:42px; margin-bottom:18px}
.footer-brand .tag{font-family:var(--h); font-weight:600; font-size:18px; color:#fff; line-height:1.5; margin-bottom:18px}
.socials{display:flex; gap:10px}
.socials a{width:44px; height:44px; border-radius:12px; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; transition:background .2s, transform .2s}
.socials a:hover{background:var(--grad); transform:translateY(-3px)}
.socials a svg{width:21px; height:21px; fill:#fff}
.footer h4{color:#fff; font-family:var(--ui); font-weight:800; font-size:14px; text-transform:uppercase; letter-spacing:.06em; margin-bottom:18px}
.footer a.fl{display:block; color:rgba(255,255,255,.7); padding:6px 0; transition:color .2s; font-size:15px}
.footer a.fl:hover{color:#fff}
.footer .ci{padding:6px 0; font-size:15px; line-height:1.5}
.footer .ci b{color:#fff; font-weight:700}
.footer-bottom{display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; padding-top:26px; font-size:13.5px; color:rgba(255,255,255,.5)}

/* ============================== RESPONSIVE ============================== */
@media (max-width:980px){
  .hero-grid,.about-grid,.impact-inner,.donate-grid,.budget-grid,.regions-grid,.analytics-grid{grid-template-columns:1fr}
  .hero-media{max-width:440px; margin:0 auto; order:-1}
  .hero-photo{aspect-ratio:4/3.2; transform:none}
  .do-grid{grid-template-columns:repeat(2,1fr)}
  .help-grid,.stats{grid-template-columns:repeat(2,1fr)}
  .about-photo{max-width:480px; margin:0 auto; aspect-ratio:16/11}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:760px){
  .nav, .hdr-cta .btn{display:none}
  .nav-toggle{display:flex}
  .nav.open{display:flex; position:fixed; inset:72px 14px auto; flex-direction:column; align-items:stretch; gap:6px; background:var(--white); border:1px solid var(--line); border-radius:20px; padding:14px; box-shadow:var(--shadow-l); z-index:70}
  .nav.open a{padding:14px 16px; font-size:16px}
  .nav.open a.m-cta{background:var(--grad); color:#fff; text-align:center; margin-top:6px}
  .testi{grid-template-columns:1fr; text-align:center}
  .testi .ph{margin:0 auto}
  .impact-num{font-size:64px}
  .donate-grid{gap:36px}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  /* ---- MOBILE HERO FIXES ---- */
  .hero{padding-top:24px}
  .hero-copy{text-align:center}
  .hero-copy .eyebrow{align-self:center}
  .hero .rotator{justify-content:center; gap:.4em}
  .hero p.lead{margin-left:auto; margin-right:auto}
  .hero-cta{justify-content:center}
  .hero h1{font-size:clamp(40px,12vw,56px); line-height:1.08}
  .hero h1 .feed{padding-bottom:.14em; margin-bottom:-.08em}
  .hero-photo{aspect-ratio:4/3.4}
  .hero-badge{padding:10px 13px; border-radius:15px}
  .hero-badge .ico{width:34px; height:34px; border-radius:10px}
  .hero-badge .ico svg{width:20px; height:20px}
  .hero-badge b{font-size:15px}
  .hero-badge span{font-size:10.5px}
  .hero-badge.b1{bottom:12px; left:10px; transform:rotate(-2deg)}
  .hero-badge.b2{top:auto; bottom:12px; right:10px; transform:rotate(2deg)}
  .hero-cta{gap:11px; margin-top:28px}
  .hero-cta .btn{flex:1 1 100%; width:100%}
  .hero-trust{gap:0; margin-top:30px; padding-top:24px; display:grid; grid-template-columns:repeat(3,1fr)}
  .hero-trust .t{align-items:center; text-align:center; gap:4px}
  .hero-trust b{font-size:clamp(20px,6vw,26px)}
  .hero-trust span{font-size:10.5px; line-height:1.2}
}
@media (max-width:480px){
  body{font-size:16px}
  .container{padding:0 18px}
  .do-grid,.help-grid,.stats{grid-template-columns:1fr}
  .presets{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .panel-stats{grid-template-columns:1fr 1fr}
  .counter-num{font-size:clamp(46px,15vw,64px)}
  .hero-trust span{font-size:10px}
}
