:root{
  --green-900:#0b3a17;
  --green-800:#0f4a1f;
  --green-700:#145a26;
  --green-200:#cfecc0;
  --ink:#101828;
  --muted:#475467;
  --bg:#ffffff;
  --card:#ffffff;
  --border:rgba(16,24,40,.12);
  --shadow:0 12px 40px rgba(16,24,40,.10);
  --radius:18px;
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background:var(--bg);
  line-height:1.5;
}
a{color:inherit; text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%; display:block}

.container{width:100%; max-width:var(--max); margin:0 auto; padding:0 18px}
.small{font-size:.92rem; color:var(--muted)}
.kicker{font-size:.86rem; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.92)}

.skiplink{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skiplink:focus{
  left:14px; top:12px; width:auto; height:auto; padding:10px 12px;
  background:#fff; border-radius:10px; box-shadow:var(--shadow); z-index:9999;
}

/* ===== Header / Nav ===== */
.siteHeader{
  position:sticky; top:0; z-index:1000;
  background: linear-gradient(180deg, var(--green-900), var(--green-800));
  border-bottom:1px solid rgba(255,255,255,.10);
}
.navBar{
  display:flex; align-items:center; justify-content:space-between;
  gap:14px; padding:14px 0;
}
.brand{
  display:flex; align-items:center; gap:12px; min-width:max-content;
}
.brand img{height:42px; width:auto}

.navLinks{
  display:flex; align-items:center; gap:18px;
  color:#fff;
  font-weight:700;
}
.navLinks a, .navLinks button{
  color:#fff;
  font-weight:800;
  letter-spacing:.01em;
  padding:10px 10px;
  border-radius:12px;
}
.navLinks a:hover, .navLinks button:hover{ background:rgba(255,255,255,.10); text-decoration:none }
.navLinks .active{ background:rgba(255,255,255,.14) }

.navBtn{
  background:transparent; border:0; cursor:pointer; font:inherit;
  display:flex; align-items:center; gap:8px;
}
.chev{width:10px; height:10px; border-right:2px solid rgba(255,255,255,.9); border-bottom:2px solid rgba(255,255,255,.9); transform:rotate(45deg); margin-top:-2px}

.dropdown{position:relative}
.menu{
  position:absolute; top:100%; right:0;
  min-width:260px;
  background:#fff;
  color:var(--ink);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:10px;
  display:none;
}
.dropdown[data-open="true"] .menu{display:block}
.menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  font-weight:700;
  color:var(--ink);
}
.menu a:hover{background:rgba(16,24,40,.06); text-decoration:none}
.menu .menuTitle{
  padding:8px 12px 6px;
  color:var(--muted);
  font-weight:800;
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
}

/* Mobile nav */
.hamburger{
  display:none;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);
  color:#fff;
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  font-weight:900;
}
.hamburger:active{transform:translateY(1px)}
.mobilePanel{
  display:none;
  padding:0 0 16px;
}
.mobilePanelInner{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  padding:10px;
}
.mLink, .mDrop > button{
  width:100%;
  text-align:left;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  padding:12px 12px;
  color:#fff;
  font-weight:900;
  border-radius:14px;
  background:transparent;
  border:0;
  cursor:pointer;
}
.mLink:hover, .mDrop > button:hover{background:rgba(255,255,255,.10); text-decoration:none}
.mDropItems{display:none; padding:6px 6px 10px}
.mDrop[data-open="true"] .mDropItems{display:block}
.mDropItems a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(0,0,0,.06);
  color:#fff;
  font-weight:800;
  margin:6px 0;
}
.mDropItems a:hover{background:rgba(0,0,0,.12); text-decoration:none}

/* ===== Hero ===== */
.hero{
  position:relative;
  width:100%;
  overflow:hidden;
  background: radial-gradient(1200px 420px at 12% 14%, rgba(255,255,255,.55), rgba(255,255,255,0)),
              linear-gradient(90deg, rgba(255,255,255,.65), rgba(255,255,255,0));
}
.hero img{
  width:100%;
  height:clamp(320px, 54vw, 560px);
  object-fit:cover;
  filter:saturate(1.05) contrast(1.02);
}
.heroOverlay{
  position:absolute; inset:0;
  display:flex; align-items:center;
}
.heroCard{
  max-width:680px;
  padding: clamp(16px, 3vw, 28px);
  margin-left: clamp(14px, 4vw, 54px);
  background:rgba(255,255,255,.62);
  border:1px solid rgba(255,255,255,.55);
  backdrop-filter: blur(8px);
  border-radius: 22px;
  box-shadow: 0 18px 60px rgba(16,24,40,.14);
}
.hero h1{
  margin:0 0 10px;
  font-size: clamp(38px, 6.2vw, 78px);
  line-height:1.02;
  letter-spacing:-.03em;
}
.hero p{
  margin:0;
  max-width:60ch;
  font-size: clamp(15px, 2.2vw, 18px);
  color:#1f2a37;
}

/* smaller hero variant */
.hero--small img{ height: clamp(220px, 34vw, 360px) }
.hero--small .heroCard{ max-width:760px }
.hero--small h1{ font-size: clamp(30px, 4.6vw, 56px) }

.section{padding:54px 0}
.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:18px;
}
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow: 0 14px 40px rgba(16,24,40,.08);
  padding:18px;
}
.card h2{margin:0 0 10px; letter-spacing:-.02em}
.card h3{margin:0 0 8px}
.card p{margin:0 0 10px; color:var(--muted)}
.pillRow{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.pill{
  border:1px solid var(--border);
  border-radius:999px;
  padding:6px 10px;
  font-size:.86rem;
  color:var(--muted);
  background:rgba(16,24,40,.02);
}

.twoCol{grid-column:span 6}
.fourCol{grid-column:span 4}
.eightCol{grid-column:span 8}
.full{grid-column:1/-1}

.ctaRow{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  font-weight:900;
  border:1px solid rgba(16,24,40,.16);
  background:#fff;
  cursor:pointer;
}
.btnPrimary{
  background: linear-gradient(180deg, #1d7a2f, #0f4a1f);
  border-color: rgba(255,255,255,.14);
  color:#fff;
}
.btn:hover{text-decoration:none; filter:brightness(1.02)}
.btn:active{transform:translateY(1px)}

/* ===== FAQ ===== */
.faqWrap .card{padding:0}
.faqHead{padding:18px 18px 0}
.faqHead h2{margin:0 0 6px}
.faqList{padding:12px}
.faqItem{
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  margin:10px 0;
  background:#fff;
}
.faqQ{
  width:100%;
  text-align:left;
  background:rgba(16,24,40,.02);
  border:0;
  padding:14px 14px;
  font-weight:900;
  cursor:pointer;
  display:flex; align-items:center; justify-content:space-between;
  gap:14px;
}
.faqA{display:none; padding:0 14px 14px; color:var(--muted)}
.faqItem[data-open="true"] .faqA{display:block}
.faqIcon{
  width:12px; height:12px;
  border-right:2px solid rgba(16,24,40,.55);
  border-bottom:2px solid rgba(16,24,40,.55);
  transform:rotate(45deg);
}
.faqItem[data-open="true"] .faqIcon{transform:rotate(-135deg)}

/* ===== Footer ===== */
.siteFooter{
  border-top:1px solid var(--border);
  background:#fff;
}

/* Banner image with text overlaid */
.footerBanner{
  position:relative;
  overflow:hidden;
  border-top:1px solid rgba(0,0,0,.04);
}
.footerTopImg{
  width:100%;
  height:260px;           /* taller so copy fits on the green band */
  object-fit:cover;
  display:block;
}
.footerOverlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;     /* vertically center text within the banner */
}
.footerInner{
  padding:24px 0;         /* internal spacing inside the overlay */
}
.footerGrid{
  display:grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap:18px;
}

/* Footer type colors for green background */
.siteFooter .footerTitle{font-weight:900; margin:0 0 10px; color:#0b1a10}
.siteFooter .small{color:#12301f}
.siteFooter .footerNote{color:#12301f; margin:10px 0 0}
.siteFooter .footerGrid a{color:#12301f; text-decoration:none}
.siteFooter .footerGrid a:hover{color:#07120b; text-decoration:underline}

/* ===== Forms ===== */
.field{display:flex; flex-direction:column; gap:6px; margin:10px 0}
.field label{font-weight:800}
.field input, .field textarea{
  padding:12px 12px;
  border:1px solid var(--border);
  border-radius:14px;
  font:inherit;
}
.field textarea{min-height:120px; resize:vertical}

/* ===== Responsive ===== */
@media (max-width: 920px){
  .navLinks{display:none}
  .hamburger{display:inline-flex}
  .mobilePanel{display:block}
  .footerGrid{grid-template-columns:1fr}
  .twoCol{grid-column:1/-1}
  .fourCol{grid-column:1/-1}
  .eightCol{grid-column:1/-1}
  .heroCard{margin:0 14px}
}
/* ===== Articles dropdown: 4 across x 4 deep mega menu ===== */
.dropdown-menu.articles-mega{
  /* override any existing flex/row/nowrap behavior */
  display: grid !important;
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  gap: 10px 18px;

  /* sizing */
  width: min(960px, calc(100vw - 24px));
  padding: 14px 14px;

  /* keep it readable */
  white-space: normal !important;
}

.dropdown-menu.articles-mega > li{
  width: auto !important;
}

.dropdown-menu.articles-mega > li > a{
  display: block;
  white-space: normal;         /* allow wrapping */
  line-height: 1.2;
  padding: 10px 10px;
  border-radius: 10px;
}

/* Responsive: collapse to 2 columns on small screens */
@media (max-width: 820px){
  .dropdown-menu.articles-mega{
    grid-template-columns: repeat(2, minmax(160px, 1fr));
  }
}
@media (max-width: 420px){
  .dropdown-menu.articles-mega{
    grid-template-columns: 1fr;
  }
}

