/* ================================================================
   PETRAD AID — about.css
   ----------------------------------------------------------------
   Fixes applied:
   [1] :root moved to top — variables declared before first use
   [2] .mobile a — removed white-space/overflow/text-overflow
   [3] Removed redundant .footer-grid rule at max-width:900px
   [4] .flag-img hidden at max-width:768px
   [5] .cta-btn-gold:hover — explicit color declared
   [+] Hero section lightened
   [+] Location Visualizer styles (World → Africa → Kenya)
   ================================================================ */


/* ================================================================
   FIX 1 — :root moved to the very top
   ================================================================ */
:root {
  --color-primary:      #0f2a7a;
  --color-primary-mid:  #1a3fa0;
  --color-primary-dark: #050f2e;
  --color-primary-deep: #2952c8;
  --color-gold:         #d4a017;
  --color-gold-light:   #f0c040;
  --color-gold-dark:    #b8860b;
  --color-text:         #1a1f2e;
  --color-text-muted:   #555e7a;
  --color-bg:           #f7f8fc;

  /* LIGHTENED: semi-transparent stops instead of near-opaque dark */
  --gradient-hero: linear-gradient(
    135deg,
    rgba(15, 42, 122, 0.72) 0%,
    rgba(26, 63, 160, 0.65) 50%,
    rgba(41, 82, 200, 0.60) 100%
  );

  --gradient-dark: linear-gradient(
    135deg,
    #020a1e 0%,
    var(--color-primary-dark) 60%,
    var(--color-primary) 100%
  );
  --gradient-gold: linear-gradient(
    135deg,
    var(--color-gold-dark) 0%,
    var(--color-gold) 50%,
    var(--color-gold-light) 100%
  );
  --gradient-cta: linear-gradient(
    135deg,
    #020a1e,
    var(--color-primary-dark),
    var(--color-primary)
  );
}


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

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: 'Inter', 'Segoe UI', Roboto, sans-serif;
  color: var(--color-text);
  line-height: 1.7;
  background: var(--color-bg);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

ul {
  list-style: none;
}


/* ================================================================
   SKIP LINK
   ================================================================ */
.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  background: var(--color-gold);
  color: var(--color-primary);
  padding: .6rem 1.2rem;
  z-index: 9999;
  font-weight: 700;
}

.skip-link:focus {
  top: 0;
}


/* ================================================================
   CONTAINER
   ================================================================ */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}


/* ================================================================
   TOP BAR
   ================================================================ */
.topbar {
  background: var(--color-primary-dark);
  color: rgba(255, 255, 255, .7);
  font-size: .78rem;
  padding: .5rem 0;
  border-bottom: 1px solid rgba(240, 192, 64, .15);
}

.topbar .container {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}

.topbar-left {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: center;
}

.topbar-left span.sep {
  color: rgba(255, 255, 255, .25);
}

.topbar a {
  color: rgba(255, 255, 255, .75);
  transition: color .2s;
}

.topbar a:hover {
  color: var(--color-gold-light);
}

.topbar-right {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.topbar-tagline {
  font-size: .72rem;
  color: rgba(240, 192, 64, .7);
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
}


/* ================================================================
   SOCIAL ICONS (top bar + footer)
   ================================================================ */
.socials {
  display: flex;
  gap: .4rem;
  align-items: center;
}

.socials a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 4px;
  background: rgba(255, 255, 255, .06);
  transition: background .2s, color .2s, transform .2s;
}

.socials a:hover,
.socials a:focus-visible {
  transform: scale(1.15);
}

.socials svg {
  width: 13px;
  height: 13px;
  pointer-events: none;
}

.socials a[aria-label*="Facebook"]  { color: #1877f2; }
.socials a[aria-label*="Instagram"] { color: #e4405f; }
.socials a[aria-label*="WhatsApp"]  { color: #25d366; }
.socials a[aria-label*="YouTube"]   { color: #ff0000; }
.socials a[aria-label*="LinkedIn"]  { color: #0a66c2; }
.socials a[aria-label*="Email"]     { color: var(--color-gold-light); }

.socials a[aria-label*="Facebook"]:hover  { background: #1877f2; color: #fff; }
.socials a[aria-label*="Instagram"]:hover { background: #e4405f; color: #fff; }
.socials a[aria-label*="WhatsApp"]:hover  { background: #25d366; color: #fff; }
.socials a[aria-label*="YouTube"]:hover   { background: #ff0000; color: #fff; }
.socials a[aria-label*="LinkedIn"]:hover  { background: #0a66c2; color: #fff; }
.socials a[aria-label*="Email"]:hover     { background: var(--color-gold-light); color: var(--color-primary); }

.socials a:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}


/* ================================================================
   HEADER
   ================================================================ */
.header {
  background: #fff;
  box-shadow: 0 1px 0 #e0e4f0, 0 4px 20px rgba(15, 42, 122, .06);
  position: sticky;
  top: 0;
  z-index: 200;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
  gap: 1rem;
}


/* ── Brand ── */
.brand {
  display: flex;
  align-items: center;
  gap: .85rem;
  flex-shrink: 0;
}

.brand img.logo-img {
  height: 62px;
  width: auto;
}

.brand-text-wrap {
  display: flex;
  flex-direction: column;
}

.brand-name {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--color-primary);
  letter-spacing: -.01em;
  line-height: 1.2;
}

.brand-full {
  font-size: .65rem;
  color: var(--color-text-muted);
  font-weight: 500;
  letter-spacing: .02em;
}

.brand-pill {
  display: inline-block;
  font-size: .58rem;
  background: var(--color-primary);
  color: var(--color-gold-light);
  padding: .1rem .5rem;
  border-radius: 3px;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 700;
  margin-top: .2rem;
  width: fit-content;
}

.flag-img {
  height: 40px;
  margin-left: .5rem;
  border-radius: 2px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .2);
}


/* ================================================================
   NAVIGATION
   ================================================================ */
.navwrap {
  display: flex;
  align-items: center;
  gap: .5rem;
}

.nav {
  display: flex;
  align-items: center;
}

.nav > a,
.dropbtn {
  background: none;
  border: none;
  cursor: pointer;
  font: inherit;
  font-family: 'Inter', sans-serif;
  font-size: .82rem;
  font-weight: 500;
  padding: .5rem .7rem;
  border-radius: 4px;
  color: #2d3554;
  transition: color .2s, background .2s;
  white-space: nowrap;
  letter-spacing: .01em;
}

.nav > a:hover,
.nav > a:focus-visible,
.dropbtn:hover,
.dropbtn:focus-visible {
  color: var(--color-primary);
  background: #f0f2fa;
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.nav > a.active {
  color: var(--color-primary);
  font-weight: 700;
}


/* ── Dropdown ── */
.dropdown {
  position: relative;
}

.dropdown-content {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background: #fff;
  min-width: 220px;
  box-shadow: 0 8px 32px rgba(15, 42, 122, .12), 0 0 0 1px rgba(15, 42, 122, .06);
  border-radius: 6px;
  overflow: hidden;
  z-index: 300;
  border-top: 3px solid var(--color-gold);
  transition: opacity .15s ease, visibility .15s ease;
}

.dropdown-content a {
  display: block;
  padding: .6rem 1.1rem;
  font-size: .82rem;
  color: #2d3554;
  font-weight: 500;
  border-bottom: 1px solid #f0f2fa;
  transition: background .15s, color .15s, padding .15s;
}

.dropdown-content a:last-child {
  border-bottom: none;
}

.dropdown-content a:hover,
.dropdown-content a:focus-visible {
  background: #f0f2fa;
  color: var(--color-primary);
  padding-left: 1.4rem;
  outline: 2px solid var(--color-primary);
  outline-offset: -2px;
}

.dropdown-content a.active {
  background: #f0f2fa;
  color: var(--color-primary);
  font-weight: 700;
}

.dropdown.open .dropdown-content {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.drop-arrow {
  font-size: .75em;
  margin-left: .25rem;
}

.nav-divider {
  width: 1px;
  height: 20px;
  background: #e0e4f0;
  margin: 0 .25rem;
}


/* ── Donate button ── */
.btn-donate {
  background: linear-gradient(to bottom, #ef4444, #b91c1c);
  color: #fff;
  padding: .4rem 1rem;
  border-radius: 5px;
  font-weight: 800;
  font-size: .8rem;
  letter-spacing: .03em;
  text-transform: uppercase;
  white-space: nowrap;
  border: none;
  border-bottom: 3px solid #7f1d1d;
  cursor: pointer;
  box-shadow: 0 3px 0 #7f1d1d, 0 5px 10px rgba(0, 0, 0, .2);
  transition: all .1s ease;
  margin-left: .5rem;
}

.btn-donate:hover,
.btn-donate:focus-visible {
  background: linear-gradient(to bottom, #dc2626, #991b1b);
  color: #fff;
  transform: translateY(1px);
  border-bottom: 2px solid #7f1d1d;
  box-shadow: 0 1px 0 #7f1d1d, 0 2px 4px rgba(0, 0, 0, .2);
  outline: 3px solid var(--color-gold-light);
  outline-offset: 2px;
}

.btn-donate:active {
  transform: translateY(3px);
  border-bottom: 0 solid #7f1d1d;
  box-shadow: 0 0 0 #7f1d1d, 0 1px 2px rgba(0, 0, 0, .2);
}


/* ── Mobile menu button ── */
.menu-btn {
  display: none;
  background: none;
  border: 1.5px solid var(--color-primary);
  border-radius: 4px;
  padding: .4rem .7rem;
  font-weight: 700;
  font-size: .85rem;
  color: var(--color-primary);
  cursor: pointer;
}

.menu-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

@media (max-width: 768px) {
  .header-inner { flex-wrap: wrap; }
  .menu-btn     { order: -1; }
  .brand        { order: 0; flex: 1; }
}


/* ================================================================
   FIX 2 — Mobile nav
   Removed: white-space:nowrap; overflow:hidden; text-overflow:ellipsis
   ================================================================ */
.mobile {
  display: none;
  flex-direction: column;
  width: 100%;
  background: #fff;
  border-top: 2px solid var(--color-gold);
  padding: 0;
  max-height: 70vh;
  overflow-y: auto;
  box-shadow: 0 8px 24px rgba(15, 42, 122, .12);
}

.mobile.open {
  display: flex;
}

.mobile::-webkit-scrollbar {
  width: 3px;
}

.mobile::-webkit-scrollbar-thumb {
  background: var(--color-gold);
  border-radius: 2px;
}

/* FIX 2: white-space / overflow / text-overflow removed */
.mobile a {
  padding: .32rem 1rem;
  font-size: .72rem;
  color: #2d3554;
  border-bottom: 1px solid #f5f6fa;
  font-weight: 500;
  line-height: 1.3;
}

.mobile a:hover,
.mobile a:focus-visible {
  background: #f0f2fa;
  color: var(--color-primary);
}

.mobile .mob-section {
  padding: .2rem 1rem .1rem;
  font-size: .55rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #9099b8;
  font-weight: 700;
  margin-top: .15rem;
  background: #fafbff;
  border-bottom: 1px solid #eef0f5;
  position: sticky;
  top: 0;
  z-index: 1;
}

.mobile .mob-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.mobile .mob-grid a {
  border-right: 1px solid #f5f6fa;
}

.mobile .mob-grid a:nth-child(even) {
  border-right: none;
}

.mobile .mob-donate {
  background: linear-gradient(to bottom, #ef4444, #b91c1c);
  color: #fff !important;
  font-weight: 800 !important;
  text-align: center;
  margin: .4rem .5rem .5rem;
  border-radius: 5px;
  padding: .45rem .7rem;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .03em;
  border-bottom: 2px solid #7f1d1d;
  box-shadow: 0 2px 0 #7f1d1d, 0 3px 6px rgba(0, 0, 0, .2);
  transition: all .1s ease;
}

.mobile .mob-donate:hover {
  background: linear-gradient(to bottom, #dc2626, #991b1b);
  color: #fff !important;
  transform: translateY(1px);
  border-bottom: 1px solid #7f1d1d;
  box-shadow: 0 1px 0 #7f1d1d, 0 2px 4px rgba(0, 0, 0, .2);
}


/* ================================================================
   HERO — LIGHTENED
   Semi-transparent gradient + lighter base + raised pattern opacity
   ================================================================ */
.hero {
  background:
    linear-gradient(
      135deg,
      rgba(15, 42, 122, 0.72) 0%,
      rgba(26, 63, 160, 0.65) 50%,
      rgba(41, 82, 200, 0.60) 100%
    ),
    var(--color-primary-mid);
  color: #fff;
  padding: 3.5rem 0 3rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* LIGHTENED: fill-opacity raised from 0.04 → 0.09 for visible texture */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.09'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

.hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-gold-dark), var(--color-gold-light), var(--color-gold-dark));
}

.hero h1 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 2.4rem;
  font-weight: 800;
  margin-bottom: .5rem;
  position: relative;
  z-index: 1;
}

.hero h1 span {
  color: var(--color-gold-light);
  font-style: italic;
}

.hero p {
  font-size: 1rem;
  opacity: .85;
  max-width: 620px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.breadcrumb {
  font-size: .82rem;
  margin-bottom: 1rem;
  opacity: .7;
  position: relative;
  z-index: 1;
}

.breadcrumb a {
  color: var(--color-gold-light);
  text-decoration: underline;
}


/* ================================================================
   SECTIONS
   ================================================================ */
.section {
  padding: 4rem 0;
}

.section.bg-white { background: #fff; }
.section.bg-grey  { background: var(--color-bg); }


/* ── Section heading decorations ── */
.sh-eyebrow {
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .7rem;
}

.sh-line {
  width: 24px;
  height: 2px;
  background: var(--color-gold);
  flex-shrink: 0;
}

.sh-label {
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--color-gold);
  font-weight: 700;
}

.sh-label.light {
  color: var(--color-gold-light);
}

.sh-rule {
  width: 48px;
  height: 3px;
  background: linear-gradient(90deg, var(--color-gold), var(--color-gold-light));
  border-radius: 2px;
  margin-bottom: .8rem;
}

.section-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.9rem;
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1.25;
  margin-bottom: .6rem;
}

.section-title .accent {
  color: var(--color-gold);
  font-style: italic;
}

.section-title.light {
  color: #fff;
}

.section-sub {
  font-size: .95rem;
  color: var(--color-text-muted);
  max-width: 720px;
  line-height: 1.75;
}

.section-sub.light {
  color: rgba(200, 215, 255, .88);
}


/* ================================================================
   ABOUT HERO GRID
   ================================================================ */
.about-hero-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 3rem;
  align-items: start;
  margin-top: 2rem;
}

.about-hero-text p {
  font-size: .95rem;
  color: #3a4260;
  line-height: 1.8;
  margin-bottom: .8rem;
}


/* ================================================================
   MISSION / VISION / VALUES
   ================================================================ */
.mvv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
  margin-top: 2rem;
}

.mvv-card {
  background: #fff;
  border-radius: 10px;
  padding: 1.8rem 1.5rem;
  border: 1px solid #e8eaf0;
  box-shadow: 0 2px 12px rgba(15, 42, 122, .06);
  transition: transform .25s, box-shadow .25s;
  display: flex;
  flex-direction: column;
}

.mvv-card:hover,
.mvv-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(15, 42, 122, .12);
  outline: none;
}

.mvv-card:focus-visible {
  outline: 3px solid var(--color-gold);
  outline-offset: 2px;
}

.mvv-card.mission { border-top: 4px solid var(--color-gold); }
.mvv-card.vision  { border-top: 4px solid var(--color-primary); }
.mvv-card.values  { border-top: 4px solid #047857; }

.mvv-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
}

.mvv-icon svg {
  width: 22px;
  height: 22px;
}

.mvv-icon.gold {
  background: linear-gradient(135deg, var(--color-gold-dark), var(--color-gold));
  box-shadow: 0 4px 12px rgba(212, 160, 23, .25);
}
.mvv-icon.gold svg { fill: var(--color-primary); }

.mvv-icon.blue {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-mid));
  box-shadow: 0 4px 12px rgba(15, 42, 122, .25);
}
.mvv-icon.blue svg { fill: var(--color-gold-light); }

.mvv-icon.green {
  background: linear-gradient(135deg, #047857, #10b981);
  box-shadow: 0 4px 12px rgba(4, 120, 87, .25);
}
.mvv-icon.green svg { fill: #fff; }

.mvv-tag {
  display: inline-block;
  font-size: .6rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 700;
  padding: .15rem .55rem;
  border-radius: 3px;
  margin-bottom: .5rem;
  width: fit-content;
}

.mvv-tag.gold  { background: rgba(212, 160, 23, .12); color: #8a6200; }
.mvv-tag.blue  { background: #eef0fa; color: var(--color-primary); }
.mvv-tag.green { background: rgba(4, 120, 87, .1); color: #047857; }

.mvv-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: .5rem;
}

.mvv-card p {
  font-size: .88rem;
  color: var(--color-text-muted);
  line-height: 1.65;
  flex: 1;
}


/* ================================================================
   PROGRAMME LIST
   ================================================================ */
.prog-list-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .7rem;
  margin-top: 1.5rem;
}

.prog-list-item {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .65rem .9rem;
  border-radius: 6px;
  border: 1px solid #e8eaf0;
  border-left: 3px solid var(--color-gold);
  background: #fafbff;
  transition: border-left-color .2s, background .2s;
  font-size: .88rem;
  color: #3a4260;
  font-weight: 500;
}

.prog-list-item:hover,
.prog-list-item:focus-visible {
  border-left-color: var(--color-primary);
  background: #f0f2fa;
}

.prog-list-item:focus-visible {
  outline: 3px solid var(--color-gold);
  outline-offset: 2px;
}

.prog-list-item svg {
  width: 16px;
  height: 16px;
  fill: var(--color-gold);
  flex-shrink: 0;
}


/* ================================================================
   ORG CARD
   ================================================================ */
.org-card {
  background: #fff;
  border-radius: 10px;
  padding: 1.8rem 1.6rem;
  border: 1px solid #e8eaf0;
  border-top: 4px solid var(--color-gold);
  box-shadow: 0 2px 12px rgba(15, 42, 122, .06);
}

.org-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 1rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid #e8eaf0;
}

.org-row {
  display: flex;
  gap: .5rem;
  padding: .45rem 0;
  border-bottom: 1px solid #f5f6fa;
  font-size: .85rem;
}

.org-row:last-child {
  border-bottom: none;
}

.org-key {
  color: #9099b8;
  font-weight: 600;
  min-width: 100px;
  flex-shrink: 0;
}

.org-val {
  color: #3a4260;
}

.org-val a {
  color: var(--color-primary);
  text-decoration: underline;
}


/* ================================================================
   DARK SECTION
   ================================================================ */
.dark-section {
  background: var(--gradient-dark);
  padding: 3.5rem 0;
  position: relative;
  overflow: hidden;
}

.dark-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, .025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .025) 1px, transparent 1px);
  background-size: 40px 40px;
}

.dark-section::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-gold-dark), var(--color-gold-light), var(--color-gold-dark));
}

.dark-bot {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-gold-dark), var(--color-gold-light), var(--color-gold-dark));
}

.dark-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 2.5rem;
  align-items: center;
  position: relative;
  z-index: 2;
}

.dark-text h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.6rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: .8rem;
  line-height: 1.3;
}

.dark-text h2 span {
  color: var(--color-gold-light);
  font-style: italic;
}

.dark-text p {
  font-size: .9rem;
  color: rgba(200, 215, 255, .85);
  line-height: 1.75;
  margin-bottom: .8rem;
}

.dark-box {
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(240, 192, 64, .18);
  border-radius: 14px;
  padding: 1.6rem 1.5rem;
  box-shadow: 0 4px 18px rgba(0, 0, 0, .15);
}

.dark-box h3 {
  color: var(--color-gold-light);
  margin-bottom: .8rem;
  font-size: 1.05rem;
  font-weight: 700;
}

.dark-box ul {
  display: grid;
  gap: .6rem;
}

.dark-box li {
  color: #dbe4ff;
  font-size: .9rem;
  padding-left: 1.2rem;
  position: relative;
  line-height: 1.5;
}

.dark-box li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--color-gold-light);
  font-weight: 700;
}


/* ================================================================
   QUOTE STRIP
   ================================================================ */
.quote-strip {
  background: var(--gradient-gold);
  padding: 2.5rem 0;
  text-align: center;
}

.quote-text {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: #0a1f5c;
  line-height: 1.5;
  max-width: 800px;
  margin: 0 auto;
  font-style: italic;
}

.quote-attr {
  margin-top: .8rem;
  font-size: .82rem;
  font-weight: 700;
  color: #0a1f5c;
  text-transform: uppercase;
  letter-spacing: .08em;
}


/* ================================================================
   CTA BANNER
   ================================================================ */
.cta-banner {
  background: var(--gradient-cta);
  border-radius: 14px;
  padding: 3rem 2.5rem;
  position: relative;
  overflow: hidden;
  margin-top: 2rem;
}

.cta-banner::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-gold-dark), var(--color-gold-light), var(--color-gold-dark));
}

.cta-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  align-items: center;
  position: relative;
  z-index: 1;
}

.cta-text h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: .5rem;
}

.cta-text h2 span {
  color: var(--color-gold-light);
  font-style: italic;
}

.cta-text p {
  font-size: .9rem;
  color: rgba(200, 215, 255, .88);
  line-height: 1.65;
}

.cta-actions {
  display: flex;
  gap: .6rem;
  flex-shrink: 0;
  flex-wrap: wrap;
}

.cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  padding: .7rem 1.8rem;
  border-radius: 4px;
  font-weight: 700;
  font-size: .88rem;
  transition: transform .2s, box-shadow .2s, background .2s;
  white-space: nowrap;
}

.cta-btn svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}

.cta-btn:hover {
  transform: translateY(-1px);
}

.cta-btn:focus-visible {
  outline: 2px solid var(--color-gold-light);
  outline-offset: 2px;
}

/* FIX 5: explicit color on both base and hover */
.cta-btn-gold {
  background: var(--color-gold);
  color: var(--color-primary);
  box-shadow: 0 4px 16px rgba(212, 160, 23, .35);
}

.cta-btn-gold:hover {
  background: #e6b020;
  color: var(--color-primary); /* FIX 5 */
}

.cta-btn-outline {
  background: transparent;
  color: rgba(255, 255, 255, .85);
  border: 1.5px solid rgba(255, 255, 255, .3);
}

.cta-btn-outline:hover {
  background: rgba(255, 255, 255, .08);
  color: #fff;
}


/* ================================================================
   FOOTER
   ================================================================ */
.footer {
  background: #04091e;
  color: #a0a8c8;
  padding: 3.5rem 0 0;
  border-top: 4px solid var(--color-gold);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1.1fr;
  gap: 2.5rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, .07);
}

.footer-brand img {
  height: 44px;
  margin-bottom: .8rem;
}

.footer-brand h3 {
  font-size: 1.05rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: .2rem;
}

.footer-brand .ft-full {
  font-size: .72rem;
  color: #6070a0;
  margin-bottom: .7rem;
}

.footer-brand p {
  font-size: .82rem;
  color: #7080a8;
  line-height: 1.65;
  margin-bottom: 1rem;
}

.footer-brand .ft-pill {
  display: inline-block;
  font-size: .62rem;
  background: rgba(212, 160, 23, .15);
  color: var(--color-gold);
  padding: .2rem .65rem;
  border-radius: 3px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  border: 1px solid rgba(212, 160, 23, .25);
}

/* Merged duplicated footer column h4 rules */
.footer-col h4,
.footer-contact h4 {
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 700;
  color: var(--color-gold-light);
  margin-bottom: 1rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid rgba(240, 192, 64, .15);
}

.footer-col ul {
  display: grid;
  gap: .4rem;
}

.footer-col li {
  font-size: .83rem;
  color: #7080a8;
}

.footer-col li a {
  color: #8090b8;
  transition: color .2s;
}

.footer-col li a:hover {
  color: var(--color-gold-light);
}

/* ── Footer contact ── */
.fc-item {
  display: flex;
  gap: .6rem;
  margin-bottom: .7rem;
  align-items: flex-start;
}

.fc-icon {
  width: 26px;
  height: 26px;
  border-radius: 4px;
  background: rgba(15, 42, 122, .5);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.fc-icon svg {
  width: 12px;
  height: 12px;
  fill: var(--color-gold-light);
}

.fc-text {
  font-size: .8rem;
  color: #8090b8;
  line-height: 1.5;
}

.fc-text a {
  color: var(--color-gold-light);
}

.fc-text a:hover {
  text-decoration: underline;
}

/* ── Footer socials ── */
.footer-socials {
  display: flex;
  gap: .4rem;
  margin-top: 1rem;
}

.footer-socials a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 4px;
  background: rgba(255, 255, 255, .06);
  transition: background .2s, color .2s, transform .2s;
}

.footer-socials a:hover {
  transform: scale(1.15);
}

.footer-socials svg {
  width: 15px;
  height: 15px;
}

.footer-socials a[aria-label*="Facebook"]  { color: #1877f2; }
.footer-socials a[aria-label*="Instagram"] { color: #e4405f; }
.footer-socials a[aria-label*="WhatsApp"]  { color: #25d366; }
.footer-socials a[aria-label*="YouTube"]   { color: #ff0000; }
.footer-socials a[aria-label*="LinkedIn"]  { color: #0a66c2; }
.footer-socials a[aria-label*="Email"]     { color: var(--color-gold-light); }

.footer-socials a[aria-label*="Facebook"]:hover  { background: #1877f2; color: #fff; }
.footer-socials a[aria-label*="Instagram"]:hover { background: #e4405f; color: #fff; }
.footer-socials a[aria-label*="WhatsApp"]:hover  { background: #25d366; color: #fff; }
.footer-socials a[aria-label*="YouTube"]:hover   { background: #ff0000; color: #fff; }
.footer-socials a[aria-label*="LinkedIn"]:hover  { background: #0a66c2; color: #fff; }
.footer-socials a[aria-label*="Email"]:hover     { background: var(--color-gold-light); color: var(--color-primary); }

.footer-socials a:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

/* ── Footer bottom bar ── */
.footer-bottom {
  padding: 1.2rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem;
}

.footer-bottom p {
  font-size: .75rem;
  color: #4a5470;
}

.footer-bottom-links {
  display: flex;
  gap: 1.2rem;
}

.footer-bottom-links a {
  font-size: .72rem;
  color: #4a5470;
  transition: color .2s;
}

.footer-bottom-links a:hover {
  color: var(--color-gold-light);
}


/* ================================================================
   WHATSAPP FAB
   ================================================================ */
.wa {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  background: #25d366;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(37, 211, 102, .4);
  transition: transform .2s;
  z-index: 500;
}

.wa:hover {
  transform: scale(1.1);
}

.wa:focus-visible {
  outline: 3px solid #128c7e;
  outline-offset: 3px;
}

.wa svg {
  width: 26px;
  height: 26px;
  fill: #fff;
  pointer-events: none;
}


/* ================================================================
   SCROLL TO TOP
   ================================================================ */
.scroll-top {
  position: fixed;
  bottom: 1.5rem;
  left: 1.5rem;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-mid));
  box-shadow: 0 4px 20px rgba(15, 42, 122, .35), 0 0 0 3px rgba(212, 160, 23, .3);
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: opacity .35s, visibility .35s, transform .35s, background .2s;
}

.scroll-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.scroll-top:hover {
  background: linear-gradient(135deg, var(--color-gold), #e6b020);
  transform: translateY(-3px);
}

.scroll-top:focus-visible {
  outline: 2px solid var(--color-gold-light);
  outline-offset: 3px;
}

.scroll-top svg {
  width: 22px;
  height: 22px;
  fill: var(--color-gold-light);
}

.scroll-top:hover svg {
  fill: var(--color-primary);
}


/* ================================================================
   LOCATION VISUALIZER — World → Africa → Kenya → PETRAD AID
   ================================================================ */

.loc-viz-section {
  overflow: hidden;
}

/* Three-column grid: stage | arrow | stage | arrow | stage */
.loc-viz-grid {
  display: grid;
  grid-template-columns: 1fr 44px 1fr 44px 1fr;
  gap: 1rem;
  align-items: center;
  margin-top: 2.5rem;
}

.loc-viz-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .75rem;
}

.loc-stage-header {
  display: flex;
  align-items: center;
  gap: .5rem;
}

.loc-stage-title {
  font-size: .78rem;
  font-weight: 700;
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: .09em;
}

/* Number badge */
.loc-badge {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-size: .64rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: 0;
}

.loc-badge--gold {
  background: var(--color-gold);
  color: var(--color-primary);
}

/* Map wrapper */
.loc-map-wrap {
  width: 100%;
  background: #dceaf6;
  border-radius: 12px;
  overflow: hidden;
  border: 2px solid #b8cede;
  box-shadow: 0 4px 16px rgba(15, 42, 122, .10);
  transition: box-shadow .25s, border-color .25s;
  position: relative;
}

.loc-map-wrap:hover {
  box-shadow: 0 8px 28px rgba(15, 42, 122, .18);
}

.loc-map-wrap--active {
  border-color: var(--color-gold);
  box-shadow: 0 4px 22px rgba(212, 160, 23, .28);
}

.loc-map-wrap--active:hover {
  box-shadow: 0 8px 32px rgba(212, 160, 23, .38);
}

/* SVG fills its wrapper */
.loc-svg {
  width: 100%;
  height: auto;
  display: block;
}

/* Caption below map */
.loc-map-caption {
  background: var(--color-primary);
  color: rgba(255, 255, 255, .82);
  font-size: .65rem;
  font-weight: 600;
  text-align: center;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: .3rem .5rem;
}

.loc-viz-stage--active .loc-map-caption {
  background: var(--color-gold-dark);
  color: var(--color-primary);
}

/* Arrow between stages */
.loc-viz-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  opacity: .65;
}


/* ── World map SVG styles ── */
.wm-land {
  fill: #a8c4a0;
  stroke: #7aaa70;
  stroke-width: 1;
  stroke-linejoin: round;
}

.wm-africa {
  fill: var(--color-primary);
  stroke: var(--color-primary-mid);
  stroke-width: 1.5;
  stroke-linejoin: round;
}

.wm-kenya-marker .wm-kp-dot {
  fill: var(--color-gold-light);
  stroke: #fff;
  stroke-width: 1.5;
}

.wm-kenya-marker .wm-kp-pulse {
  fill: none;
  stroke: var(--color-gold-light);
  stroke-width: 1.5;
  transform-box: fill-box;
  transform-origin: center;
  animation: loc-pulse 2.4s ease-out infinite;
}


/* ── Africa map SVG styles ── */
.af-land {
  fill: #2a50a8;
  stroke: #1a3a8a;
  stroke-width: 2;
  stroke-linejoin: round;
}

.af-neighbour {
  fill: #3a62b8;
  stroke: #2a50a8;
  stroke-width: 1;
}

.af-kenya {
  fill: var(--color-gold);
  stroke: var(--color-gold-dark);
  stroke-width: 2;
  stroke-linejoin: round;
}

.af-kenya-label {
  fill: var(--color-primary);
  font-family: 'Inter', sans-serif;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: .04em;
  pointer-events: none;
}

.af-nairobi-marker .af-nb-dot {
  fill: var(--color-primary);
  stroke: #fff;
  stroke-width: 2;
}

.af-nairobi-marker .af-nb-pulse {
  fill: none;
  stroke: var(--color-primary-mid);
  stroke-width: 2;
  transform-box: fill-box;
  transform-origin: center;
  animation: loc-pulse 2.4s ease-out infinite;
}


/* ── Kenya map SVG styles ── */
.ke-neighbour {
  fill: #2a50a8;
  stroke: #1a3a8a;
  stroke-width: 1;
}

.ke-land {
  fill: #1a3fa0;
  stroke: #0f2a7a;
  stroke-width: 2.5;
  stroke-linejoin: round;
}

.ke-lake {
  fill: #7ab8e0;
  stroke: #5898c0;
  stroke-width: 1.5;
}

.ke-city-glow {
  fill: rgba(255, 255, 255, .12);
  stroke: rgba(255, 255, 255, .2);
  stroke-width: 1.5;
}

.ke-pulse-1 {
  fill: none;
  stroke: var(--color-gold-light);
  stroke-width: 2;
  transform-box: fill-box;
  transform-origin: center;
  animation: loc-pulse 2.2s ease-out infinite;
}

.ke-pulse-2 {
  fill: none;
  stroke: var(--color-gold-light);
  stroke-width: 2;
  transform-box: fill-box;
  transform-origin: center;
  animation: loc-pulse 2.2s ease-out infinite .8s;
}

.ke-pin-group {
  filter: drop-shadow(0 3px 6px rgba(0, 0, 0, .4));
}

.ke-pin-body {
  fill: var(--color-gold);
  stroke: var(--color-gold-dark);
  stroke-width: 2;
  stroke-linejoin: round;
}

.ke-pin-inner {
  fill: var(--color-primary);
  stroke: rgba(255, 255, 255, .6);
  stroke-width: 1.5;
}

.ke-leader {
  stroke: rgba(255, 255, 255, .45);
  stroke-width: 1.5;
  stroke-dasharray: 5 4;
}

.ke-label-box {
  fill: rgba(5, 15, 46, .82);
  stroke: var(--color-gold);
  stroke-width: 1.5;
}

.ke-label-main {
  fill: #fff;
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: .03em;
}

.ke-label-sub {
  fill: var(--color-gold-light);
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 600;
}

.ke-coords {
  fill: rgba(255, 255, 255, .5);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  font-style: italic;
}

.ke-city-label {
  fill: rgba(255, 255, 255, .75);
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 600;
}

.ke-compass-bg {
  fill: rgba(5, 15, 46, .65);
  stroke: rgba(255, 255, 255, .2);
  stroke-width: 1;
}

.ke-compass-n {
  fill: var(--color-gold-light);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 800;
}

.ke-compass-arrow   { fill: var(--color-gold-light); }
.ke-compass-arrow-s { fill: rgba(255, 255, 255, .6); }


/* ── Breadcrumb coordinates strip ── */
.loc-crumb {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: .4rem .8rem;
  margin-top: 2rem;
  background: #fff;
  border: 1px solid #e8eaf0;
  border-left: 4px solid var(--color-gold);
  border-radius: 8px;
  padding: .9rem 1.5rem;
  box-shadow: 0 2px 10px rgba(15, 42, 122, .06);
}

.loc-crumb-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .15rem;
}

.loc-crumb-label {
  font-size: .58rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #9099b8;
  font-weight: 700;
}

.loc-crumb-val {
  font-size: .84rem;
  font-weight: 700;
  color: var(--color-primary);
}

.loc-crumb-sep {
  color: var(--color-gold);
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1;
  margin-top: .8rem;
}


/* ================================================================
   PULSE KEYFRAME
   ================================================================ */
@keyframes loc-pulse {
  0%   { transform: scale(1);   opacity: .85; }
  100% { transform: scale(3.8); opacity: 0;   }
}


/* ================================================================
   DESKTOP STICKY ORG CARD
   ================================================================ */
@media (min-width: 1025px) {
  .org-card {
    position: sticky;
    top: 100px;
  }
}


/* ================================================================
   BREAKPOINT: 1100px — footer 2-col
   ================================================================ */
@media (max-width: 1100px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}


/* ================================================================
   BREAKPOINT: 1024px
   ================================================================ */
@media (max-width: 1024px) {
  .about-hero-grid { grid-template-columns: 1fr; }
  .dark-grid       { grid-template-columns: 1fr; }
}


/* ================================================================
   BREAKPOINT: 900px
   FIX 3 — removed duplicate .footer-grid rule (was identical to 1100px)
   ================================================================ */
@media (max-width: 900px) {
  .mvv-grid       { grid-template-columns: 1fr; }
  .prog-list-grid { grid-template-columns: 1fr; }
  .cta-grid       { grid-template-columns: 1fr; }
  /* FIX 3: .footer-grid removed — already handled at 1100px */

  /* Location visualizer stacks vertically */
  .loc-viz-grid {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
  .loc-viz-arrow {
    transform: rotate(90deg);
    justify-self: center;
  }
  .loc-viz-stage {
    width: 100%;
    max-width: 480px;
    margin: 0 auto;
  }
  .loc-crumb {
    gap: .4rem .6rem;
  }
}


/* ================================================================
   BREAKPOINT: 768px — mobile layout
   FIX 4 — .flag-img hidden on mobile
   ================================================================ */
@media (max-width: 768px) {
  .nav         { display: none; }
  .btn-donate  { display: none; }
  .nav-divider { display: none; }
  .menu-btn    { display: block; }
  .flag-img    { display: none; } /* FIX 4 */

  .hero h1 { font-size: 1.8rem; }

  .topbar-tagline    { display: none; }
  .topbar .container { flex-direction: column; }

  .footer-grid   { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; text-align: center; }

  .scroll-top     { width: 46px; height: 46px; }
  .scroll-top svg { width: 20px; height: 20px; }

  .navwrap     { width: 100%; order: 2; }
  .mobile.open { display: flex; width: 100%; }
}


/* ================================================================
   BREAKPOINT: 600px
   ================================================================ */
@media (max-width: 600px) {
  .cta-banner  { padding: 2rem 1.25rem; }
  .cta-text h2 { font-size: 1.25rem; }

  /* Location visualizer breadcrumb strip stacks on mobile */
  .loc-stage-title { font-size: .72rem; }
  .loc-crumb {
    flex-direction: column;
    align-items: flex-start;
    padding: .8rem 1rem;
  }
  .loc-crumb-sep  { display: none; }
  .loc-crumb-item { flex-direction: row; gap: .5rem; align-items: baseline; }
  .loc-crumb-label::after { content: ':'; }
}


/* ================================================================
   REDUCED MOTION
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }

  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  /* Explicitly kill pulse animations */
  .wm-kp-pulse,
  .af-nb-pulse,
  .ke-pulse-1,
  .ke-pulse-2 {
    animation: none;
    opacity: 0;
  }
}
/* ══════════════════════════════════════════
   NEWSLETTER SECTION
══════════════════════════════════════════ */
.newsletter-section{background:var(--gradient-dark);padding:3.5rem 0;position:relative;overflow:hidden;}
.newsletter-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 60% 50%,rgba(212,160,23,.08),transparent 70%);}
.newsletter-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:center;position:relative;z-index:1;}
.newsletter-text h2{font-family:'Playfair Display',serif;font-size:1.6rem;color:#fff;font-weight:800;margin-bottom:.6rem;}
.newsletter-text h2 span{color:var(--color-gold-light);font-style:italic;}
.newsletter-text p{color:rgba(200,215,255,.82);font-size:.9rem;line-height:1.7;}
.nl-field-group{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:.5rem;}
.nl-input{flex:1;min-width:160px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:.65rem 1rem;color:#fff;font-size:.9rem;outline:none;transition:border-color .2s;}
.nl-input::placeholder{color:rgba(200,215,255,.5);}
.nl-input:focus{border-color:var(--color-gold);}
.nl-btn{background:var(--color-gold);color:#0f2a7a;font-weight:700;border:none;border-radius:8px;padding:.65rem 1.3rem;cursor:pointer;display:flex;align-items:center;gap:.4rem;font-size:.88rem;transition:background .2s,transform .15s;white-space:nowrap;}
.nl-btn:hover{background:var(--color-gold-light);transform:translateY(-1px);}
.nl-note{font-size:.75rem;color:rgba(200,215,255,.5);margin-top:.4rem;}
.nl-note a{color:rgba(200,215,255,.7);text-decoration:underline;}
.nl-success{display:flex;align-items:center;gap:.6rem;color:var(--color-gold-light);font-size:.9rem;font-weight:600;padding:.8rem 0;}
@media(max-width:720px){.newsletter-inner{grid-template-columns:1fr;gap:1.5rem;}}

/* ══════════════════════════════════════════
   COOKIE BANNER
══════════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);width:calc(100% - 2rem);max-width:700px;background:var(--gradient-dark);border:1px solid rgba(212,160,23,.2);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.4);z-index:9999;padding:1rem 1.25rem;animation:slideUp .4s ease;}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(20px);}to{opacity:1;transform:translateX(-50%) translateY(0);}}
.cookie-inner{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;}
.cookie-text{display:flex;align-items:flex-start;gap:.5rem;flex:1;min-width:200px;}
.cookie-text p{font-size:.82rem;color:rgba(200,215,255,.85);line-height:1.5;margin:0;}
.cookie-text a{color:var(--color-gold-light);text-decoration:underline;}
.cookie-actions{display:flex;gap:.5rem;flex-shrink:0;}
.cookie-btn{border:none;border-radius:8px;padding:.45rem 1rem;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .2s;}
.cookie-accept{background:var(--color-gold);color:#0f2a7a;}
.cookie-accept:hover{background:var(--color-gold-light);}
.cookie-decline{background:rgba(255,255,255,.08);color:rgba(200,215,255,.7);border:1px solid rgba(255,255,255,.1);}
.cookie-decline:hover{background:rgba(255,255,255,.14);}

/* ══════════════════════════════════════════
   BENEFICIARY STORIES
══════════════════════════════════════════ */
.stories-section{}
.stories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.story-card{background:#fff;border-radius:16px;padding:1.6rem 1.4rem 1.2rem;box-shadow:0 2px 16px rgba(15,42,122,.07);border-top:4px solid var(--color-primary);position:relative;display:flex;flex-direction:column;gap:.8rem;transition:transform .25s,box-shadow .25s;}
.story-card:hover{transform:translateY(-4px);box-shadow:0 10px 32px rgba(15,42,122,.13);}
.story-quote-mark{font-size:4rem;line-height:.8;color:var(--color-primary);opacity:.12;font-family:Georgia,serif;position:absolute;top:.8rem;right:1.2rem;}
.story-quote p{font-size:.88rem;color:var(--color-text);line-height:1.7;font-style:italic;}
.story-author{display:flex;align-items:center;gap:.7rem;margin-top:.8rem;}
.story-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.9rem;flex-shrink:0;}
.story-name{font-weight:700;font-size:.85rem;color:var(--color-primary);}
.story-location{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--color-text-muted);}
.story-prog-badge{display:inline-block;background:#eef0fa;color:var(--color-primary);border:1px solid #d0d5ef;border-radius:99px;font-size:.68rem;font-weight:700;padding:.2rem .65rem;text-transform:uppercase;letter-spacing:.05em;margin-top:auto;}
@media(max-width:900px){.stories-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:580px){.stories-grid{grid-template-columns:1fr;}}

/* ══════════════════════════════════════════
   DONATE: FREQUENCY TOGGLE & IMPACT EQUIV
══════════════════════════════════════════ */
.frequency-toggle{display:flex;gap:.5rem;margin-bottom:1rem;background:var(--color-bg);border-radius:10px;padding:.3rem;}
.freq-btn{flex:1;background:transparent;border:none;border-radius:8px;padding:.55rem .8rem;font-size:.85rem;font-weight:600;cursor:pointer;color:var(--color-text-muted);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.4rem;}
.freq-btn.active{background:#fff;color:var(--color-primary);box-shadow:0 1px 6px rgba(15,42,122,.12);}
.freq-badge{background:var(--color-gold);color:#0f2a7a;font-size:.6rem;font-weight:800;padding:.1rem .4rem;border-radius:99px;text-transform:uppercase;letter-spacing:.05em;}
.freq-note{display:flex;align-items:flex-start;gap:.5rem;background:#eef7f0;border:1px solid #b8dfc5;border-radius:8px;padding:.65rem .9rem;font-size:.8rem;color:#1a6640;margin-bottom:.8rem;line-height:1.5;}
.impact-equiv{display:none;align-items:center;gap:.5rem;background:linear-gradient(135deg,#fff8e6,#fff3cc);border:1px solid #f0d080;border-radius:8px;padding:.6rem .9rem;font-size:.82rem;color:#7a4f00;font-weight:600;margin-bottom:.8rem;}
.impact-equiv svg{fill:#c07a00;flex-shrink:0;}

/* ══════════════════════════════════════════
   VOLUNTEER FORM (partners page)
══════════════════════════════════════════ */
.volunteer-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:start;}
.volunteer-text h2{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:800;color:var(--color-primary);margin-bottom:.6rem;}
.volunteer-perks{list-style:none;padding:0;display:grid;gap:.5rem;margin-top:1rem;}
.volunteer-perks li{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--color-text);}
.volunteer-perks li svg{fill:var(--color-primary);flex-shrink:0;}
.volunteer-form-wrap{background:#fff;border-radius:16px;padding:1.8rem;box-shadow:0 4px 24px rgba(15,42,122,.09);border-top:4px solid var(--color-primary);}
.volunteer-form-wrap h3{font-size:1.1rem;font-weight:800;color:var(--color-primary);margin-bottom:1.2rem;}
.vf-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;}
.volunteer-form .form-group{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.8rem;}
.volunteer-form label{font-size:.8rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;}
.volunteer-form input,.volunteer-form select,.volunteer-form textarea{border:1.5px solid #d8ddef;border-radius:8px;padding:.6rem .85rem;font-size:.88rem;color:var(--color-text);background:#fff;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box;}
.volunteer-form input:focus,.volunteer-form select:focus,.volunteer-form textarea:focus{border-color:var(--color-primary);}
.volunteer-form textarea{resize:vertical;min-height:80px;}
.btn-submit{background:var(--color-primary);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:.9rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background .2s,transform .15s;width:100%;justify-content:center;}
.btn-submit:hover{background:var(--color-primary-mid);transform:translateY(-1px);}
.form-success{display:flex;align-items:center;gap:.6rem;color:#1a6640;font-size:.9rem;font-weight:600;background:#eef7f0;border-radius:8px;padding:1rem;margin-top:.5rem;}
@media(max-width:860px){.volunteer-grid{grid-template-columns:1fr;}}
@media(max-width:540px){.vf-row{grid-template-columns:1fr;}}

/* ══════════════════════════════════════════
   PRIVACY PAGE
══════════════════════════════════════════ */
.privacy-block{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #eee;}
.privacy-block:last-child{border-bottom:none;}
.privacy-block h2{font-size:1.1rem;font-weight:800;color:var(--color-primary);margin-bottom:.7rem;}
.privacy-block p{font-size:.9rem;color:var(--color-text);line-height:1.75;margin-bottom:.6rem;}
.privacy-block ul{padding-left:1.2rem;display:grid;gap:.4rem;}
.privacy-block ul li{font-size:.9rem;color:var(--color-text);line-height:1.6;}

/* ── Flag video size fix ── */
.flag-video,.flag-img.header-video{height:32px!important;width:auto!important;max-width:46px!important;object-fit:cover!important;object-position:center!important;border-radius:3px!important;}

/* ══════════════════════════════════════════
   NEW HEADER OVERRIDES — forces correct layout
   on all pages regardless of old CSS
══════════════════════════════════════════ */
.header{position:sticky!important;top:0!important;z-index:1000!important;background:#fff!important;border-bottom:1px solid #e2e6f0!important;box-shadow:0 2px 8px rgba(15,42,122,.08)!important;}
.header-inner{max-width:1200px!important;margin:0 auto!important;padding:0 1.5rem!important;display:flex!important;align-items:center!important;justify-content:space-between!important;height:68px!important;gap:1.5rem!important;flex-wrap:nowrap!important;}
/* Brand — always visible, left side */
.brand{display:flex!important;align-items:center!important;gap:.75rem!important;flex-shrink:0!important;order:1!important;}
.brand a{display:flex!important;align-items:center!important;gap:.75rem!important;}
.logo-img{height:46px!important;width:auto!important;max-width:none!important;}
.brand-text-wrap{display:flex!important;flex-direction:column!important;line-height:1.2!important;}
.brand-name{font-size:1.1rem!important;font-weight:800!important;color:#0f2a7a!important;}
.brand-full{font-size:.65rem!important;color:#6b7394!important;font-weight:500!important;}
.brand-pill{display:inline-block!important;background:#f5a623!important;color:#0f2a7a!important;font-size:.55rem!important;font-weight:700!important;padding:.1rem .4rem!important;border-radius:20px!important;text-transform:uppercase!important;letter-spacing:.04em!important;margin-top:.15rem!important;}
/* Nav — centre */
.nav{display:flex!important;align-items:center!important;gap:.25rem!important;order:2!important;flex:1!important;justify-content:center!important;}
.nav>a,.dropbtn{font-size:.82rem!important;font-weight:500!important;color:#3a4260!important;padding:.5rem .7rem!important;border-radius:8px!important;white-space:nowrap!important;background:none!important;border:none!important;cursor:pointer!important;font-family:inherit!important;display:flex!important;align-items:center!important;gap:.25rem!important;}
.nav>a:hover,.dropbtn:hover,.nav>a[aria-current="page"]{background:#f0f2f8!important;color:#0f2a7a!important;}
.nav>a[aria-current="page"]{font-weight:700!important;}
/* Right actions — flag + donate */
.header-actions{display:flex!important;align-items:center!important;gap:.75rem!important;order:3!important;flex-shrink:0!important;}
.btn-donate-nav{background:#f5a623!important;color:#0f2a7a!important;font-size:.85rem!important;font-weight:700!important;padding:.55rem 1.3rem!important;border-radius:50px!important;white-space:nowrap!important;box-shadow:0 4px 12px rgba(245,166,35,.4)!important;display:inline-block!important;text-decoration:none!important;}
.btn-donate-nav:hover{background:#d4891a!important;transform:translateY(-1px)!important;}
/* Flag video — small emblem */
.flag-video,.flag-img,.flag-img.header-video{height:32px!important;width:auto!important;max-width:46px!important;object-fit:cover!important;object-position:center!important;border-radius:3px!important;display:block!important;}
/* Mobile toggle */
.menu-btn{display:none!important;font-size:.85rem!important;font-weight:600!important;color:#0f2a7a!important;padding:.5rem .9rem!important;border-radius:8px!important;border:1px solid #e2e6f0!important;background:none!important;cursor:pointer!important;font-family:inherit!important;order:0!important;}
/* Hide OLD layout wrappers */
.navwrap,.header-right,.btn-donate:not(.btn-donate-nav){display:none!important;}
/* Dropdowns */
.dropdown{position:relative!important;}
.dropdown-content{display:none!important;position:absolute!important;top:calc(100% + .5rem)!important;left:0!important;background:#fff!important;border:1px solid #e2e6f0!important;border-radius:16px!important;box-shadow:0 24px 64px rgba(15,42,122,.18)!important;min-width:200px!important;z-index:500!important;overflow:hidden!important;}
.dropdown.open .dropdown-content{display:block!important;}
.dropdown-content a{display:block!important;padding:.65rem 1.1rem!important;font-size:.82rem!important;color:#3a4260!important;border-bottom:1px solid #f0f2f8!important;transition:all .25s!important;}
.dropdown-content a:last-child{border-bottom:none!important;}
.dropdown-content a:hover{background:#f0f2f8!important;color:#0f2a7a!important;padding-left:1.4rem!important;}
/* Mobile nav */
.mobile{display:none!important;position:fixed!important;inset:0!important;top:68px!important;background:#fff!important;z-index:900!important;overflow-y:auto!important;padding:1.5rem!important;flex-direction:column!important;gap:.75rem!important;}
.mobile.open{display:flex!important;}
.mob-section{font-size:.7rem!important;font-weight:700!important;color:#b0b8d0!important;letter-spacing:.1em!important;text-transform:uppercase!important;margin-top:1rem!important;}
.mob-grid{display:grid!important;grid-template-columns:1fr 1fr!important;gap:.5rem!important;}
.mob-grid a{padding:.7rem .9rem!important;border-radius:8px!important;background:#f0f2f8!important;font-size:.85rem!important;font-weight:500!important;color:#3a4260!important;}
.mob-donate{display:block!important;margin-top:1rem!important;background:#f5a623!important;color:#0f2a7a!important;text-align:center!important;font-weight:700!important;padding:1rem!important;border-radius:16px!important;font-size:1rem!important;}
@media(max-width:900px){
  .nav{display:none!important;}
  .header-actions .flag-video,.header-actions .flag-img{display:none!important;}
  .menu-btn{display:block!important;}
}


@media (max-width:480px){
  .brand-name{font-size:.95rem!important;}
  .brand-full{font-size:.58rem!important;white-space:normal!important;line-height:1.3!important;}
  .brand-pill{font-size:.5rem!important;}
  .brand img.logo-img{height:48px!important;}
  .header-inner{padding:.5rem .75rem!important;gap:.5rem!important;}
  .menu-btn{padding:.3rem .55rem!important;font-size:.78rem!important;}
}
@media (max-width:360px){
  .brand-full{display:none!important;}
  .brand-name{font-size:.9rem!important;}
}


/* Brand text — prevent overflow on narrow screens */
.brand-text-wrap{min-width:0;max-width:calc(100vw - 140px);}
.brand-full,.brand-name,.brand-pill{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.brand-full{max-width:200px;}
@media (max-width:520px){
  .flag-video,.flag-img{display:none!important;}
  .header-actions{gap:.4rem!important;}
  .btn-donate-nav{padding:.35rem .75rem!important;font-size:.75rem!important;}
}
