
:root{
  --green:#23AB70; --green-deep:#137a4f; --lime:#85C440;
  --pink:#F00561; --pink-dark:#c80050; --navy:#021A38; --ink:#10242f;
  --paper:#fbfdfb; --cloud:#eef6f0; --muted:#5d6f6a; --line:#e4efe8;
  --radius:20px; --shadow:0 18px 40px -18px rgba(2,26,56,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.display{font-family:'Poppins',sans-serif;line-height:1.07;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1180px,92%);margin-inline:auto}
.narrow{width:min(820px,92%);margin-inline:auto}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'Poppins',sans-serif;font-weight:700;font-size:1rem;padding:.95rem 1.7rem;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-pink{background:var(--pink);color:#fff;box-shadow:0 10px 24px -8px rgba(240,5,97,.6)}
.btn-pink:hover{background:var(--pink-dark)}
.btn-green{background:var(--green);color:#fff;box-shadow:0 10px 24px -8px rgba(35,171,112,.6)}
.btn-green:hover{background:var(--green-deep)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-outline{background:#fff;color:var(--navy);border-color:#d9e6dd}
.btn-outline:hover{border-color:var(--green)}
.sm{font-size:.92rem;padding:.6rem 1.2rem}

/* header */
header{position:sticky;top:0;z-index:80;background:rgba(251,253,251,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:1.4rem;padding:.6rem 0}
.nav>a{flex-shrink:0;display:inline-flex;align-items:center}
.logo{height:46px;width:auto;max-width:none;flex-shrink:0;border-radius:6px}
.nav-links{display:flex;gap:1.35rem;margin-left:auto;align-items:center;font-weight:600;font-size:.95rem}
.nav-links>a,.has-drop>span{padding:.5rem 0;color:var(--navy);cursor:pointer;display:inline-block}
.nav-links a:hover,.has-drop:hover>span{color:var(--green)}
.nav-links a.active{color:var(--green)}
.has-drop{position:relative}
.has-drop>span::after{content:" ▾";font-size:.7em;color:var(--muted)}
.drop{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:.5rem;min-width:230px;display:none;flex-direction:column}
.has-drop:hover .drop{display:flex}
.drop a{padding:.6rem .8rem;border-radius:9px;color:var(--navy);white-space:nowrap}
.drop a:hover{background:var(--cloud);color:var(--green-deep)}
.nav-cta{display:flex;gap:.6rem;align-items:center}
.menu-btn{display:none;margin-left:auto;background:none;border:0;font-size:1.7rem;color:var(--navy);cursor:pointer}
#mobile{display:none;background:#fff;border-bottom:1px solid var(--line);padding:.5rem 0 1rem}
#mobile a{display:block;padding:.7rem 0;font-weight:600;color:var(--navy);border-bottom:1px solid var(--line)}
#mobile .sub{padding-left:1rem;color:var(--muted);font-weight:500}

/* hero */
.hero{position:relative;background:radial-gradient(120% 120% at 80% 0%,#0a4d34 0%,var(--navy) 55%);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(240,5,97,.5),transparent 65%);top:-180px;right:-120px}
.hero::after{content:"";position:absolute;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(133,196,64,.42),transparent 65%);bottom:-220px;left:-140px}
.hero-inner{position:relative;z-index:2;padding:5rem 0 5.5rem}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(133,196,64,.18);color:#bdf0a4;font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;padding:.45rem 1rem;border-radius:999px;margin-bottom:1.3rem}
.hero h1{font-size:clamp(2.3rem,5vw,4rem);font-weight:900}
.hero h1 .hl{color:var(--lime)}
.hero p.lede{font-size:1.18rem;color:#cfe0d8;max-width:52ch;margin:1.3rem 0 2rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-card{background:#fff;color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.hero-card img{height:230px;object-fit:cover;width:100%}
.hero-card .body{padding:1.3rem 1.5rem 1.6rem}
.hero-card .tag{color:var(--pink);font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}
.hero-card h3{font-size:1.25rem;margin:.4rem 0 .55rem}
.hero-card a.read{color:var(--green-deep);font-weight:700}

/* page header (interior) */
.phead{background:linear-gradient(160deg,#0a4d34,var(--navy));color:#fff;padding:3.8rem 0 3.4rem;position:relative;overflow:hidden}
.phead::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(240,5,97,.4),transparent 65%);top:-140px;right:-80px}
.phead .eyebrow{position:relative;z-index:2}
.phead h1{position:relative;z-index:2;font-size:clamp(2.1rem,4.2vw,3.3rem);font-weight:900;max-width:20ch}
.phead p{position:relative;z-index:2;color:#cfe0d8;font-size:1.15rem;max-width:60ch;margin-top:1rem}
.phead{padding:4.4rem 0 4rem}
.phead .bgmedia{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.phead .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(115deg,rgba(2,26,56,.9) 0%,rgba(2,26,56,.78) 45%,rgba(10,77,52,.62) 100%)}
.phead.hasmedia::after{display:none}
.phead.hasmedia .wrap{position:relative;z-index:2}
.hero .herobg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero .heroscrim{position:absolute;inset:0;z-index:1;background:radial-gradient(120% 120% at 80% 0%,rgba(10,77,52,.86) 0%,rgba(2,26,56,.92) 60%)}

/* stats band */
.stats{background:var(--green);color:#fff;padding:2.3rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;text-align:center}
.stat .num{font-family:'Poppins';font-weight:900;font-size:clamp(2rem,3.6vw,2.9rem);line-height:1}
.stat .lbl{font-weight:600;opacity:.92;margin-top:.35rem;font-size:.95rem}
.stat{border-right:1px solid rgba(255,255,255,.25)}
.stat:last-child{border-right:0}

/* sections */
section.pad{padding:5rem 0}
section.pad-sm{padding:3.4rem 0}
.sec-head{text-align:center;max-width:680px;margin:0 auto 3rem}
.sec-head.left{text-align:left;margin-left:0}
.kicker{color:var(--pink);font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:.8rem}
.sec-head h2{font-size:clamp(1.9rem,3.5vw,2.8rem);font-weight:800;margin:.55rem 0 .8rem;color:var(--navy)}
.sec-head p{color:var(--muted);font-size:1.08rem}
.cloud{background:var(--cloud)}
.prose{max-width:760px;margin-inline:auto}
.prose h2{color:var(--navy);font-size:1.8rem;margin:2.2rem 0 .8rem}
.prose h3{color:var(--green-deep);font-size:1.25rem;margin:1.6rem 0 .5rem}
.prose p{margin-bottom:1rem;font-size:1.07rem;color:#33433e}
.prose ul{margin:0 0 1.2rem 1.1rem}
.prose li{margin-bottom:.5rem;color:#33433e}
.lead{font-size:1.25rem;color:var(--navy);font-weight:500;line-height:1.5}

/* cards grid */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem}
.card .ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.1rem;background:rgba(35,171,112,.12)}
.card .ico svg{width:28px;height:28px;stroke:var(--green-deep)}
.card.pink .ico{background:rgba(240,5,97,.1)} .card.pink .ico svg{stroke:var(--pink)}
.card.navy .ico{background:rgba(2,26,56,.08)} .card.navy .ico svg{stroke:var(--navy)}
.card h3{color:var(--navy);font-size:1.3rem;margin-bottom:.5rem}
.card p{color:var(--muted)}

/* pillar cards */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pillar{border-radius:var(--radius);padding:2.1rem;color:#fff;position:relative;overflow:hidden}
.pillar.access{background:linear-gradient(160deg,#1aa06a,#137a4f)}
.pillar.tools{background:linear-gradient(160deg,#0a4d34,var(--navy))}
.pillar.agency{background:linear-gradient(160deg,var(--pink),var(--pink-dark))}
.pillar .lab{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:800;opacity:.85}
.pillar h3{font-size:1.6rem;margin:.3rem 0 .7rem}
.pillar p{color:rgba(255,255,255,.92)}
.pillar ul{margin:.5rem 0 0;padding-left:1.15rem;color:rgba(255,255,255,.94)}
.pillar li{margin-bottom:.45rem;line-height:1.4}

/* program feature rows */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin-bottom:1rem}
.feature.rev .media{order:2}
.feature .media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:300px;background:linear-gradient(160deg,var(--green),var(--navy))}
.feature .media img{height:100%;width:100%;object-fit:cover;min-height:300px}
.feature .pill{display:inline-block;background:rgba(240,5,97,.1);color:var(--pink);font-weight:700;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;padding:.35rem .8rem;border-radius:999px;margin-bottom:.9rem}
.feature h2{color:var(--navy);font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:.7rem}
.feature p{color:var(--muted);margin-bottom:1rem;font-size:1.07rem}

/* product cards */
.prod{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.prod .top{height:190px;display:grid;place-items:center;font-size:3rem;overflow:hidden}
.prod .top img{width:100%;height:100%;object-fit:cover}
.prod .top.s1{background:linear-gradient(160deg,#fde7ef,#ffd2e2)}
.prod .top.s2{background:linear-gradient(160deg,#e7f6ec,#cfeede)}
.prod .top.s3{background:linear-gradient(160deg,#fff4d6,#ffe9a8)}
.prod .body{padding:1.4rem 1.5rem 1.6rem}
.prod h3{color:var(--navy);font-size:1.25rem;margin-bottom:.4rem}
.prod p{color:var(--muted);font-size:.98rem}

/* value list */
.values{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.value{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem;border-left:5px solid var(--green)}
.value:nth-child(2n){border-left-color:var(--pink)}
.value .n{font-family:'Poppins';font-weight:800;color:var(--lime);font-size:1.6rem}
.value h3{color:var(--navy);font-size:1.35rem;margin:.2rem 0 .55rem}
.value p{color:var(--muted)}

/* NJI scale */
.njibar{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin:2rem 0}
.njibar .seg{padding:1.2rem 1rem;border-radius:14px;color:#fff;text-align:center}
.njibar .seg .r{font-weight:800;font-family:'Poppins';font-size:1.1rem}
.njibar .seg .s{font-size:.9rem;opacity:.9;margin-top:.2rem}
.seg.s0{background:#9fb0aa} .seg.s1{background:var(--lime)} .seg.s2{background:var(--green)} .seg.s3{background:var(--green-deep)}

/* timeline */
.timeline{border-left:3px solid var(--line);margin-left:8px;padding-left:1.8rem}
.tl{position:relative;margin-bottom:1.8rem}
.tl::before{content:"";position:absolute;left:-2.3rem;top:.35rem;width:14px;height:14px;border-radius:50%;background:var(--pink);border:3px solid #fff;box-shadow:0 0 0 2px var(--pink)}
.tl .ph{font-weight:800;color:var(--pink);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}
.tl h3{color:var(--navy);font-size:1.2rem;margin:.15rem 0 .35rem}
.tl p{color:var(--muted)}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.tm{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.6rem 1.4rem;text-align:center}
.tm .av{width:104px;height:104px;border-radius:50%;margin:0 auto .9rem;background:linear-gradient(160deg,var(--green),var(--navy));color:#fff;display:grid;place-items:center;font-family:'Poppins';font-weight:800;font-size:2rem;overflow:hidden}
.tm .av img{width:100%;height:100%;object-fit:cover}
.tm h4{color:var(--navy);font-size:1.08rem}
.tm span{color:var(--green-deep);font-size:.86rem;font-weight:600}
.tm .aff{display:block;color:var(--muted);font-size:.8rem;font-weight:400;margin-top:.35rem;line-height:1.35}

/* partner chips */
.chips{display:flex;flex-wrap:wrap;gap:.7rem}
.chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.6rem 1.2rem;font-weight:600;color:var(--navy)}
/* logo grids */
.logos{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.logocard{background:#fff;border:1px solid var(--line);border-radius:16px;min-height:150px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.9rem;padding:1.5rem;text-align:center;transition:box-shadow .15s,transform .15s}
.logocard:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.logocard img{max-height:80px;max-width:82%;object-fit:contain}
.logocard .nm{font-size:.82rem;color:var(--muted);font-weight:600;line-height:1.3}
@media(max-width:900px){.logos{grid-template-columns:repeat(2,1fr)}}

/* equity / quote band */
.band{background:linear-gradient(160deg,var(--navy),#06243f);color:#fff}
.band .wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:3rem;align-items:center}
.band h2{font-size:clamp(1.7rem,3vw,2.4rem);font-weight:800}
.band h2 .hl{color:var(--pink)}
.band p{color:#cfe0d8;margin-top:1rem}
.bigquote{text-align:center;max-width:880px;margin-inline:auto}
.bigquote p{font-family:'Poppins';font-weight:700;font-size:clamp(1.5rem,3vw,2.2rem);color:var(--navy);line-height:1.25;letter-spacing:-.02em}
.bigquote .mark{color:var(--lime);font-size:3rem;font-family:'Poppins'}
.bigquote cite{display:block;margin-top:1.2rem;color:var(--muted);font-style:normal;font-weight:600}

/* testimonials */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;align-items:stretch}
.tcard{background:#fff;border-radius:var(--radius);padding:2rem 2rem 1.8rem;border:1px solid var(--line);box-shadow:var(--shadow);position:relative;display:flex;flex-direction:column}
.tcard p{color:#33433e;font-size:1.05rem;line-height:1.6;margin:0 0 1.3rem;flex:1}
.tcard .who{font-weight:700;color:var(--green-deep);font-size:.95rem}
@media(max-width:900px){.tgrid{grid-template-columns:1fr}}

/* photo gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}
.gallery a{display:block;aspect-ratio:1/1;border-radius:12px;overflow:hidden;background:var(--cloud)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;display:block}
.gallery a:hover img{transform:scale(1.07)}
@media(max-width:900px){.gallery{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* video gallery */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.vid{border-radius:14px;overflow:hidden;background:#000;aspect-ratio:16/9;box-shadow:var(--shadow)}
.vid video{width:100%;height:100%;object-fit:contain;display:block;background:#000}
@media(max-width:900px){.vgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.vgrid{grid-template-columns:1fr}}

/* cta band */
.cta-band{background:var(--pink);color:#fff;text-align:center;padding:4.5rem 0}
.cta-band h2{font-size:clamp(2rem,4vw,3rem);font-weight:900}
.cta-band p{font-size:1.13rem;opacity:.95;margin:.8rem auto 2rem;max-width:52ch}
.cta-band .btn-outline{background:#fff;color:var(--pink)}

/* forms */
.formcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2.4rem;box-shadow:var(--shadow)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;color:var(--navy);margin-bottom:.35rem;font-size:.95rem}
.field input,.field select,.field textarea{width:100%;padding:.8rem 1rem;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:1rem;background:var(--paper)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green)}
.embed-note{background:#fff7d6;border:1px dashed #e3cf72;color:#6b5a16;border-radius:12px;padding:1rem 1.2rem;font-size:.92rem;margin-bottom:1.4rem}

/* footer */
footer{background:var(--navy);color:#aebfcf;padding:3.6rem 0 2rem;font-size:.95rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.2rem;margin-bottom:2.4rem}
footer h4{color:#fff;font-size:1rem;margin-bottom:1rem}
footer a{display:block;padding:.22rem 0;color:#aebfcf}
footer a:hover{color:var(--lime)}
.foot-logo{background:#fff;padding:.5rem .7rem;border-radius:8px;display:inline-block;margin-bottom:1rem}
.foot-logo img{height:40px}
.badge501{display:inline-block;border:1px solid rgba(255,255,255,.25);border-radius:8px;padding:.3rem .7rem;color:#cfe0d8;font-weight:600;margin-top:1rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;color:#7e93a6;font-size:.85rem}

@media(max-width:900px){
  .nav-links{display:none}
  .menu-btn{display:block}
  .nav{gap:.8rem}
  .nav-cta .btn-outline{display:none}
  .hero-grid,.grid-2,.grid-3,.pillars,.values,.feature,.band .wrap,.njibar{grid-template-columns:1fr}
  .feature.rev .media{order:0}
  .stats-grid{grid-template-columns:1fr 1fr;gap:1.4rem}
  .stat:nth-child(2){border-right:0}
  .team-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:1.6rem}
  .hero-inner{padding:3.2rem 0 3.6rem}
}
@media(max-width:560px){.team-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr}.stat{border-right:0;border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:1.2rem}.logo{height:38px}}
