
:root{
  --ink:#16243f;--ink-soft:#3a4a68;--paper:#fbf8f3;--surface:#ffffff;--line:#e9e2d6;
  --love:#2e7ce4;--educate:#2fa84f;--protect:#7b4fc4;--support:#f2922c;--empower:#e0408a;
  --rainbow:linear-gradient(90deg,var(--love),var(--educate),var(--protect),var(--support),var(--empower));
  --maxw:1180px;--radius:22px;
  --shadow:0 18px 50px -20px rgba(22,36,63,.28);--shadow-sm:0 6px 24px -12px rgba(22,36,63,.30);
  --font-display:"Fraunces",Georgia,serif;--font-body:"Plus Jakarta Sans",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.08;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--protect);display:inline-flex;align-items:center;gap:10px;margin-bottom:18px}
.eyebrow::before{content:"";width:26px;height:3px;border-radius:3px;background:var(--rainbow)}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:62ch}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.98rem;padding:14px 26px;border-radius:100px;cursor:pointer;border:2px solid transparent;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}
.btn-primary{background:var(--ink);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(22,36,63,.55)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-give{background:var(--rainbow);color:#fff;box-shadow:0 14px 30px -12px rgba(224,64,138,.6)}
.btn-give:hover{transform:translateY(-2px);filter:saturate(1.1)}
:focus-visible{outline:3px solid var(--protect);outline-offset:3px;border-radius:6px}

header{position:sticky;top:0;z-index:50;background:rgba(251,248,243,.85);backdrop-filter:blur(12px);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;font-family:var(--font-display);font-weight:700;font-size:1.18rem}
.brand .mark{width:46px;height:46px;flex:none;object-fit:contain}
.brand small{display:block;font-family:var(--font-body);font-weight:600;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--protect)}
.menu{display:flex;align-items:center;gap:26px;list-style:none}
.menu a{font-weight:600;font-size:.93rem;color:var(--ink-soft);transition:color .15s;position:relative}
.menu a:hover{color:var(--ink)}
.menu a.active{color:var(--love)}
.menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2.5px;border-radius:3px;background:var(--rainbow)}
.nav-cta{display:flex;align-items:center;gap:12px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2.5px;background:var(--ink);border-radius:3px;transition:.25s}

/* HOME hero */
.hero{position:relative;padding:70px 0 90px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.1rem)}
.hero h1 em{font-style:normal;color:var(--love)}
.hero p{margin:24px 0 32px;font-size:1.15rem;color:var(--ink-soft);max-width:48ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.hero-tags{display:flex;gap:22px;margin-top:34px;flex-wrap:wrap}
.hero-tags span{font-size:.86rem;font-weight:600;color:var(--ink-soft);display:flex;align-items:center;gap:8px}
.hero-tags i{width:9px;height:9px;border-radius:50%}
.haven{position:relative;aspect-ratio:1/1;max-width:480px;margin-inline:auto;width:100%}
.haven .badge-img{position:relative;z-index:2;width:100%;border-radius:50%;filter:drop-shadow(0 20px 40px rgba(22,36,63,.18))}
.haven .glow{position:absolute;inset:-6%;border-radius:50%;background:radial-gradient(circle at 50% 38%,rgba(46,124,228,.16),transparent 60%),radial-gradient(circle at 30% 70%,rgba(47,168,79,.14),transparent 55%),radial-gradient(circle at 72% 66%,rgba(224,64,138,.14),transparent 55%)}
.float{animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* PAGE head (inner pages) */
.pagehead{background:linear-gradient(160deg,#16243f,#243a66);color:#fff;padding:72px 0 60px;position:relative}
.pagehead h1{color:#fff;font-size:clamp(2.1rem,4.6vw,3.2rem)}
.pagehead p{color:rgba(255,255,255,.78);max-width:60ch;margin-top:16px;font-size:1.08rem}
.crumb{font-size:.84rem;color:rgba(255,255,255,.6);margin-bottom:14px;display:flex;gap:8px;flex-wrap:wrap}
.crumb a{color:rgba(255,255,255,.8)}
.crumb a:hover{color:#fff}
.tagband{height:5px;background:var(--rainbow)}

/* Pillars */
.pillars{background:var(--ink);color:#fff}
.pillars .head{text-align:center;max-width:60ch;margin:0 auto 54px}
.pillars h2{color:#fff;font-size:clamp(1.9rem,3.5vw,2.7rem)}
.pillars .head p{color:rgba(255,255,255,.72);margin-top:14px}
.pillar-row{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.pillar{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:28px 20px;text-align:center;transition:transform .2s,background .2s}
.pillar:hover{transform:translateY(-6px);background:rgba(255,255,255,.09)}
.pillar .ico{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;margin:0 auto 16px}
.pillar h3{font-size:1.18rem;color:#fff;margin-bottom:7px}
.pillar p{font-size:.86rem;color:rgba(255,255,255,.66);line-height:1.5}

/* Stats */
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:34px 26px;box-shadow:var(--shadow-sm)}
.stat .num{font-family:var(--font-display);font-size:2.7rem;font-weight:600;line-height:1}
.stat .lab{margin-top:10px;font-weight:600;color:var(--ink-soft);font-size:.94rem}
.stat:nth-child(1) .num{color:var(--love)}
.stat:nth-child(2) .num{color:var(--educate)}
.stat:nth-child(3) .num{color:var(--support)}
.stat:nth-child(4) .num{color:var(--empower)}

/* Split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.vm{display:grid;gap:18px;margin-top:24px}
.vm div{padding-left:20px;border-left:3px solid var(--line)}
.vm h4{font-family:var(--font-body);font-weight:800;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--protect);margin-bottom:6px}
.vm p{color:var(--ink-soft)}
.imgslot{position:relative;border-radius:var(--radius);overflow:hidden;background:linear-gradient(135deg,#eef4fd,#fdeef6);border:1px dashed #c9bfae;min-height:340px;display:grid;place-items:center;text-align:center;color:var(--ink-soft)}
.imgslot span{font-size:.82rem;font-weight:600;max-width:24ch;opacity:.8}
.imgslot svg{opacity:.5;margin-bottom:10px}

/* Programs */
.prog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.prog{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.prog::before{content:"";position:absolute;top:0;left:0;width:100%;height:5px}
.prog:nth-child(1)::before{background:var(--support)}
.prog:nth-child(2)::before{background:var(--educate)}
.prog:nth-child(3)::before{background:var(--protect)}
.prog:nth-child(4)::before{background:var(--love)}
.prog .tag{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--protect)}
.prog h3{font-size:1.45rem;margin:10px 0 12px}
.prog p{color:var(--ink-soft);font-size:.97rem}

/* Plan */
.plan{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:38px;box-shadow:var(--shadow-sm);margin-top:36px}
.plan h3{font-size:1.5rem;margin-bottom:8px}
.plan .theme{color:var(--protect);font-weight:700;margin-bottom:18px}
.plan ul{list-style:none;display:grid;gap:12px}
.plan li{display:flex;gap:12px;color:var(--ink-soft)}
.plan li .dot{width:10px;height:10px;border-radius:50%;background:var(--rainbow);margin-top:8px;flex:none}

/* Ways */
.ways{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.way{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:36px 30px;text-align:center;box-shadow:var(--shadow-sm)}
.way .badge{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;margin:0 auto 18px;color:#fff}
.way h3{font-size:1.3rem;margin-bottom:10px}
.way p{color:var(--ink-soft);font-size:.95rem;margin-bottom:18px}

/* Donate */
.donate-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:start}
.needs{list-style:none;margin-top:26px;display:grid;gap:14px}
.needs li{display:flex;gap:14px;align-items:flex-start;color:var(--ink-soft);font-size:1rem}
.needs b{color:var(--ink)}
.needs .dot{width:11px;height:11px;border-radius:50%;margin-top:7px;flex:none}
.steps{background:var(--ink);border-radius:var(--radius);padding:38px;color:#fff;box-shadow:var(--shadow)}
.steps h3{color:#fff;display:flex;align-items:center;gap:12px;font-size:1.4rem;margin-bottom:6px}
.steps .sub{color:rgba(255,255,255,.65);font-size:.92rem;margin-bottom:24px}
.steplist{list-style:none;counter-reset:s;display:grid;gap:16px}
.steplist li{counter-increment:s;display:flex;gap:16px;align-items:flex-start;color:rgba(255,255,255,.85);font-size:.96rem}
.steplist li::before{content:counter(s);flex:none;width:30px;height:30px;border-radius:50%;background:var(--rainbow);color:#fff;font-weight:800;font-size:.9rem;display:grid;place-items:center}
.recipient{margin-top:22px;background:rgba(0,0,0,.22);border-radius:14px;padding:18px 20px}
.recipient .row{display:flex;justify-content:space-between;gap:14px;padding:7px 0;font-size:.92rem;border-bottom:1px solid rgba(255,255,255,.1)}
.recipient .row:last-child{border:0}
.recipient .k{color:rgba(255,255,255,.6)}
.recipient .v{font-weight:700;color:#fff;text-align:right}
.fine{margin-top:16px;font-size:.82rem;color:rgba(255,255,255,.55);line-height:1.5}

/* Forms */
.form-wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:700;font-size:.88rem;margin-bottom:7px}
.field .req{color:var(--empower)}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:13px 15px;transition:border .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--love);box-shadow:0 0 0 3px rgba(46,124,228,.15)}
.field textarea{min-height:130px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.check{display:flex;align-items:center;gap:9px;font-size:.92rem;font-weight:500;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:10px 12px;cursor:pointer}
.check input{width:auto}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{display:none;border-radius:12px;padding:14px 18px;margin-bottom:18px;font-weight:600;font-size:.95rem}
.form-status.show{display:block}
.form-status.ok{background:rgba(47,168,79,.12);color:#1d6e34;border:1px solid rgba(47,168,79,.4)}
.form-status.err{background:rgba(224,64,138,.1);color:#a31d5e;border:1px solid rgba(224,64,138,.4)}
.form .btn{width:100%;justify-content:center;margin-top:6px}

/* Contact cards */
.contact-list{display:grid;gap:16px}
.cc{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px 22px;box-shadow:var(--shadow-sm);transition:transform .18s}
.cc:hover{transform:translateY(-3px)}
.cc .ci{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;flex:none}
.cc .lbl{font-size:.76rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.cc .val{font-weight:700;font-size:1rem;word-break:break-word}

/* CTA band */
.ctaband{background:linear-gradient(160deg,#16243f,#22335a);color:#fff;border-radius:28px;padding:56px;text-align:center;position:relative;overflow:hidden}
.ctaband h2{color:#fff;font-size:clamp(1.8rem,3.6vw,2.6rem);max-width:22ch;margin:0 auto 14px}
.ctaband p{color:rgba(255,255,255,.75);max-width:50ch;margin:0 auto 26px}
.ctaband .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.ctaband .btn-ghost{border-color:#fff;color:#fff}
.ctaband .btn-ghost:hover{background:#fff;color:var(--ink)}

/* Footer */
footer{background:var(--ink);color:#fff;padding:64px 0 30px}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand{max-width:34ch}
.foot-brand .brand{color:#fff}
.foot-chip{background:#fff;border-radius:12px;padding:5px;display:inline-flex}
.foot-chip .mark{width:40px;height:40px}
.foot-brand p{color:rgba(255,255,255,.6);font-size:.92rem;margin-top:14px}
.foot-links{display:flex;gap:48px;flex-wrap:wrap}
.foot-col h5{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px;font-family:var(--font-body);font-weight:700}
.foot-col a{display:block;color:rgba(255,255,255,.8);font-size:.94rem;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:#fff}
.foot-bottom{padding-top:26px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.84rem;color:rgba(255,255,255,.5)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

@media(max-width:900px){
  .hero-grid,.split,.donate-grid,.contact-grid,.form-wrap{grid-template-columns:1fr;gap:40px}
  .haven{max-width:340px}
  .pillar-row{grid-template-columns:repeat(2,1fr)}
  .impact-grid{grid-template-columns:repeat(2,1fr)}
  .prog-grid,.ways{grid-template-columns:1fr}
  .menu,.nav-cta .btn-ghost{display:none}
  .burger{display:flex}
  .menu.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:var(--paper);padding:20px 24px;gap:8px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .menu.open a{padding:10px 0}
  .menu.open a.active::after{display:none}
  .section{padding:70px 0}
  .form-row,.checks{grid-template-columns:1fr}
  .ctaband{padding:40px 24px}
  .hero h1 br{display:none}
}
@media(max-width:520px){.pillar-row,.impact-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}}
