
  :root{
    --bg:#f4f7f5;
    --card:#ffffff;
    --text:#102018;
    --muted:#50665a;
    --line:#d8e1db;
    --accent:#1f6f4a;
    --btn:#1f6f4a;
    --btnText:#ffffff;
    --band:#eef3ef;
    --shadow:0 10px 30px rgba(16,32,24,.06);
    --radius:22px;
  }

  html{
    color-scheme: light;
  }
   
  *{ box-sizing:border-box; }

  html{ scroll-behavior:smooth; }

  body{
    margin:0;
    font-family:system-ui,-apple-system,Segoe UI,sans-serif;
    background:var(--bg);
    color:var(--text);
    line-height:1.55;
  }

  a{ color:inherit; }

  .wrap{
    max-width:980px;
    margin:0 auto;
    padding:0 24px;
  }

  /* ===== SHARED SITE NAV ===== */

  .siteNav{
    position:sticky;
    top:0;
    z-index:50;
    backdrop-filter:blur(8px);
    background:rgba(244,247,245,.92);
    border-bottom:1px solid rgba(16,32,24,.08);
  }

  .siteNavInner{
    max-width:1040px;
    margin:0 auto;
    padding:0 18px;
    min-height:64px;
    display:grid;
    grid-template-columns:auto 1fr auto;
    align-items:center;
    gap:18px;
  }

  .siteBrand{
    display:inline-flex;
    align-items:center;
    gap:12px;
    text-decoration:none;
    color:var(--text);
    font-weight:900;
    font-size:17px;
    letter-spacing:-0.02em;
    white-space:nowrap;
  }

  .siteBrand img{
    width:30px;
    height:30px;
    display:block;
  }

  .siteNavLinks{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:10px;
  }

  .siteNavLink{
    text-decoration:none;
    color:var(--muted);
    font-weight:750;
    font-size:14px;
    padding:8px 10px;
    border-radius:12px;
    white-space:nowrap;
  }

  .siteNavLink:hover{
    background:rgba(31,111,74,.06);
    color:var(--accent);
  }

  .siteNavActions{
    display:flex;
    align-items:center;
    gap:10px;
  }

  .siteNavCta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:0 18px;
    border-radius:16px;
    background:var(--accent);
    color:#fff;
    font-weight:900;
    font-size:15px;
    text-decoration:none;
    white-space:nowrap;
    border:1px solid transparent;
  }

  .siteNavCta:hover{
    background:#185c3d;
    color:#fff;
  }

  .menuToggle{
    display:none;
    width:44px;
    height:44px;
    border:1px solid rgba(31,111,74,.22);
    border-radius:14px;
    background:#fff;
    padding:0;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:4px;
    cursor:pointer;
  }

  .menuToggle span{
    width:18px;
    height:2px;
    background:var(--text);
    border-radius:999px;
    display:block;
  }

  .mobileMenu{
    display:none;
    max-width:1040px;
    margin:0 auto;
    padding:0 18px 16px;
  }

  .mobileMenu.open{
    display:block;
  }

  .mobileMenuLink,
  .mobileMenuCta{
    display:block;
    text-decoration:none;
    border-radius:14px;
    padding:14px 16px;
    margin-top:10px;
    font-weight:750;
  }

  .mobileMenuLink{
    background:#fff;
    color:var(--text);
    border:1px solid var(--line);
  }

  .mobileMenuCta{
    background:var(--accent);
    color:#fff;
    font-weight:900;
  }

  /* ===== SHARED HERO ===== */

  .heroTop{
    position:relative;
    overflow:hidden;
    padding-top:24px;
    padding-bottom:14px;
  }

  .heroField{
    position:absolute;
    inset:-60px -8% auto -8%;
    height:280px;
    z-index:0;
    pointer-events:none;
    opacity:.58;
    background:
      radial-gradient(circle at 49% 11%, rgba(31,111,74,.13), transparent 16%),
      radial-gradient(circle at 43% 21%, rgba(31,111,74,.10), transparent 20%),
      radial-gradient(circle at 58% 23%, rgba(31,111,74,.09), transparent 19%),
      radial-gradient(circle at 47% 34%, rgba(31,111,74,.06), transparent 27%),
      radial-gradient(circle at 56% 37%, rgba(31,111,74,.05), transparent 25%);
    filter:blur(20px);
    transform:translateY(-8px);
  }

  .heroIntro{
    position:relative;
    z-index:1;
    max-width:860px;
    margin:0 auto;
    text-align:center;
  }

  .heroMark{
    display:flex;
    justify-content:center;
    margin:0 auto 18px;
  }

  .heroMark img{
    width:72px;
    height:72px;
    display:block;
  }

  .eyebrow{
    display:inline-block;
    margin:0 0 12px;
    font-size:13px;
    font-weight:800;
    letter-spacing:.05em;
    text-transform:uppercase;
    color:var(--accent);
  }

  h1{
    font-size:clamp(38px,5vw,58px);
    line-height:1.02;
    letter-spacing:-0.03em;
    margin:0 0 14px;
    font-weight:900;
    text-align:center;
  }

  h2{
    font-size:clamp(28px,3vw,36px);
    line-height:1.1;
    margin:0 0 14px;
    font-weight:850;
    letter-spacing:-0.02em;
    text-align:center;
  }

  h3{
    font-size:22px;
    margin:0 0 10px;
    font-weight:800;
  }

  p{
    margin:0 0 18px;
    font-size:18px;
    color:var(--muted);
  }

  strong{ color:var(--text); }

  .lede{
    font-size:22px;
    max-width:760px;
    margin:0 auto 18px;
    color:var(--muted);
    line-height:1.45;
  }

  .heroSupport,
  .sectionIntro{
    max-width:760px;
    margin:0 auto 18px;
    font-size:18px;
    color:var(--muted);
    text-align:center;
  }

  .powerLine{
    margin:28px auto 12px;
    max-width:760px;
    text-align:center;
    font-size:20px;
    line-height:1.35;
    font-weight:850;
    letter-spacing:-0.01em;
    color:var(--text);
  }

  /* ===== SHARED BUTTONS ===== */

  .ctaRow{
    display:flex;
    gap:14px;
    justify-content:center;
    flex-wrap:wrap;
    margin-top:28px;
  }

  .btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:14px 22px;
    border-radius:16px;
    font-weight:800;
    text-decoration:none;
    font-size:16px;
    border:1px solid transparent;
    min-height:52px;
  }

  .primary{
    background:var(--accent);
    color:#fff;
  }

  .primary:hover{
    background:#185c3d;
    color:#fff;
  }

  .secondary{
    border:1px solid rgba(31,111,74,.3);
    color:var(--accent);
    background:transparent;
  }

  .secondary:hover{
    background:rgba(31,111,74,.06);
  }

  /* ===== SHARED CONTENT BLOCKS ===== */

  .section{
    margin-top:56px;
  }

  .band{
    background:var(--band);
    border:1px solid var(--line);
    border-radius:28px;
    box-shadow:var(--shadow);
    padding:28px 24px;
    margin-top:28px;
  }

  .grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:18px;
    margin-top:20px;
  }

  .card{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:20px;
  }

  .card p{
    font-size:16px;
    line-height:1.5;
    margin:0;
  }

  .card h3{
    margin-bottom:12px;
  }

  .pill{
    margin-top:28px;
    text-align:center;
    font-weight:850;
    color:var(--accent);
    font-size:20px;
  }

  .statement{
    margin-top:22px;
    text-align:center;
    font-size:20px;
    line-height:1.35;
    font-weight:850;
    color:var(--text);
  }

  .statement span{
    display:block;
    margin-top:6px;
    font-size:16px;
    font-weight:600;
    color:var(--muted);
  }

  .footerCta{
    margin-top:30px;
    text-align:center;
  }

  /* ===== SHARED SVG / IMAGE WRAPPERS ===== */

  .svgWrap{
    background:#f0f3f1;
    border:1px solid var(--line);
    border-radius:18px;
    overflow:hidden;
    padding:14px;
  }

  .svgWrap img{
    display:block;
    width:100%;
    height:auto;
  }


  .gridWrap{
  max-width:980px;
  margin:0 auto;
  padding:0 18px;
}

.supportGrid{
  gap:14px;
  margin-top:16px;
}

.supportGrid .card{
  padding:18px 18px;
}

.supportGrid .card h3{
  margin-bottom:8px;
  font-size:20px;
}

.supportGrid .card p{
  font-size:15px;
  line-height:1.45;
}


  /* ===== RESPONSIVE ===== */

  @media (max-width:900px){
    .siteNavInner{
      grid-template-columns:auto auto;
      justify-content:space-between;
      padding:0 16px;
    }

    .siteNavLinks{
      display:none;
    }

    .siteNavCta{
      display:none;
    }

    .menuToggle{
      display:inline-flex;
    }
  }

  @media (max-width:760px){
    .wrap{ padding:0 18px 64px; }
    .grid{ grid-template-columns:1fr; }
    p{ font-size:17px; }
    .lede{ font-size:20px; }
    .heroSupport, .sectionIntro{ font-size:17px; }
    .heroTop{ padding-top:0; }
    .heroField{ height:220px; opacity:.52; }
    .heroMark{ margin-bottom:16px; }
    .heroMark img{ width:60px; height:60px; }
    .ctaRow .btn{ width:100%; text-align:center; }
  }

  @media (max-width:520px){
    .siteNavInner{
      min-height:60px;
      padding:0 14px;
      gap:12px;
    }

    .siteBrand{
      font-size:16px;
    }

    .siteBrand img{
      width:28px;
      height:28px;
    }

    .mobileMenu{
      padding:0 14px 14px;
    }

    .powerLine{
      font-size:16px;
      padding:0 10px;
    }
  }
