:root{
  --g900:#0f2d1c;
  --g700:#1a4a2e;
  --g500:#2d7a4f;
  --g300:#4caf78;
  --g100:#d6ede1;
  --g50:#f0f9f4;
  --amber:#e8a020;
  --amber-soft:#fef6e4;
  --cream:#fdfcf7;
  --ink:#141d11;
  --muted:#5a6b55;
  --border:rgba(45,122,79,0.14);
  --shadow:0 10px 36px rgba(15,45,28,0.11);
  --shadow-sm:0 4px 18px rgba(15,45,28,0.08);
  --radius-xl:28px;
  --radius-lg:20px;
  --radius-md:14px;
  --radius-sm:10px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Outfit',sans-serif;background:var(--cream);color:var(--ink);line-height:1.7}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.shell{min-height:100vh;display:flex;flex-direction:column}
.nav{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 5vw;background:rgba(253,252,247,.96);border-bottom:1px solid var(--border);backdrop-filter:blur(12px)}
.brand{display:flex;align-items:center;gap:.75rem}
.brand img{width:42px;height:42px;border-radius:12px;object-fit:cover}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:700;color:var(--g700)}
.brand-name b{color:var(--g500)}
.nav-links{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;justify-content:center}
.nav-links a{padding:.55rem .9rem;border-radius:999px;font-size:.9rem;color:var(--muted);transition:.2s ease}
.nav-links a:hover,.nav-links a.active{color:var(--g700);background:var(--g100)}
.nav-cta{background:var(--g700);color:#fff;padding:.75rem 1.15rem;border-radius:999px;font-weight:600}
.hero{padding:5.5rem 5vw 4.5rem;background:linear-gradient(120deg, rgba(15,45,28,.86), rgba(26,74,46,.7)),url('images/hero-bg.jpg') center/cover;color:#fff}
.hero.compact{padding:4.5rem 5vw 3.5rem}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;max-width:1200px;margin:0 auto}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(76,175,120,.16);color:var(--g300);border:1px solid rgba(76,175,120,.24);border-radius:999px;padding:.45rem .9rem;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:700}
.hero h1,.section-title,.callout-title{font-family:'Cormorant Garamond',serif;line-height:1.06;margin:.9rem 0 1rem}
.hero h1{font-size:clamp(2.8rem,5.6vw,4.7rem)}
.hero h1 em,.section-title em,.callout-title em{font-style:italic;color:var(--g300)}
.hero p{max-width:600px;color:rgba(255,255,255,.82);font-size:1.02rem}
.hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-xl);padding:1.35rem;box-shadow:var(--shadow-sm)}
.hero-card img{border-radius:calc(var(--radius-xl) - 8px);aspect-ratio:4/3;object-fit:cover}
.hero-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:1rem}
.hero-meta div{background:rgba(255,255,255,.08);border-radius:var(--radius-md);padding:.85rem}
.hero-meta strong{display:block;color:#fff;font-size:1.1rem}
.hero-meta span{color:rgba(255,255,255,.7);font-size:.78rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.5rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.85rem 1.25rem;border-radius:999px;font-weight:600;border:1px solid transparent;transition:.2s ease}
.btn-primary{background:var(--amber);color:var(--g900)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-secondary{color:#fff;border-color:rgba(255,255,255,.25)}
.btn-secondary.dark{color:var(--g700);border-color:var(--g700)}
.btn-secondary:hover{background:rgba(255,255,255,.08)}
.section{padding:4.5rem 5vw}
.section.alt{background:var(--g50)}
.section.dark{background:var(--g900);color:#fff}
.section-inner{max-width:1200px;margin:0 auto}
.intro{max-width:760px;margin-bottom:2rem}
.label{text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;font-weight:700;color:var(--g500)}
.label.light{color:var(--g300)}
.section-title{font-size:clamp(2rem,4vw,3.2rem);color:var(--g900)}
.dark .section-title{color:#fff}
.lead{color:var(--muted);font-size:1rem;max-width:720px}
.dark .lead{color:rgba(255,255,255,.74)}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.card-body{padding:1.25rem 1.3rem 1.4rem}
.card h3{margin:0 0 .45rem;font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--g900)}
.card p{margin:0;color:var(--muted);font-size:.94rem}
.partner-logo{background:#fff;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;padding:1.5rem}
.partner-logo img{width:min(100%,320px);height:auto;object-fit:contain}
.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}
.stat{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.3rem;box-shadow:var(--shadow-sm)}
.stat strong{display:block;font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--g700)}
.stat span{color:var(--muted);font-size:.88rem}
.split-visual{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow)}
.split-visual img{width:100%;height:100%;min-height:320px;object-fit:cover}
.list{margin:1.1rem 0 0;padding-left:1.2rem;color:var(--muted)}
.list li{margin-bottom:.6rem}
.callout{background:var(--amber-soft);border:1px solid rgba(232,160,32,.3);border-radius:var(--radius-xl);padding:1.5rem}
.callout-title{font-size:2rem;color:var(--g900);margin-top:0}
.video-story{display:grid;grid-template-columns:1.05fr .95fr;gap:1.5rem;align-items:center}
.video-frame{background:#0c1f14;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow)}
.video-frame video{display:block;width:100%;height:auto;background:#000}
.video-copy{background:#fff;border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.6rem;box-shadow:var(--shadow-sm)}
.video-copy p{margin:0 0 .95rem;color:var(--muted)}
.legal-stack{display:grid;gap:1rem}
.legal-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.4rem;box-shadow:var(--shadow-sm)}
.legal-card h2{margin:0 0 .6rem;font-family:'Cormorant Garamond',serif;font-size:1.7rem;color:var(--g900)}
.legal-card p,.legal-card li{color:var(--muted);font-size:.95rem}
.legal-card ul{margin:.8rem 0 0;padding-left:1.2rem}
.legal-links{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1rem;font-size:.88rem}
.legal-links a{color:rgba(255,255,255,.78)}
.legal-links a:hover{color:#fff}
.footer{margin-top:auto;background:var(--g900);color:rgba(255,255,255,.7);padding:3rem 5vw 1.4rem}
.footer-grid{max-width:1200px;margin:0 auto 1.4rem;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2rem}
.footer h4{margin:0 0 .75rem;color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
.footer ul{list-style:none;padding:0;margin:0}
.footer li{margin-bottom:.5rem}
.footer a:hover{color:#fff}
.footer-bar{max-width:1200px;margin:0 auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,.08);font-size:.82rem}
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:1.5rem}
.contact-card,.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-sm)}
.contact-item{margin-bottom:1rem}
.contact-item strong{display:block;margin-bottom:.2rem;color:var(--g700)}
.invite-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem;margin-bottom:1.5rem}
.invite-card{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);color:#fff;display:flex;flex-direction:column;min-height:100%}
.invite-card.donate{background:linear-gradient(160deg,#1a4a2e,#2d7a4f)}
.invite-card.volunteer{background:linear-gradient(160deg,#14532d,#1f7a47)}
.invite-card.newsletter{background:linear-gradient(160deg,#9a6a09,#e8a020)}
.invite-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.invite-body{padding:1.2rem;display:flex;flex-direction:column;flex:1}
.invite-body h3{margin:0 0 .45rem;font-family:'Cormorant Garamond',serif;font-size:1.45rem;color:#fff}
.invite-body p{margin:0 0 1rem;color:rgba(255,255,255,.82);font-size:.92rem}
.invite-note{background:rgba(255,255,255,.12);border-radius:14px;padding:1rem;margin-bottom:1rem;text-align:center}
.invite-note small{display:block;font-size:.72rem;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem}
.invite-note strong{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:#fff}
.btn-light{background:#fff;color:var(--g900)}
.btn-light:hover{transform:translateY(-1px)}
.btn-outline-light{border:1px solid rgba(255,255,255,.28);color:#fff}
.btn-outline-light:hover{background:rgba(255,255,255,.08)}
.btn-full{width:100%}
.modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:1rem;
  background:rgba(15,45,28,.52);
  z-index:50;
}
.modal.open{display:flex}
.modal-panel{
  width:min(100%,520px);
  max-height:90vh;
  overflow:auto;
  background:#fff;
  border-radius:var(--radius-xl);
  padding:1.4rem;
  box-shadow:0 22px 70px rgba(15,45,28,.24);
  position:relative;
}
.modal-close{
  position:absolute;
  top:.9rem;
  right:.9rem;
  width:38px;
  height:38px;
  border:none;
  border-radius:50%;
  background:var(--g50);
  cursor:pointer;
  font-size:1rem;
}
.modal-title{margin:.2rem 0 .35rem;font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--g900)}
.modal-desc{margin:0 0 1rem;color:var(--muted);font-size:.92rem}
.wa-float{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:45;
  width:60px;
  height:60px;
  border-radius:50%;
  background:#25d366;
  box-shadow:0 10px 28px rgba(37,211,102,.34);
  display:flex;
  align-items:center;
  justify-content:center;
}
.wa-float svg{width:30px;height:30px;fill:#fff}
.wa-tooltip{
  position:absolute;
  right:72px;
  background:var(--g900);
  color:#fff;
  font-size:.76rem;
  padding:.45rem .7rem;
  border-radius:8px;
  white-space:nowrap;
  opacity:0;
  transition:.2s ease;
}
.wa-float:hover .wa-tooltip{opacity:1}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field label{font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--g700)}
.field input,.field select,.field textarea{width:100%;padding:.9rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--g50);font:inherit;color:var(--ink)}
.field textarea{min-height:140px;resize:vertical}
.status{display:none;margin-bottom:1rem;padding:.9rem 1rem;border-radius:var(--radius-sm);font-size:.92rem}
.status.show{display:block}
.status.success{background:var(--g50);border:1px solid rgba(45,122,79,.35);color:var(--g700)}
.status.error{background:#fff1f1;border:1px solid rgba(185,28,28,.25);color:#b91c1c}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media (max-width:980px){
  .hero-grid,.grid-2,.grid-3,.contact-grid,.footer-grid,.stat-grid,.invite-grid,.video-story{grid-template-columns:1fr}
  .nav{position:static;top:auto;flex-direction:column;align-items:flex-start}
  .nav-links{justify-content:flex-start}
  .hero-meta,.form-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .hero,.hero.compact,.section{padding-left:1rem;padding-right:1rem}
  .nav,.footer{padding-left:1rem;padding-right:1rem}
  .hero h1{font-size:2.3rem}
}

/* Overrides for homepage video size and partner logo fit */
.video-story{max-width:860px;margin:0 auto;gap:1rem}
.video-frame{max-width:390px;width:100%}
.video-frame video{aspect-ratio:16/9}
.partner-logo{padding:.65rem;min-height:88px;border:1px solid rgba(0,0,0,0.06);border-radius:18px}
.partner-logo img{width:min(100%,200px);max-height:62px}

@media (max-width:980px){
  .video-frame{max-width:100%}
}

/* Newsletter editorial layout */
.newsletter-hero{
  position:relative;
  overflow:hidden;
  margin:0;
  padding:4.5rem 5vw 3rem;
  background:
    radial-gradient(circle at 15% 20%, rgba(255,255,255,.45), transparent 24%),
    radial-gradient(circle at 80% 18%, rgba(232,160,32,.16), transparent 18%),
    linear-gradient(135deg, #d9ead7 0%, #eff5e5 52%, #f8f9ee 100%);
}
.newsletter-hero::before,
.newsletter-hero::after{
  content:"";
  position:absolute;
  border-radius:50%;
  pointer-events:none;
  filter:blur(0.5px);
  opacity:.9;
}
.newsletter-hero::before{
  width:240px;height:240px;
  right:-70px;top:-55px;
  background:radial-gradient(circle, rgba(255,255,255,.7), rgba(255,255,255,0) 68%);
}
.newsletter-hero::after{
  width:180px;height:180px;
  left:-50px;bottom:-40px;
  background:radial-gradient(circle, rgba(45,122,79,.12), rgba(45,122,79,0) 70%);
}
.newsletter-hero-grid{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:2rem;
  align-items:center;
}
.newsletter-hero-copy h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,6vw,5.2rem);
  line-height:.95;
  color:var(--g900);
  margin:.8rem 0 1rem;
}
.newsletter-hero-copy h1 em{font-style:italic;color:var(--g700)}
.newsletter-hero-copy .lead{
  max-width:620px;
  color:rgba(20,35,24,.82);
  font-size:1.05rem;
}
.newsletter-hero-art{
  background:rgba(255,255,255,.52);
  border:1px solid rgba(84,117,86,.16);
  border-radius:32px;
  padding:1rem;
  box-shadow:0 16px 48px rgba(39,64,41,.12);
  backdrop-filter:blur(8px);
}
.newsletter-hero-art img{
  display:block;
  width:100%;
  height:auto;
  border-radius:24px;
  object-fit:cover;
}
.newsletter-pills{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.9rem;
  margin-top:1.4rem;
}
.newsletter-pills div{
  background:rgba(255,255,255,.54);
  border:1px solid rgba(84,117,86,.12);
  border-radius:18px;
  padding:.95rem 1rem;
  box-shadow:0 10px 28px rgba(39,64,41,.06);
}
.newsletter-pills strong{
  display:block;
  color:var(--g900);
  font-family:'Cormorant Garamond',serif;
  font-size:1.25rem;
}
.newsletter-pills span{
  display:block;
  margin-top:.15rem;
  color:var(--muted);
  font-size:.82rem;
}
.newsletter-article{
  background:#f8f6ed;
  padding:2rem 5vw 4rem;
}
.newsletter-post{
  max-width:900px;
  margin:0 auto;
  background:#fff;
  border:1px solid var(--border);
  border-radius:34px;
  box-shadow:0 18px 50px rgba(39,64,41,.08);
  padding:clamp(1.2rem,3vw,2.4rem);
}
.newsletter-post-head{
  max-width:760px;
  margin:0 auto 2rem;
  text-align:left;
}
.newsletter-post-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.02;
  color:var(--g900);
  margin:.65rem 0 1rem;
}
.newsletter-post-head p{
  color:var(--muted);
  font-size:1rem;
}
.newsletter-story-block{
  max-width:760px;
  margin:0 auto 1.9rem;
}
.newsletter-story-block h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;
  color:var(--g900);
  margin:0 0 .75rem;
}
.newsletter-story-block p,
.newsletter-story-block li{
  color:var(--muted);
  font-size:1rem;
  line-height:1.8;
}
.newsletter-story-block ol,
.newsletter-story-block ul{
  margin:.8rem 0 0;
  padding-left:1.2rem;
}
.newsletter-story-block li{margin-bottom:.45rem}
.newsletter-inline-image{
  max-width:760px;
  margin:0 auto 2rem;
  background:#f6f8ef;
  border:1px solid rgba(84,117,86,.12);
  border-radius:28px;
  padding:1rem;
}
.newsletter-inline-image img{
  display:block;
  width:100%;
  height:auto;
  border-radius:22px;
  background:#fff;
}
.newsletter-inline-image p{
  margin:.7rem 0 0;
  font-size:.84rem;
  color:var(--muted);
  text-align:center;
}
.newsletter-contact{
  background:linear-gradient(180deg, rgba(255,249,225,.8), rgba(245,250,238,.9));
  padding:1.1rem 1.2rem;
  border-radius:24px;
  border:1px solid rgba(84,117,86,.12);
}
.newsletter-signup-wrap{
  max-width:1200px;
  margin:0 auto;
  padding:0 5vw 4.5rem;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
  align-items:start;
}
.newsletter-signup-copy{
  background:linear-gradient(160deg, #e8f2df, #f7f4e3);
  border:1px solid rgba(84,117,86,.12);
  border-radius:32px;
  padding:1.6rem;
  box-shadow:0 14px 40px rgba(39,64,41,.08);
}
.newsletter-signup-copy h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3rem);
  line-height:1.05;
  color:var(--g900);
  margin:.6rem 0 .8rem;
}
.newsletter-signup-copy p{color:var(--muted);max-width:560px}
.newsletter-signup-card{
  background:#fff;
  border-radius:32px;
  border:1px solid var(--border);
}
@media (max-width:980px){
  .newsletter-hero-grid,.newsletter-signup-wrap{grid-template-columns:1fr}
  .newsletter-pills{grid-template-columns:1fr}
}
@media (max-width:640px){
  .newsletter-hero{padding:3.5rem 1rem 2rem}
  .newsletter-article,.newsletter-signup-wrap{padding-left:1rem;padding-right:1rem}
  .newsletter-post{border-radius:24px}
}
