@import url('https://fonts.googleapis.com/css2?family=Faustina:ital,wght@0,400;0,600;0,700;1,400&family=Open+Sans:wght@300;400;600;700&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  line-height: 2em;        /* from .et_pb_text_0: line-height:2em */
  color: #666;
  background: #fff;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }
ul { padding-left: 1.5rem; }

/* ══════════════════════════════════════
   EXACT COLOURS FROM DIVI CSS INSPECTION
   ══════════════════════════════════════
   #065c2e — nav bar, section bg, box border
   #0e7162 — headings (h1,h2 teal)
   #26c699 — links, green button, accents
   #f3cc2d — gold/yellow button
   #f7f9f9 — light grey section bg
   #ffffff — white card bg
*/
:root {
  --dark-green:  #065c2e;   /* nav, section backgrounds, box borders */
  --teal:        #0e7162;   /* all headings */
  --mint:        #26c699;   /* links, mint button, accents */
  --gold:        #f3cc2d;   /* primary CTA button */
  --bg-light:    #f7f9f9;   /* light section background */
  --white:       #ffffff;
  --text:        #666666;
  --dark:        #333333;
  --shadow:      0px 40px 100px -30px rgba(0,0,0,0.22); /* exact from CSS */
}

/* ══ NAV ══════════════════════════════ */
.site-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: var(--dark-green);  /* #065c2e */
  display: flex; align-items: center; justify-content: space-between;
  padding: 60px 40px; height: 66px;
}
.nav-logo img { height: 60px; }
.nav-links { display: flex; align-items: center; list-style: none; }
.nav-links li a {
  display: block; padding: 0 20px; height: 66px; line-height: 66px;
  color: #FFFFFF;  /* exact: #FFFFFF */
  font-size: 16px; /* exact: font-size:16px */
  transition: background 0.3s;
}
.nav-links li a:hover,
.nav-links li a.active { background: rgba(0,0,0,0.15); }
.nav-links .nav-cta a {
  background: var(--gold);  /* #f3cc2d */
  color: #000000 !important;  /* exact: color:#000000 */
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 13px 48px;  /* exact: padding-top/bottom:13px, left/right:48px */
  height: auto; line-height: normal; margin: auto 0;
}
.nav-links .nav-cta a:hover { background: #e0b820; }

.hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer;
}
.hamburger span { width: 25px; height: 2px; background: var(--gold); display: block; }
.mob-menu {
  display: none; position: fixed; top: 66px; left: 0; right: 0;
  background: var(--dark-green); z-index: 999; flex-direction: column;
}
.mob-menu.open { display: flex; }
.mob-menu a {
  padding: 14px 20px; color: #fff; font-size: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.mob-menu .mob-cta { background: var(--gold); color: #000 !important; font-weight: 700; }

/* ══ PAGE ═════════════════════════════ */
.page { padding-top: 66px; }

/* ══ HEADINGS — Faustina, teal (#0e7162) ══ */
h1, h2, h3, h4 {
  font-family: 'Faustina', Georgia, "Times New Roman", serif;
  color: var(--teal);  /* #0e7162 */
  font-weight: 600;
  line-height: 1.4em;
}

/* ══ HERO — FULL WIDTH PHOTO with dark overlay ══ */
/* From fullwidth_header module in Divi */
.page-hero {
  position: relative; min-height: 500px;
  display: flex; align-items: center;
  overflow: hidden;
  padding: 10vw 0;  /* exact: padding-top/bottom:10vw */
}
.page-hero img.bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
}
.page-hero .dim {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.5);
}
.page-hero-inner {
  position: relative; z-index: 1;
  max-width: 1080px; margin: 0 auto;
  padding: 0 40px; width: 100%;
}
.page-hero h1 {
  font-family: 'Faustina', Georgia, "Times New Roman", serif;
  font-size: 60px;  /* exact: font-size:60px */
  font-weight: 600;
  color: #FFFFFF !important;  /* exact */
  line-height: 1.3em;  /* exact */
  margin-bottom: 20px;
}
.page-hero p {
  font-family: 'Open Sans', sans-serif;
  font-size: 17px; color: rgba(255,255,255,0.88);
  line-height: 2em; max-width: 600px; margin-bottom: 30px;
}

/* ══ SECTIONS ════════════════════════ */
.section     { padding: 80px 40px; }
.section.bg-light { background: var(--bg-light); }  /* #f7f9f9 */
.section.bg-dark  { background: var(--dark-green); }
.inner    { max-width: 1080px; margin: 0 auto; }
.inner-sm { max-width: 800px; margin: 0 auto; }

/* Section headings */
.sec-h2 {
  font-family: 'Faustina', Georgia, "Times New Roman", serif;
  font-size: 42px;  /* exact: font-size:42px */
  font-weight: 600;
  color: var(--teal) !important;  /* #0e7162 */
  line-height: 1.4em;
  margin-bottom: 15px;
}
.sec-h2.white { color: #FFFFFF !important; }
.sec-h3 {
  font-family: 'Faustina', Georgia, "Times New Roman", serif;
  font-size: 26px;  /* from blurb h3: 26px */
  font-weight: 600;
  color: var(--teal) !important;
  line-height: 1.4em; margin-bottom: 12px;
}
.sec-h3.sm { font-size: 18px; }

.sec-text {
  font-size: 17px;  /* from et_pb_text_1: font-size:20px */
  color: var(--text); line-height: 2em;
  font-family: 'Faustina', Georgia, "Times New Roman", serif;
}
.sec-text a { color: var(--mint) !important; font-weight: 700; }

/* ══ BUTTONS ══════════════════════════ */
/* Gold button — exact from CSS: #f3cc2d, color:#000, uppercase, letter-spacing:1px */
.btn-gold {
  display: inline-block;
  background-color: #f3cc2d;
  color: #000000 !important;
  border: none; letter-spacing: 1px;
  font-size: 14px; font-weight: 700 !important;
  text-transform: uppercase !important;
  padding: 13px 48px;  /* exact */
  cursor: pointer; font-family: 'Open Sans', sans-serif;
  transition: all 300ms ease 0ms;  /* exact */
}
.btn-gold:hover { background: #e0b820; }

/* Mint/green button — exact: #26c699 */
.btn-mint {
  display: inline-block;
  background-color: #26c699;
  color: #ffffff !important;
  border: none; letter-spacing: 1px;
  font-size: 14px; font-weight: 700 !important;
  text-transform: uppercase !important;
  padding: 12px 30px;
  cursor: pointer; font-family: 'Open Sans', sans-serif;
  transition: all 300ms ease 0ms;
}
.btn-mint:hover { background: #1fa882; }

/* Outline button — exact: color:#065c2e, border:#26c699, 1px */
.btn-outline {
  display: inline-block;
  color: #065c2e !important;
  border: 1px solid #26c699;
  background: rgba(38,198,153,0);  /* exact */
  font-size: 14px; font-weight: 600 !important;
  padding: 12px 28px;
  cursor: pointer; font-family: 'Open Sans', sans-serif;
  transition: all 300ms ease 0ms;
}
.btn-outline:hover { background: #26c699; color: #fff !important; }

/* ══ THE SIGNATURE BORDERED BOX ═══════
   EXACT FROM CSS:
   border-width: 20px
   border-color: #065c2e
   border-radius: 3px
   box-shadow: 0px 40px 100px -30px rgba(0,0,0,0.22)
   background: #ffffff
   padding: 30px
*/
.divi-box {
  background-color: #ffffff;
  border-radius: 3px;
  border-style: solid;
  border-width: 20px;         /* EXACT: 20px */
  border-color: #065c2e;      /* EXACT: #065c2e */
  padding: 30px;              /* EXACT */
  box-shadow: 0px 40px 100px -30px rgba(0,0,0,0.22);  /* EXACT */
  overflow: hidden;
}
.divi-box h3, .divi-box h4 {
  font-family: 'Faustina', Georgia, "Times New Roman", serif;
  font-weight: 600; color: var(--teal);
  margin-bottom: 12px;
}
.divi-box p, .divi-box ul { font-size: 14px; color: var(--text); line-height: 2em; }

/* Dark green filled box */
.divi-box.filled {
  background-color: var(--dark-green);
  border-color: var(--dark-green);
}
.divi-box.filled h3,
.divi-box.filled h4 { color: #fff; }
.divi-box.filled p,
.divi-box.filled ul { color: rgba(255,255,255,0.88); }

/* ══ WHITE CARD WITH SHADOW ═══════════
   From et_pb_row_3/4/5:
   background:#fff, box-shadow same
*/
.divi-card {
  background-color: #ffffff;
  border-radius: 3px;
  box-shadow: 0px 40px 100px -30px rgba(0,0,0,0.22);
  padding: 40px;
}

/* ══ BLURB / ICON CARD (from PDF value cards) ══
   background:#fff, border-width:5px, border-color:rgba(255,255,255,0)
   box-shadow same
*/
.divi-blurb {
  background-color: #ffffff;
  border-radius: 3px;
  padding: 20px;
  box-shadow: 0px 40px 100px -30px rgba(0,0,0,0.22);
  text-align: center;
}
.divi-blurb .blurb-icon { font-size: 32px; margin-bottom: 12px; }
.divi-blurb h3 {
  font-family: 'Faustina', Georgia, serif;
  font-size: 16px; font-weight: 700;  /* exact: 16px, 700 */
  color: var(--teal); line-height: 2em; margin-bottom: 5px;
}
.divi-blurb p { font-size: 14px; color: var(--text); line-height: 2em; }

/* ══ GRID ════════════════════════════ */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 30px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.grid-half { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }

/* ══ CAUSE / PROGRAM ITEMS ═══════════ */
.cause-row { display: flex; flex-direction: column; gap: 0; }
.cause-item {
  display: grid; grid-template-columns: 220px 1fr;
  gap: 30px; padding: 35px 0;
  border-bottom: 1px solid #e8e8e8; align-items: start;
}
.cause-item img { width: 220px; height: 150px; object-fit: cover; border-radius: 3px; }
.cause-item h3 {
  font-family: 'Faustina', Georgia, serif;
  font-size: 20px; font-weight: 600; color: var(--teal);
  margin-bottom: 8px; line-height: 1.4em;
}
.cause-item p { font-size: 14px; color: var(--text); line-height: 2em; margin-bottom: 10px; }
.cause-item .donated {
  font-size: 13px; font-weight: 700; color: var(--mint);
  text-transform: uppercase; letter-spacing: 1px; display: block; margin-bottom: 8px;
}
.cause-item .donate-link {
  font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px;
  color: var(--mint); border-bottom: 1px solid var(--mint);
  padding-bottom: 1px; display: inline-block; transition: all 0.3s;
}

/* ══ STATS ════════════════════════════ */
.stats-wrap { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin: 30px 0; }
.stat-card {
  background: #fff;
  box-shadow: 0px 40px 100px -30px rgba(0,0,0,0.22);
  padding: 30px; text-align: center; border-radius: 3px;
}
.stat-card .num {
  font-family: 'Faustina', Georgia, serif;
  font-size: 42px; font-weight: 600;  /* exact: 42px */
  color: var(--teal); line-height: 1; margin-bottom: 8px;
}
.stat-card .lbl {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: #999;
}

/* ══ SPLIT SECTION ════════════════════ */
.split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.split-img  { position: relative; min-height: 480px; overflow: hidden; }
.split-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.split-text { padding: 80px; display: flex; flex-direction: column; justify-content: center; background: #fff; }

/* ══ CONTACT / FOOTER BAND ════════════ */
.footer-band { background: var(--dark-green); padding: 80px 40px; }
.footer-band-inner {
  max-width: 1080px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: 60px; align-items: center; justify-items: center; /* centers items horizontally */
  text-align: center;
}
.footer-band h2 {
  font-family: 'Faustina', Georgia, serif;
  font-size: 42px; font-weight: 600; color: #fff;
  line-height: 1.3em; margin-bottom: 15px;
}
.footer-band p { color: rgba(255,255,255,0.82); font-size: 14px; line-height: 2em; margin-bottom: 20px; }
.footer-contact-item { display: flex; gap: 14px; align-items: flex-start; margin-bottom: 12px; }
.footer-contact-item .icon { color: var(--mint); font-size: 16px; flex-shrink: 0; margin-top: 3px; }
.footer-contact-item span, .footer-contact-item a {
  color: rgba(255,255,255,0.85); font-size: 14px; font-weight: 600;
}
.footer-contact-item a:hover { color: var(--mint); }
.footer-social { display: flex; gap: 10px; margin-top: 20px; }
.footer-social a {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.3);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.65); font-size: 13px; font-weight: 700; transition: all 0.3s;
}
.footer-social a:hover { background: var(--mint); border-color: var(--mint); color: #fff; }

/* Form inside dark footer */
.footer-form {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.15);
  padding: 40px;
}
.footer-form p { color: rgba(255,255,255,0.8); font-size: 14px; line-height: 2em; margin-bottom: 20px; }
.f-input {
  width: 100%; background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.2);
  color: #fff; padding: 13px 16px; font-size: 14px;
  font-family: 'Open Sans', sans-serif; margin-bottom: 12px; transition: border 0.3s;
}
.f-input::placeholder { color: rgba(255,255,255,0.4); }
.f-input:focus { outline: none; border-color: var(--mint); }
textarea.f-input { min-height: 100px; resize: vertical; }
.f-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.f-submit { display: flex; justify-content: flex-end; margin-top: 8px; }

/* ══ MAIN FOOTER ══════════════════════ */
.main-footer { background: #065c2e; padding: 60px 40px 25px; }
.mf-inner {
  max-width: 1080px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px; padding-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,0.06);
}
.mf-brand img { height: 44px; margin-bottom: 15px; opacity: 0.85; }
.mf-brand p { font-size: 13px; color: #e4d4d4c2; line-height: 1.8em; max-width: 230px; }
.mf-col h4 { color: #fff; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 15px; font-family: 'Open Sans', sans-serif; }
.mf-col ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.mf-col ul a { color: #e4d4d4c2; font-size: 13px; transition: color 0.3s; }
.mf-col ul a:hover { color: var(--mint); }
.mf-social { display: flex; gap: 15px; margin-top: 15px; }
.mf-social a { color: rgba(255,255,255,0.4); font-size: 14px; font-weight: 700; transition: color 0.3s; }
.mf-social a:hover { color: var(--mint); }
.mf-bottom {
  max-width: 1080px; margin: 20px auto 0;
  display: flex; justify-content: space-between;
  font-size: 12px; color: rgba(255,255,255,0.3); flex-wrap: wrap; gap: 8px;
}
.mf-bottom a { color: rgba(255,255,255,0.3); }
.mf-bottom a:hover { color: var(--mint); }

/* ══ TABS ════════════════════════════ */
.tabs-nav { display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 30px; }
.tab-btn {
  padding: 10px 22px; background: var(--bg-light); border: 1px solid #ddd;
  color: var(--text); font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 1px; cursor: pointer; font-family: 'Open Sans', sans-serif; transition: all 0.3s;
}
.tab-btn.active, .tab-btn:hover { background: var(--dark-green); color: #fff; border-color: var(--dark-green); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* ══ BLOG CARDS ══════════════════════ */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 25px; }
.blog-card { background: #fff; box-shadow: 0px 40px 100px -30px rgba(0,0,0,0.22); }
.blog-card img { width: 100%; height: 190px; object-fit: cover; }
.blog-body { padding: 25px; }
.blog-tag { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: var(--mint); margin-bottom: 8px; display: block; }
.blog-body h3 { font-family: 'Faustina', Georgia, serif; font-size: 18px; color: var(--teal); margin-bottom: 10px; font-weight: 600; line-height: 1.4em; }
.blog-body p { font-size: 13px; color: var(--text); line-height: 1.8em; }
.blog-body .more { color: var(--mint); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-top: 14px; display: inline-block; border-bottom: 1px solid var(--mint); }

/* ══ FAQ ══════════════════════════════ */
.faq-list { display: flex; flex-direction: column; gap: 8px; }
details.faq { background: #fff; border: 1px solid #e8e8e8; box-shadow: 0px 10px 30px -10px rgba(0,0,0,0.1); }
details.faq summary { padding: 16px 20px; font-weight: 600; font-size: 14px; color: var(--teal); cursor: pointer; list-style: none; display: flex; justify-content: space-between; }
details.faq summary::after { content: '+'; color: var(--mint); font-size: 20px; font-weight: 300; }
details.faq[open] summary::after { content: '−'; }
details.faq > p { padding: 0 20px 16px; font-size: 13px; color: var(--text); line-height: 1.8em; }

/* ══ TOAST ════════════════════════════ */
.toast {
  position: fixed; bottom: 25px; right: 25px; z-index: 9999;
  background: var(--mint); color: #fff; font-weight: 700; font-size: 13px;
  padding: 14px 22px; box-shadow: 0px 40px 100px -30px rgba(0,0,0,0.22);
  transform: translateY(80px); opacity: 0; transition: all 0.35s;
}
.toast.show { transform: translateY(0); opacity: 1; }

/* ══ RESPONSIVE ════════════════════════ */
@media (max-width: 980px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .grid-2, .grid-3, .grid-4,
  .split-grid, .footer-band-inner, .mf-inner { grid-template-columns: 1fr; }
  .split-img { min-height: 300px; }
  .split-img img { position: relative; inset: auto; width: 100%; height: 300px; object-fit: cover; }
  .split-text { padding: 50px 30px; }
  .cause-item { grid-template-columns: 1fr; }
  .cause-item img { width: 100%; height: 200px; }
  .stats-wrap { grid-template-columns: 1fr 1fr; }
  .f-row { grid-template-columns: 1fr; }
  .section { padding: 60px 20px; }
  .footer-band { padding: 60px 20px; }
  .page-hero h1 { font-size: 38px; }
  .sec-h2 { font-size: 28px; }
  .blog-grid { grid-template-columns: 1fr 1fr; }
  .page-hero-inner { padding: 0 20px; }
  .main-footer { padding: 50px 20px 20px; }
}
@media (max-width: 560px) {
  .stats-wrap { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .mf-bottom { flex-direction: column; text-align: center; }
  .page-hero h1 { font-size: 30px; }
}
