/* ============================================================
   HER PRIDE FOUNDATION — STYLESHEET
   Empowering · Bold · Community-Led
   Palette: Deep Navy · Amber/Gold · Teal · White
   Fonts: Playfair Display (display) · Lato (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&family=Lato:ital,wght@0,300;0,400;0,700;0,900;1,400&family=Montserrat:wght@400;500;600;700&display=swap');

/* ------------------------------------------------------------
   VARIABLES
   ------------------------------------------------------------ */
:root {
  --navy:        #0c537a;
  --navy-mid:    #0c537a;
  --navy-light:  #0e6090;
  --teal:        #2ABFBF;
  --teal-dark:   #1A9090;
  --teal-light:  rgba(42,191,191,0.15);
  --gold:        #F5A623;
  --gold-dark:   #D4891A;
  --gold-light:  rgba(245,166,35,0.15);
  --white:       #FFFFFF;
  --off-white:   #F8F9FA;
  --text:        #0D1B2A;
  --muted:       #6B7E8E;
  --border:      rgba(13,27,42,0.1);
  --border-light:rgba(255,255,255,0.12);

  --font-display: 'Playfair Display', serif;
  --font-body:    'Lato', sans-serif;
  --font-ui:      'Montserrat', sans-serif;

  --header-h: 72px;
  --max-w:    1200px;
  --r-sm:     8px;
  --r-md:     16px;
  --r-lg:     24px;

  --sh-sm: 0 2px 12px rgba(13,27,42,0.08);
  --sh-md: 0 6px 24px rgba(13,27,42,0.12);
  --sh-lg: 0 16px 48px rgba(13,27,42,0.18);
  --sh-xl: 0 24px 64px rgba(13,27,42,0.25);
  --sh-teal: 0 8px 32px rgba(42,191,191,0.25);
  --sh-gold: 0 8px 32px rgba(245,166,35,0.25);
}

/* ------------------------------------------------------------
   RESET
   ------------------------------------------------------------ */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--font-body);
  font-size:1rem;
  line-height:1.75;
  background:var(--off-white);
  color:var(--text);
  overflow-x:hidden;
}
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; height:auto; }
ul,ol { list-style:none; }
button { font-family:inherit; cursor:pointer; }

/* ------------------------------------------------------------
   LAYOUT
   ------------------------------------------------------------ */
.container { width:92%; max-width:var(--max-w); margin:0 auto; }

/* ------------------------------------------------------------
   ANIMATIONS
   ------------------------------------------------------------ */
@keyframes fadeUp   { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes marquee  { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes shimmer  { from{background-position:-200% 0} to{background-position:200% 0} }
@keyframes float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

.fade-in { opacity:0; transform:translateY(28px); transition:opacity .75s ease, transform .75s ease; }
.fade-in.show { opacity:1; transform:translateY(0); }

/* ------------------------------------------------------------
   PAGE TRANSITION
   ------------------------------------------------------------ */
.page-transition-overlay {
  position:fixed; inset:0; background:var(--navy);
  opacity:0; pointer-events:none; z-index:9999;
  transition:opacity .5s ease;
}
.page-transition-overlay.active { opacity:1; pointer-events:all; }

/* ------------------------------------------------------------
   HEADER
   ------------------------------------------------------------ */
.header {
  position:fixed; top:0; width:100%; height:var(--header-h);
  background:var(--white); z-index:1000;
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s ease, background .3s ease;
}
.header.scrolled { box-shadow:var(--sh-md); }

.nav-container {
  display:flex; align-items:center; justify-content:space-between;
  height:var(--header-h);
}
.logo { flex-shrink:0; }
.header-logo-img { height: 70px; width:auto; }

.nav { display:flex; align-items:center; gap:2rem; flex:1; justify-content:flex-end; }

.nav-links { display:flex; align-items:center; gap:1.6rem; }
.nav-links a {
  font-family:var(--font-ui);
  font-size:0.72rem; font-weight:600; color:var(--muted);
  text-transform:uppercase; letter-spacing:.1em;
  transition:color .2s; position:relative; padding-bottom:3px;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:2px; background:var(--teal);
  transition:width .25s ease;
}
.nav-links a:hover, .nav-links a.active { color:var(--navy); }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }

.nav-right { display:flex; align-items:center; gap:1rem; flex-shrink:0; }
.nav-socials { display:flex; gap:.7rem; }
.nav-socials a { font-size:1rem; color:var(--muted); transition:color .2s; }
.nav-socials a:hover { color:var(--teal); }

.nav-right .book-btn {
  font-family:var(--font-ui);
  font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  background:var(--teal); color:var(--white);
  padding:.6rem 1.5rem; border-radius:var(--r-sm); border:none;
  transition:background .2s, transform .2s, box-shadow .2s;
  white-space:nowrap;
}
.nav-right .book-btn:hover { background:var(--teal-dark); transform:translateY(-1px); box-shadow:var(--sh-teal); }

.nav-toggle { display:none; background:none; border:none; font-size:1.5rem; color:var(--text); padding:.3rem; line-height:1; }

/* ------------------------------------------------------------
   HERO — BASE
   ------------------------------------------------------------ */
.hero {
  margin-top:var(--header-h);
  min-height:calc(100vh - var(--header-h));
  background-size:cover; background-position:center; background-repeat:no-repeat;
  background-color:var(--navy);
  display:flex; align-items:flex-end;
  position:relative; overflow:hidden;
}
.hero::before {
  content:''; position:absolute; inset:0; z-index:1;
  background:linear-gradient(to top, rgba(13,27,42,.92) 0%, rgba(13,27,42,.45) 55%, rgba(13,27,42,.15) 100%);
}
.hero-content {
  position:relative; z-index:2;
  width:92%; max-width:var(--max-w); margin:0 auto;
  padding:5rem 0 4rem;
}

/* Homepage hero */
.hero-home .hero-content {
  display:grid; grid-template-columns:1.1fr 1fr; gap:3rem; align-items:flex-end;
}
.hero-tag {
  display:inline-block;
  font-family:var(--font-ui);
  font-size:.68rem; font-weight:700; letter-spacing:.2em;
  text-transform:uppercase; color:var(--gold);
  background:rgba(245,166,35,.15); border:1px solid rgba(245,166,35,.35);
  padding:.35rem .9rem; border-radius:4px; margin-bottom:1.5rem;
}
.hero-content h1 {
  font-family:var(--font-display); font-size:clamp(3.2rem,7.5vw,7rem);
  line-height:.95; color:var(--white);
  letter-spacing:-.01em; margin-bottom:1.5rem;
}
.hero-content h1 .accent { color:var(--teal); }
.hero-content h1 .gold { color:var(--gold); }
.hero-subtitle {
  font-family:var(--font-ui);
  font-size:.78rem; font-weight:500; letter-spacing:.12em;
  text-transform:uppercase; color:rgba(255,255,255,.6);
  margin-bottom:2.5rem; line-height:2;
}
.hero-buttons { display:flex; gap:1rem; flex-wrap:wrap; }

/* Sub-page hero */
.hero-sub { min-height:52vh; align-items:center; }
.hero-sub .hero-content { padding:3rem 0; }
.hero-eyebrow {
  display:block;
  font-family:var(--font-ui);
  font-size:.7rem; font-weight:700; letter-spacing:.2em;
  text-transform:uppercase; color:var(--gold); margin-bottom:1rem;
}
.hero-sub h1 {
  font-family:var(--font-display); font-size:clamp(3.5rem,10vw,9rem);
  line-height:.9; color:var(--white);
}

/* Hero images */
.hero-home    { background-image: url('/assets/images/cover1.webp'); background-size: cover; background-position: center; }
.hero-about   { background-image: url('/assets/images/cover2.webp'); background-size: cover; background-position: center; }
.hero-pillars { background-image: url('/assets/images/cover3.webp'); background-size: cover; background-position: center; }
.hero-programs{ background-image: url('/assets/images/cover4.webp'); background-size: cover; background-position: center; }
.hero-impact  { background-image: url('/assets/images/cover5.webp'); background-size: cover; background-position: center; }
.hero-involved{ background-image: url('/assets/images/cover6.webp'); background-size: cover; background-position: center; }
.hero-contact { background-image: url('/assets/images/cover2.webp'); background-size: cover; background-position: center; }

/* ------------------------------------------------------------
   BUTTONS
   ------------------------------------------------------------ */
.btn-primary {
  display:inline-block;
  font-family:var(--font-ui);
  font-size:.78rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  background:var(--teal); color:var(--white);
  padding:.9rem 2.2rem; border-radius:var(--r-sm); border:none;
  transition:background .2s, transform .2s, box-shadow .2s;
}
.btn-primary:hover { background:var(--teal-dark); transform:translateY(-2px); box-shadow:var(--sh-teal); }

.btn-gold {
  display:inline-block;
  font-family:var(--font-ui);
  font-size:.78rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  background:var(--gold); color:var(--navy);
  padding:.9rem 2.2rem; border-radius:var(--r-sm); border:none;
  transition:background .2s, transform .2s, box-shadow .2s;
}
.btn-gold:hover { background:var(--gold-dark); transform:translateY(-2px); box-shadow:var(--sh-gold); }

.btn-secondary {
  display:inline-block;
  font-family:var(--font-ui);
  font-size:.78rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  background:transparent; color:var(--white);
  padding:.9rem 2.2rem; border-radius:var(--r-sm);
  border:2px solid rgba(255,255,255,.45);
  transition:border-color .2s, background .2s;
}
.btn-secondary:hover { border-color:var(--white); background:rgba(255,255,255,.08); }

.btn-outline {
  display:inline-block;
  font-family:var(--font-ui);
  font-size:.78rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  background:transparent; color:var(--teal);
  padding:.9rem 2.2rem; border-radius:var(--r-sm);
  border:2px solid var(--teal);
  transition:background .2s, color .2s;
}
.btn-outline:hover { background:var(--teal); color:var(--white); }

/* ------------------------------------------------------------
   SECTION TYPOGRAPHY
   ------------------------------------------------------------ */
.section-label {
  display:block;
  font-family:var(--font-ui);
  font-size:.68rem; font-weight:700; letter-spacing:.2em;
  text-transform:uppercase; color:var(--teal);
  margin-bottom:.75rem;
}
.section-title {
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3.5vw,3rem);
  font-weight:700; line-height:1.15;
  color:var(--navy); margin-bottom:1.5rem;
}
.section-divider {
  width:56px; height:3px;
  background:var(--gold);
  margin-bottom:2.5rem;
  border-radius:2px;
}
.section-divider--center { margin-left:auto; margin-right:auto; }

section { padding:6rem 0; }

/* ------------------------------------------------------------
   FOOTER
   ------------------------------------------------------------ */
.footer { background:var(--navy); color:var(--white); }
.footer-accent-bar {
  height:4px;
  background:linear-gradient(90deg, var(--teal), var(--gold), var(--teal));
}
.footer-main { padding:4rem 0 0; }

.footer-grid {
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1.2fr;
  gap:3rem;
  padding-bottom:3rem;
}

.footer-brand {}
.footer-logo-img { height: 140px; width:auto; margin-bottom:1.25rem; filter:brightness(0) invert(1); }
.footer-brand-desc {
  font-size:.88rem; line-height:1.8;
  color:rgba(255,255,255,.55); margin-bottom:1.5rem;
}
.footer-socials { display:flex; gap:.75rem; }
.footer-social-btn {
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  font-size:.95rem; color:rgba(255,255,255,.7);
  transition:background .2s, color .2s, border-color .2s;
}
.footer-social-btn:hover { background:var(--teal); color:var(--white); border-color:var(--teal); }

.footer-col-heading {
  font-family:var(--font-ui);
  font-size:.7rem; font-weight:700; letter-spacing:.15em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:1.25rem;
}
.footer-nav-links { display:flex; flex-direction:column; gap:.6rem; }
.footer-nav-links a {
  font-size:.88rem; color:rgba(255,255,255,.55);
  transition:color .2s; padding-left:0;
}
.footer-nav-links a:hover { color:var(--teal); }

.footer-contact-list { display:flex; flex-direction:column; gap:.85rem; }
.footer-contact-item {
  display:flex; align-items:flex-start; gap:.75rem;
  font-size:.85rem; color:rgba(255,255,255,.55);
  transition:color .2s;
}
a.footer-contact-item:hover { color:var(--teal); }
.footer-contact-icon {
  width:28px; height:28px; border-radius:6px;
  background:rgba(42,191,191,.12); border:1px solid rgba(42,191,191,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:.75rem; color:var(--teal); flex-shrink:0; margin-top:.1rem;
}

.footer-profile-desc { font-size:.85rem; color:rgba(255,255,255,.5); margin-bottom:1.25rem; line-height:1.7; }
.footer-profile-btn {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--font-ui);
  font-size:.74rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  background:var(--gold); color:var(--navy);
  padding:.7rem 1.4rem; border-radius:var(--r-sm);
  transition:background .2s, transform .2s;
}
.footer-profile-btn:hover { background:var(--gold-dark); transform:translateY(-1px); }

.footer-divider { height:1px; background:rgba(255,255,255,.08); }

.footer-bottom {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:1rem;
  padding:1.5rem 0;
}
.footer-copy, .footer-tagline, .footer-location {
  font-size:.8rem; color:rgba(255,255,255,.35);
  font-family:var(--font-ui);
}
.footer-tagline { color:rgba(245,166,35,.5); font-style:italic; }

/* ------------------------------------------------------------
   HOME — HERO STATS
   ------------------------------------------------------------ */
.hero-stats {
  display:flex; flex-direction:column; gap:1.5rem;
  justify-content:flex-end; padding-bottom:.5rem;
}
.hero-stat {
  display:flex; align-items:center; gap:1rem;
  padding:1rem 1.25rem;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-md);
  backdrop-filter:blur(8px);
}
.hero-stat-num {
  font-family:var(--font-display);
  font-size:2rem; font-weight:700; color:var(--gold); line-height:1;
}
.hero-stat-label {
  font-family:var(--font-ui);
  font-size:.72rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.1em;
  color:rgba(255,255,255,.7); line-height:1.4;
}

/* ------------------------------------------------------------
   HOME — MISSION STRIP
   ------------------------------------------------------------ */
.mission-strip {
  background:var(--teal);
  padding:2rem 0;
  overflow:hidden;
}
.mission-strip-inner {
  display:flex; align-items:center; gap:3rem;
  flex-wrap:wrap; justify-content:center;
}
.mission-strip-item {
  display:flex; align-items:center; gap:.75rem;
  font-family:var(--font-ui);
  font-size:.75rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.12em;
  color:var(--white);
}
.mission-strip-dot {
  width:6px; height:6px; border-radius:50%;
  background:rgba(255,255,255,.5);
}

/* ------------------------------------------------------------
   HOME — ABOUT PREVIEW
   ------------------------------------------------------------ */
.about-preview {
  background:var(--white);
}
.about-preview-inner {
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:center;
}
.about-preview-image {
  position:relative;
}
.about-preview-image img {
  width:100%; border-radius:var(--r-lg);
  box-shadow:var(--sh-xl);
  aspect-ratio:4/5; object-fit:cover;
}
.about-preview-image::before {
  content:'';
  position:absolute; top:-16px; left:-16px;
  width:60%; height:60%;
  border:3px solid var(--teal);
  border-radius:var(--r-lg);
  z-index:-1;
}
.about-preview-badge {
  position:absolute; bottom:2rem; right:-2rem;
  background:var(--gold); color:var(--navy);
  padding:1rem 1.5rem; border-radius:var(--r-md);
  text-align:center; box-shadow:var(--sh-gold);
}
.about-preview-badge strong {
  display:block;
  font-family:var(--font-display);
  font-size:2.2rem; font-weight:700; line-height:1;
}
.about-preview-badge span {
  font-family:var(--font-ui);
  font-size:.65rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.1em;
}

/* ------------------------------------------------------------
   PILLARS PREVIEW (home)
   ------------------------------------------------------------ */
.pillars-preview { background:var(--white); }
.pillars-preview .section-label { color:var(--teal); }
.pillars-preview .section-title { color:var(--navy); }

.pillars-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1.5rem; margin-top:1rem;
}
.pillar-card {
  background:var(--navy);
  border:1px solid rgba(12,83,122,.12);
  border-radius:var(--r-lg);
  padding:2.5rem 2rem;
  transition:transform .3s, background .3s, border-color .3s, box-shadow .3s;
  position:relative; overflow:hidden;
}
.pillar-card::before {
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--teal), var(--gold));
  transform:scaleX(0); transform-origin:left;
  transition:transform .35s ease;
}
.pillar-card:hover { background:var(--navy-light); border-color:rgba(42,191,191,.35); transform:translateY(-4px); box-shadow:var(--sh-lg); }
.pillar-card:hover::before { transform:scaleX(1); }

.pillar-icon {
  width:56px; height:56px; border-radius:var(--r-md);
  background:rgba(42,191,191,.15);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; color:var(--teal);
  margin-bottom:1.5rem;
}
.pillar-card h3 {
  font-family:var(--font-display);
  font-size:1.3rem; font-weight:700;
  color:var(--white); margin-bottom:.75rem; line-height:1.2;
}
.pillar-card p {
  font-size:.88rem; color:rgba(255,255,255,.6);
  line-height:1.8;
}
.pillar-card a { color:var(--teal) !important; }

/* ------------------------------------------------------------
   IMPACT NUMBERS
   ------------------------------------------------------------ */
.impact-numbers {
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  position:relative; overflow:hidden;
}
.impact-numbers::before {
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:4px;
  background:linear-gradient(90deg, var(--teal), var(--gold), var(--teal));
}
.impact-numbers .section-title { color:var(--white); }

.numbers-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:2rem;
}
.number-item {
  text-align:center;
  padding:2.5rem 1.5rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-lg);
}
.number-item h3 {
  font-family:var(--font-display);
  font-size:clamp(2.5rem,4vw,3.5rem);
  font-weight:700; color:var(--gold);
  line-height:1; margin-bottom:.5rem;
}
.number-item p {
  font-family:var(--font-ui);
  font-size:.75rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.12em;
  color:rgba(255,255,255,.5);
}

/* ------------------------------------------------------------
   PROGRAMS PREVIEW (home)
   ------------------------------------------------------------ */
.programs-preview { background:var(--off-white); }

.programs-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
}
.program-card {
  background:var(--white);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--sh-sm);
  transition:transform .3s, box-shadow .3s;
  display:flex; flex-direction:column;
}
.program-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); }
.program-card-img {
  height:220px; overflow:hidden;
  background:var(--navy);
}
.program-card-img img {
  width:100%; height:100%; object-fit:cover; object-position:center 30%;
  transition:transform .4s;
}
.program-card:hover .program-card-img img { transform:scale(1.04); }
.program-card-body { padding:2rem; flex:1; display:flex; flex-direction:column; }
.program-card-num {
  font-family:var(--font-ui);
  font-size:.65rem; font-weight:700; letter-spacing:.15em;
  text-transform:uppercase; color:var(--teal);
  margin-bottom:.75rem;
}
.program-card h3 {
  font-family:var(--font-display);
  font-size:1.35rem; font-weight:700;
  color:var(--navy); margin-bottom:.75rem;
}
.program-card p { font-size:.9rem; color:var(--muted); line-height:1.8; flex:1; }

/* ------------------------------------------------------------
   PARTNERS MARQUEE
   ------------------------------------------------------------ */
.partners-section { background:var(--white); padding:4rem 0; overflow:hidden; }
.partners-section .section-label { text-align:center; margin-bottom:2rem; }

.marquee-track {
  display:flex; gap:3rem; align-items:center;
  animation:marquee 28s linear infinite;
  width:max-content;
}
.marquee-track:hover { animation-play-state:paused; }
.marquee-item {
  flex-shrink:0;
  font-family:var(--font-ui);
  font-size:.8rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:var(--muted);
  padding:.5rem 1.5rem;
  border:1px solid var(--border);
  border-radius:40px;
  white-space:nowrap;
  transition:color .2s, border-color .2s;
  height: 70px;       /* adjust to taste */
  width: auto;
}
.marquee-item:hover { color:var(--teal); border-color:var(--teal); }

/* ------------------------------------------------------------
   BOOKING CTA
   ------------------------------------------------------------ */
.booking-cta {
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 100%);
  text-align:center; padding:6rem 0;
  position:relative; overflow:hidden;
}
.booking-cta::before {
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(42,191,191,.15) 0%, transparent 70%);
  pointer-events:none;
}
.booking-cta .section-title { color:var(--white); }
.booking-cta p { color:rgba(255,255,255,.65); max-width:540px; margin:0 auto 2.5rem; font-size:1.05rem; }
.booking-cta .btn-group { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ------------------------------------------------------------
   ABOUT PAGE
   ------------------------------------------------------------ */
.about-page .section-label { color:var(--teal); }
.about-page .section-divider { background:var(--gold); }

.about-hero-layout {
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:start; padding:5rem 0;
}
.about-text h2 {
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:700; color:var(--navy);
  line-height:1.15; margin-bottom:1.5rem;
}
.about-text p { color:var(--muted); margin-bottom:1.25rem; font-size:.95rem; line-height:1.85; }

.founder-card {
  background:var(--white);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--sh-lg);
}
.founder-card-img {
  width:100%; aspect-ratio:3/4; object-fit:cover; object-position:top;
}
.founder-card-body { padding:2rem; }
.founder-card-name {
  font-family:var(--font-display);
  font-size:1.8rem; color:var(--navy); margin-bottom:.25rem;
}
.founder-card-title {
  font-family:var(--font-ui);
  font-size:.72rem; font-weight:700; letter-spacing:.15em;
  text-transform:uppercase; color:var(--teal); margin-bottom:1rem;
}
.founder-card-quote {
  font-size:.9rem; color:var(--muted); line-height:1.8;
  border-left:3px solid var(--gold); padding-left:1rem; font-style:italic;
}

.vision-mission-section { background:var(--navy); }
.vision-mission-section .section-title { color:var(--white); }
.vision-mission-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:2rem; margin-top:1rem;
}
.vm-card {
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-lg);
  padding:2.5rem;
}
.vm-card-icon {
  width:52px; height:52px; border-radius:var(--r-md);
  background:var(--gold-light); border:1px solid rgba(245,166,35,.3);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; color:var(--gold); margin-bottom:1.5rem;
}
.vm-card h3 {
  font-family:var(--font-display);
  font-size:1.6rem; color:var(--white); margin-bottom:1rem;
}
.vm-card p { color:rgba(255,255,255,.6); font-size:.9rem; line-height:1.8; }

/* Registration badge */
.reg-badge {
  display:inline-flex; align-items:center; gap:.75rem;
  background:var(--gold-light); border:1px solid rgba(245,166,35,.3);
  padding:.6rem 1.2rem; border-radius:40px; margin-top:1.5rem;
  font-family:var(--font-ui); font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--gold-dark);
}

/* ------------------------------------------------------------
   PILLARS PAGE
   ------------------------------------------------------------ */
.pillars-section { background:var(--white); }

.pillars-full-grid {
  display:flex; flex-direction:column; gap:5rem;
  margin-top:1rem;
}
.pillar-full {
  display:grid; grid-template-columns:80px 1fr;
  gap:2.5rem; align-items:start;
}
.pillar-full:nth-child(even) { }
.pillar-num {
  font-family:var(--font-display);
  font-size:5rem; font-weight:700;
  color:var(--teal-light); line-height:1;
  position:relative; top:-.5rem;
}
.pillar-full-content h3 {
  font-family:var(--font-display);
  font-size:2rem; font-weight:700;
  color:var(--navy); margin-bottom:.5rem;
}
.pillar-tag {
  display:inline-block;
  font-family:var(--font-ui);
  font-size:.65rem; font-weight:700; letter-spacing:.15em;
  text-transform:uppercase; color:var(--teal);
  background:var(--teal-light);
  padding:.25rem .75rem; border-radius:4px;
  margin-bottom:1rem;
}
.pillar-full-content p { color:var(--muted); line-height:1.85; font-size:.95rem; margin-bottom:1rem; }

.pillar-divider { height:1px; background:var(--border); }

/* ------------------------------------------------------------
   PROGRAMS PAGE
   ------------------------------------------------------------ */
.programs-section { background:var(--off-white); }

.programs-full-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:2rem; margin-top:1rem;
}
.program-full-card {
  background:var(--white);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--sh-sm);
  transition:transform .3s, box-shadow .3s;
}
.program-full-card:hover { transform:translateY(-4px); box-shadow:var(--sh-md); }
.program-full-img {
  height:240px; background:var(--navy-mid);
  overflow:hidden;

}
.program-full-img img { width:100%; height:100%; object-fit:cover; object-position:center 25%;}
.program-full-body { padding:2.5rem; }
.program-full-num {
  font-family:var(--font-ui); font-size:.65rem; font-weight:700;
  letter-spacing:.15em; text-transform:uppercase;
  color:var(--gold); margin-bottom:.75rem;
}
.program-full-card h3 {
  font-family:var(--font-display);
  font-size:1.5rem; color:var(--navy); margin-bottom:1rem;
}
.program-full-card p { color:var(--muted); font-size:.9rem; line-height:1.8; }

/* ------------------------------------------------------------
   IMPACT PAGE
   ------------------------------------------------------------ */
.footprint-section { background:var(--white); }

.footprint-stats {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:2rem; margin-top:1rem;
}
.footprint-stat {
  text-align:center;
  padding:3rem 2rem;
  border-radius:var(--r-lg);
  position:relative; overflow:hidden;
}
.footprint-stat:nth-child(1) { background:var(--teal); }
.footprint-stat:nth-child(2) { background:var(--navy); }
.footprint-stat:nth-child(3) { background:var(--gold); }
.footprint-stat h3 {
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3rem);
  font-weight:700; color:var(--white); margin-bottom:.5rem;
}
.footprint-stat:nth-child(3) h3 { color:var(--navy); }
.footprint-stat-label {
  font-family:var(--font-ui); font-size:.8rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  color:rgba(255,255,255,.8); margin-bottom:.5rem;
}
.footprint-stat:nth-child(3) .footprint-stat-label { color:rgba(13,27,42,.7); }
.footprint-stat p { font-size:.85rem; color:rgba(255,255,255,.7); line-height:1.7; }
.footprint-stat:nth-child(3) p { color:rgba(13,27,42,.6); }

.partners-grid-section { background:var(--off-white); }
.partners-logos-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(140px,1fr));
  gap:1rem;
  margin-top:1rem;
}
.partner-logo-item {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:1.25rem 1rem;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-ui); font-size:.78rem; font-weight:700;
  text-align:center; color:var(--muted);
  min-height:72px;
  transition:border-color .2s, color .2s;
}
.partner-logo-item:hover { border-color:var(--teal); color:var(--navy); }

/* ------------------------------------------------------------
   GET INVOLVED PAGE
   ------------------------------------------------------------ */
.get-involved-section { background:var(--white); }

.involved-grid {
  display:flex; flex-direction:column;
  gap:4rem; margin-top:1rem;
}
.involved-item {
  display:grid; grid-template-columns:1fr 1fr;
  gap:4rem; align-items:center;
}
.involved-item:nth-child(even) .involved-content { order:2; }
.involved-item:nth-child(even) .involved-visual { order:1; }

.involved-visual {
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--sh-lg); aspect-ratio:4/3;
  background:var(--navy-mid);
}
.involved-visual img { width:100%; height:100%; object-fit:cover; }

.involved-num {
  font-family:var(--font-display);
  font-size:5rem; font-weight:700;
  color:var(--gold-light); line-height:1;
  margin-bottom:.5rem;
}
.involved-content h3 {
  font-family:var(--font-display);
  font-size:2rem; color:var(--navy); margin-bottom:1rem;
}
.involved-content p { color:var(--muted); line-height:1.85; font-size:.95rem; margin-bottom:1.5rem; }

/* ------------------------------------------------------------
   CONTACT PAGE
   ------------------------------------------------------------ */
.contact-section { background:var(--white); }

.contact-layout {
  display:grid; grid-template-columns:1fr 1.5fr;
  gap:5rem;
}
.contact-info {}
.contact-big-title {
  font-family:var(--font-display);
  font-size:clamp(3rem,5vw,5rem);
  font-weight:900; line-height:.9;
  color:var(--navy); margin-bottom:1.5rem;
}
.contact-big-title span { color:var(--teal); }
.contact-tagline {
  font-size:1rem; color:var(--muted);
  line-height:1.8; margin-bottom:2.5rem;
  font-style:italic;
  border-left:3px solid var(--gold);
  padding-left:1.25rem;
}
.contact-items { display:flex; flex-direction:column; gap:1.25rem; }
.contact-item {
  display:flex; align-items:flex-start; gap:1rem;
}
.c-icon {
  width:44px; height:44px; border-radius:var(--r-md);
  background:var(--teal-light); border:1px solid rgba(42,191,191,.25);
  display:flex; align-items:center; justify-content:center;
  font-size:.95rem; color:var(--teal); flex-shrink:0;
}
.c-text strong {
  display:block; font-family:var(--font-ui);
  font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--navy); margin-bottom:.2rem;
}
.c-text a, .c-text span {
  font-size:.9rem; color:var(--muted);
  transition:color .2s;
}
.c-text a:hover { color:var(--teal); }

/* Contact form */
.contact-form-wrap h2 {
  font-family:var(--font-display);
  font-size:1.8rem; color:var(--navy); margin-bottom:2rem;
}
.contact-form { display:flex; flex-direction:column; gap:1.25rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.form-group { display:flex; flex-direction:column; gap:.4rem; }
.form-group label {
  font-family:var(--font-ui);
  font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--navy);
}
.form-group input,
.form-group textarea,
.form-group select {
  font-family:var(--font-body); font-size:.95rem;
  color:var(--text); background:var(--off-white);
  border:1.5px solid var(--border);
  border-radius:var(--r-sm); padding:.85rem 1rem;
  transition:border-color .2s, box-shadow .2s;
  outline:none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color:var(--teal);
  box-shadow:0 0 0 3px var(--teal-light);
}
.form-group textarea { resize:vertical; min-height:140px; }
.form-group.invalid input,
.form-group.invalid textarea { border-color:#e53e3e; }
.form-group.valid input,
.form-group.valid textarea { border-color:#38a169; }
.error-message { font-size:.78rem; color:#e53e3e; min-height:1em; }

.contact-form button[type="submit"] {
  font-family:var(--font-ui);
  font-size:.8rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  background:var(--teal); color:var(--white);
  border:none; padding:1rem 2.5rem;
  border-radius:var(--r-sm); cursor:pointer;
  transition:background .2s, transform .2s;
  display:flex; align-items:center; justify-content:center; gap:.5rem;
}
.contact-form button[type="submit"]:hover { background:var(--teal-dark); transform:translateY(-1px); }
.contact-form button[type="submit"]:disabled { opacity:.6; cursor:not-allowed; }
.loading-spinner { display:none; }
.form-success {
  display:none; background:#f0fff4;
  border:1px solid #38a169;
  color:#276749; padding:1rem 1.5rem;
  border-radius:var(--r-sm); font-size:.9rem; margin-bottom:1rem;
}

/* ------------------------------------------------------------
   TESTIMONIALS
   ------------------------------------------------------------ */
.testimonials-section { background:var(--off-white); }

.testimonials-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.testimonial {
  background:var(--white);
  border-radius:var(--r-lg);
  padding:2rem;
  box-shadow:var(--sh-sm);
  display:flex; flex-direction:column; gap:1.5rem;
  transition:box-shadow .3s;
}
.testimonial:hover { box-shadow:var(--sh-md); }
.testimonial-meta { display:flex; flex-direction:column; gap:.25rem; }
.testimonial-img {
  width:52px; height:52px; border-radius:var(--r-sm);
  object-fit:cover; margin-bottom:.5rem;
  border:2px solid var(--teal-light);
}
.t-org {
  font-family:var(--font-ui);
  font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--teal);
}
.t-person { font-size:.82rem; color:var(--muted); }
.testimonial-body p {
  font-size:.9rem; line-height:1.8;
  color:var(--text); font-style:italic;
  position:relative; padding-top:1rem;
}
.testimonial-body p::before {
  content:'"';
  font-family:var(--font-display);
  font-size:4rem; color:var(--gold-light);
  line-height:0; position:absolute; top:.5rem; left:-.5rem;
}

/* ------------------------------------------------------------
   IMPACT PAGE — 2026 PROJECTS
   ------------------------------------------------------------ */
.projects-2026-section { background:var(--white); }

.projects-2026-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  margin-top:1rem;
}
.project-card-2026 {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--sh-sm);
  transition:transform .3s, box-shadow .3s;
  display:flex; flex-direction:column;
}
.project-card-2026:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); }

.project-card-2026-top {
  background:var(--navy);
  padding:1.75rem 1.75rem 1.25rem;
}
.project-card-date {
  font-family:var(--font-ui);
  font-size:.68rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); margin-bottom:.5rem; display:block;
}
.project-card-2026-top h3 {
  font-family:var(--font-display);
  font-size:1.2rem; font-weight:700;
  color:var(--white); line-height:1.2; margin-bottom:.4rem;
}
.project-card-time {
  font-family:var(--font-ui);
  font-size:.72rem; font-weight:600;
  color:rgba(255,255,255,.5); letter-spacing:.06em;
}
.project-card-2026-body {
  padding:1.5rem 1.75rem;
  flex:1; display:flex; flex-direction:column; gap:1rem;
}
.project-card-2026-body p {
  font-size:.88rem; color:var(--muted); line-height:1.8; flex:1;
}
.project-impact-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:var(--teal-light);
  border:1px solid rgba(42,191,191,.25);
  padding:.35rem .85rem; border-radius:40px;
  font-family:var(--font-ui); font-size:.7rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--teal-dark);
  width:fit-content;
}
.project-needs-list {
  display:flex; flex-wrap:wrap; gap:.4rem;
}
.project-need-tag {
  background:var(--off-white);
  border:1px solid var(--border);
  border-radius:4px;
  padding:.2rem .65rem;
  font-family:var(--font-ui); font-size:.65rem; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase;
  color:var(--muted);
}
.project-card-2026-cta {
  padding:0 1.75rem 1.75rem;
}

/* ------------------------------------------------------------
   MOBILE NAV
   ------------------------------------------------------------ */
@media (max-width:900px) {
  .nav-links { display:none; flex-direction:column; }
  .nav-toggle { display:block; }

  .nav {
    position:fixed; top:var(--header-h); left:0; right:0;
    background:var(--white);
    flex-direction:column; align-items:stretch;
    padding:1.5rem; gap:1rem;
    border-bottom:1px solid var(--border);
    box-shadow:var(--sh-md);
    display:none;
  }
  .nav.active { display:flex; }
  .nav.active .nav-links { display:flex; }
  .nav-links a { font-size:.9rem; padding:.6rem 0; border-bottom:1px solid var(--border); }
  .nav-links a::after { display:none; }
  .nav-right { justify-content:center; }
  .nav-socials { display:none; }
}

/* ------------------------------------------------------------
   RESPONSIVE
   ------------------------------------------------------------ */
@media (max-width:1024px) {
  .footer-grid { grid-template-columns:1fr 1fr; gap:2.5rem; }
  .pillars-grid { grid-template-columns:1fr; }
  .about-preview-inner { grid-template-columns:1fr; gap:3rem; }
  .about-preview-badge { right:1rem; }
  .numbers-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
  section { padding:4rem 0; }
  .hero-home .hero-content { grid-template-columns:1fr; }
  .hero-stats { display:none; }
  .programs-grid { grid-template-columns:1fr; }
  .programs-full-grid { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .contact-layout { grid-template-columns:1fr; gap:3rem; }
  .form-row { grid-template-columns:1fr; }
  .vision-mission-grid { grid-template-columns:1fr; }
  .involved-item { grid-template-columns:1fr; }
  .involved-item:nth-child(even) .involved-content { order:unset; }
  .involved-item:nth-child(even) .involved-visual { order:unset; }
  .footprint-stats { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-grid .footer-col:last-child { grid-column: 1 / -1; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .about-hero-layout { grid-template-columns:1fr; gap:3rem; }
  .pillar-full { grid-template-columns:1fr; gap:1rem; }
  .pillar-num { font-size:3rem; top:0; }
}

@media (max-width:480px) {
  .hero-content h1 { font-size:clamp(2.8rem,10vw,4rem); }
  .numbers-grid { grid-template-columns:1fr 1fr; }
}