/* ─── NUMBERS FOUNDATION — SHARED STYLES ─── */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,wght@0,300;0,600;0,900;1,300;1,600&family=Mulish:wght@300;400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --forest:#0c4a2a;
  --forest-deep:#082a18;
  --leaf:#1fa854;
  --leaf-light:#4ec97d;
  --mint:#c2f0d8;
  --cream:#faf7f2;
  --warm:#f2ebe0;
  --ink:#16120e;
  --ink-60:rgba(22,18,14,.6);
  --ink-30:rgba(22,18,14,.3);
  --gold:#c8872a;
  --gold-warm:#f5c164;
  --white:#fff;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Mulish',sans-serif;
  --radius:6px;
  --shadow:0 4px 32px rgba(0,0,0,.09);
  --shadow-lg:0 12px 56px rgba(0,0,0,.14);
}

html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);overflow-x:hidden;line-height:1.6;padding-top:72px}

/* Grain */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.018;
background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:800;display:flex;align-items:center;
justify-content:space-between;padding:1rem 4rem;height:72px;
background:rgba(8,42,24,.97);backdrop-filter:blur(20px);
border-bottom:1px solid rgba(255,255,255,.06);transition:padding .3s,height .3s}
.nav.scrolled{padding:.65rem 4rem;height:60px}

.logo{display:flex;align-items:center;gap:.85rem;text-decoration:none}
.logo-img{width:42px;height:42px;border-radius:8px;overflow:hidden;
background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-img img{width:100%;height:100%;object-fit:contain}
.logo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
font-family:var(--serif);font-weight:900;font-size:1.15rem;color:var(--leaf-light);letter-spacing:-1px}
.logo-text{color:white;line-height:1.15}
.logo-name{display:block;font-family:var(--serif);font-weight:600;font-size:1.05rem}
.logo-sub{display:block;font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;
color:rgba(255,255,255,.4);margin-top:.1rem}

.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{text-decoration:none;color:rgba(255,255,255,.72);font-size:.82rem;font-weight:500;
letter-spacing:.03em;transition:color .2s}
.nav-links a:hover{color:white}
.nav-links a.active{color:var(--leaf-light)}
.nav-links a.btn-nav{background:var(--gold);color:white!important;padding:.48rem 1.25rem;
border-radius:4px;font-weight:700;transition:background .2s,transform .2s}
.nav-links a.btn-nav:hover{background:#b07424;transform:translateY(-1px)}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;background:none;border:none}
.hamburger span{width:24px;height:2px;background:white;border-radius:2px;transition:.3s;display:block}
.mobile-menu{display:none;position:fixed;top:72px;left:0;right:0;z-index:799;
background:rgba(8,42,24,.98);backdrop-filter:blur(20px);padding:1.5rem 2rem;
flex-direction:column;gap:1.25rem;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-menu.open{display:flex}
.mobile-menu a{text-decoration:none;color:rgba(255,255,255,.8);font-size:.95rem;font-weight:500;
padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.mobile-menu a.btn-nav{background:var(--gold);color:white;padding:.75rem 1.25rem;
border-radius:4px;text-align:center;border:none;margin-top:.5rem}

/* ── BUTTONS ── */
.btn-primary{background:var(--leaf);color:white;padding:.88rem 2rem;border-radius:4px;
text-decoration:none;font-weight:700;font-size:.88rem;display:inline-block;
transition:background .2s,transform .2s,box-shadow .2s;
box-shadow:0 4px 24px rgba(31,168,84,.4)}
.btn-primary:hover{background:#198a44;transform:translateY(-2px);box-shadow:0 8px 32px rgba(31,168,84,.5)}
.btn-secondary{border:2px solid rgba(255,255,255,.3);color:rgba(255,255,255,.88);
padding:.86rem 2rem;border-radius:4px;text-decoration:none;font-weight:500;
font-size:.88rem;display:inline-block;transition:all .2s}
.btn-secondary:hover{border-color:white;background:rgba(255,255,255,.07)}
.btn-gold{background:var(--gold);color:white;padding:.88rem 2rem;border-radius:4px;
text-decoration:none;font-weight:700;font-size:.88rem;display:inline-block;
transition:all .2s;box-shadow:0 4px 24px rgba(200,135,42,.35)}
.btn-gold:hover{background:#b07424;transform:translateY(-2px)}
.btn-outline-green{border:2px solid var(--leaf);color:var(--leaf);padding:.72rem 1.75rem;
border-radius:4px;text-decoration:none;font-weight:700;font-size:.85rem;
transition:all .2s;display:inline-block;white-space:nowrap}
.btn-outline-green:hover{background:var(--leaf);color:white}

/* ── SECTION HELPERS ── */
.eyebrow{display:inline-flex;align-items:center;gap:.65rem;font-size:.68rem;font-weight:700;
letter-spacing:.22em;text-transform:uppercase;color:var(--leaf);margin-bottom:1rem}
.eyebrow::before{content:'';width:28px;height:2px;background:var(--leaf);border-radius:2px}
.eyebrow.light{color:var(--mint)}
.eyebrow.light::before{background:var(--mint)}

.section-h{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:900;
line-height:1.08;color:var(--ink)}
.section-h em{font-style:italic;color:var(--forest);font-weight:300}
.section-h.light{color:white}
.section-h.light em{color:var(--leaf-light)}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .75s ease,transform .75s ease}
.reveal.in{opacity:1;transform:none}

/* ── PAGE HERO BASE ── */
.page-hero{min-height:52vh;padding:7rem 4rem 5rem;display:flex;align-items:center;
background:linear-gradient(135deg,var(--forest-deep),var(--forest));position:relative;overflow:hidden}
.page-hero-inner{max-width:1100px;margin:0 auto;width:100%;
display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.page-hero h1{font-family:var(--serif);font-size:clamp(2.5rem,5vw,4.2rem);font-weight:900;
color:white;line-height:1.06;margin-bottom:1rem}
.page-hero h1 em{font-style:italic;color:var(--leaf-light);font-weight:300}
.page-hero p{font-size:1rem;color:rgba(255,255,255,.62);line-height:1.8;max-width:460px}
.ph-photo{border-radius:14px;overflow:hidden;box-shadow:0 16px 64px rgba(0,0,0,.4);aspect-ratio:4/3}
.ph-photo img{width:100%;height:100%;object-fit:cover;filter:brightness(.8)}

/* ── IMPACT STRIP ── */
.impact-strip{background:var(--forest-deep);display:flex;justify-content:space-around;
align-items:center;padding:2rem 4rem;flex-wrap:wrap;gap:2rem}
.is-item{text-align:center}
.is-num{font-family:var(--serif);font-size:2.2rem;font-weight:900;color:var(--leaf-light);line-height:1}
.is-lbl{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.42);margin-top:.3rem}
.is-sep{width:1px;height:44px;background:rgba(255,255,255,.07)}

/* ── CARDS ── */
.mv-item{background:var(--cream);border-radius:8px;padding:1.5rem;
border-left:3px solid var(--leaf);transition:transform .3s,box-shadow .3s}
.mv-item:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.mv-icon{font-size:1.4rem;margin-bottom:.6rem}
.mv-item h4{font-family:var(--serif);font-size:.95rem;font-weight:600;color:var(--forest);margin-bottom:.4rem}
.mv-item p{font-size:.8rem;color:var(--ink-60);line-height:1.65}

/* ── FOOTER ── */
footer{background:var(--forest-deep);color:white;padding:5.5rem 4rem 2.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:4rem;
padding-bottom:3.5rem;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:2rem}
.footer-brand .fb-logo{font-family:var(--serif);font-size:1.4rem;font-weight:700;margin-bottom:.75rem}
.footer-brand p{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.8;max-width:270px;margin-bottom:1.25rem}
.footer-reg{font-size:.68rem;color:rgba(255,255,255,.25);font-weight:600;letter-spacing:.08em}
.social-row{display:flex;gap:.6rem;margin-top:1.25rem}
.soc{width:34px;height:34px;border-radius:6px;background:rgba(255,255,255,.07);
display:flex;align-items:center;justify-content:center;font-size:.82rem;
text-decoration:none;color:rgba(255,255,255,.55);transition:all .2s}
.soc:hover{background:var(--leaf);color:white}
.footer-col h5{font-size:.63rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
color:var(--mint);margin-bottom:1.25rem;opacity:.75}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.6rem}
.footer-col a{text-decoration:none;color:rgba(255,255,255,.48);font-size:.82rem;transition:color .2s}
.footer-col a:hover{color:white}
.contact-line{display:flex;gap:.65rem;margin-bottom:.75rem;align-items:flex-start}
.ci{font-size:.9rem;flex-shrink:0;margin-top:.05rem}
.ct{font-size:.8rem;color:rgba(255,255,255,.45);line-height:1.5}
.ct a{color:rgba(255,255,255,.45);text-decoration:none;transition:color .2s}
.ct a:hover{color:white}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:.7rem;color:rgba(255,255,255,.25)}

/* ── CHART BARS ── */
.bar-group{margin-bottom:1.5rem}
.bg-label{font-size:.78rem;font-weight:600;color:var(--ink);margin-bottom:.5rem;
display:flex;justify-content:space-between}
.bg-change{font-size:.7rem;font-weight:700;color:var(--leaf)}
.bg-change.down{color:#e06060}
.dbl-bar{display:flex;flex-direction:column;gap:.32rem}
.dbl-row{display:flex;align-items:center;gap:.75rem}
.dbl-lbl{font-size:.65rem;width:110px;color:var(--ink-60);flex-shrink:0}
.dbl-track{flex:1;height:9px;background:rgba(0,0,0,.07);border-radius:100px;overflow:hidden}
.dbl-fill{height:100%;border-radius:100px;width:0;transition:width 1.4s ease}
.dbl-val{font-size:.65rem;width:32px;text-align:right;color:var(--ink-60);font-weight:600;flex-shrink:0}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .nav{padding:1rem 1.5rem}
  .nav.scrolled{padding:.65rem 1.5rem}
  .nav-links{display:none}
  .hamburger{display:flex}
  .page-hero{padding:5rem 1.5rem 3.5rem}
  .page-hero-inner{grid-template-columns:1fr}
  .ph-photo{display:none}
  .impact-strip{padding:1.75rem 1.5rem}
  .is-sep{display:none}
  footer{padding:3.5rem 1.5rem 2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
}
@media(max-width:520px){
  .footer-grid{grid-template-columns:1fr}
}
