:root{
  --bg:#f3f4f6;
  --white:#ffffff;
  --text:#071226;
  --muted:#4f5d73;
  --line:#e8eef7;
  --line2:#efd4c2;
  --blue:#2a52ea;
  --indigo:#5b45e8;
  --orange:#f5762c;
  --orange-soft:#fff4eb;
  --dark:#061126;
  --shadow:0 24px 70px rgba(15,23,42,.08);
  --shadow-lg:0 28px 80px rgba(15,23,42,.12);
  --radius:28px;
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:Inter, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
}

a{
  text-decoration:none;
  color:inherit;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.logo{
  width:340px;
  height:auto;
}

.brand-text{
  display:flex;
  flex-direction:column;
}

.brand-top{
  font-size:11px;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:#2a52ea;
  font-weight:800;
}

.brand-main{
  font-size:20px;
  font-weight:900;
  line-height:1.1;
}

img{
  max-width:100%;
  display:block;
}

.container{
  width:min(1320px, calc(100% - 40px));
  margin:auto;
}

/* =========================
   HEADER
========================= */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line2);
}

.nav-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  min-height:96px;
  padding:10px 0;
}

.brand{
  display:flex;
  flex-direction:column;
  min-width:340px;
}

.brand-top{
  font-size:11px;
  letter-spacing:.40em;
  text-transform:uppercase;
  color:var(--blue);
  font-weight:800;
  margin-bottom:6px;
}

.brand-main{
  font-size:22px;
  font-weight:900;
  line-height:1.03;
  letter-spacing:-.03em;
  max-width:360px;
}

.nav{
  display:flex;
  align-items:center;
  gap:34px;
}

.nav a{
  font-size:15px;
  font-weight:700;
  color:#334155;
}

.nav a:hover,
.nav a.active{
  color:var(--blue);
}

.nav-cta{
  display:flex;
  align-items:center;
  gap:12px;
}

.menu-toggle{
  display:none;
  border:1px solid var(--line);
  background:#fff;
  border-radius:12px;
  padding:10px 14px;
  font-size:20px;
  cursor:pointer;
}

/* =========================
   BUTTONS
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:.25s ease;
  font-weight:800;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn-outline{
  border:1px solid #efccb6;
  color:var(--blue);
  background:#fff;
  border-radius:999px;
}

.btn-primary{
  background:linear-gradient(135deg,var(--blue),var(--indigo),var(--orange));
  color:#fff;
  border-radius:999px;
  box-shadow:0 10px 22px rgba(37,99,235,.18);
}

.nav-cta .btn{
  padding:9px 16px;
  font-size:13.5px;
  font-weight:800;
  white-space:nowrap;
  line-height:1.2;
}

.btn-dark{
  background:var(--dark);
  color:#fff;
  border-radius:14px;
  padding:15px 20px;
  min-width:168px;
  font-size:14px;
}

.btn-light{
  background:#fff;
  border:1px solid #cfd8e4;
  color:var(--text);
  border-radius:14px;
  padding:15px 20px;
  min-width:158px;
  font-size:14px;
}

.full{
  width:100%;
}

/* =========================
   HERO
========================= */
.hero{
  position:relative;
  overflow:hidden;
  padding:88px 0 44px;
}

.hero-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 4% 30%, rgba(90,179,255,.12), transparent 28%),
    radial-gradient(circle at 94% 18%, rgba(245,118,44,.10), transparent 24%),
    linear-gradient(90deg, #edf8ff 0%, #f3f4f6 38%, #f3f4f6 68%, #fff2e8 100%);
}

.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0, 1.08fr) minmax(420px, .92fr);
  gap:76px;
  align-items:start;
}

.hero-left{
  padding-top:6px;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid var(--line2);
  background:rgba(255,255,255,.82);
  color:var(--blue);
  font-size:12px;
  font-weight:800;
  letter-spacing:.15em;
  margin-bottom:26px;
  box-shadow:0 8px 20px rgba(15,23,42,.03);
}

.hero-title{
  margin:0;
  font-size:clamp(64px, 7.6vw, 65px);
  line-height:.92;
  letter-spacing:-.06em;
  font-weight:900;
  color:#071226;
  max-width:760px;
}

.grad-blue{
  color:#3155eb;
}

.grad-mix{
  background:linear-gradient(135deg,#3456eb 10%, #5a46e8 58%, #9f69b6 82%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.grad-orange{
  background:linear-gradient(135deg,#c4688b 0%, #e07056 45%, #f5762c 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.hero-desc{
  margin:26px 0 0;
  font-size:18px;
  line-height:1.85;
  color:#42536a;
  max-width:720px;
}

.hero-actions{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
  margin-top:18px;
}

.hero-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:24px;
  max-width:760px;
}

.hero-stat{
  background:rgba(255,255,255,.82);
  border:1px solid #efd9c9;
  border-radius:18px;
  padding:16px 14px;
  box-shadow:0 12px 28px rgba(15,23,42,.04);
}

.hero-stat strong{
  display:block;
  font-size:22px;
  line-height:1;
  font-weight:900;
  color:#0b132b;
  margin-bottom:6px;
}

.hero-stat span{
  display:block;
  font-size:13px;
  line-height:1.4;
  color:#5c6a7c;
  font-weight:600;
}

.hero-right{
  position:relative;
  padding-top:6px;
}

.focus-card{
  max-width:380px;
  margin:0 0 42px 34px;
  background:rgba(255,255,255,.82);
  border:1px solid #efd8c8;
  border-radius:22px;
  padding:16px 22px;
  box-shadow:var(--shadow);
}

.focus-label{
  font-size:12px;
  font-weight:900;
  letter-spacing:.32em;
  color:var(--blue);
  margin-bottom:8px;
}

.focus-text{
  font-size:14px;
  line-height:1.6;
  color:#4e5c71;
  font-weight:600;
}

.vision-shell{
  background:rgba(255,255,255,.68);
  border:1px solid #efd8c8;
  border-radius:32px;
  padding:14px;
  box-shadow:var(--shadow-lg);
}

.vision-card{
  border-radius:26px;
  padding:30px 30px 18px;
  background:linear-gradient(135deg,#2a52ea 0%, #5945e8 55%, #f5762c 100%);
  color:#fff;
  min-height:440px;
}

.vision-label{
  font-size:12px;
  font-weight:900;
  letter-spacing:.34em;
  color:#fff0e5;
  margin-bottom:16px;
}

.vision-card h2{
  margin:0 0 18px;
  font-size:32px;
  line-height:1.18;
  font-weight:900;
  max-width:460px;
}

.vision-card p{
  margin:0;
  font-size:16px;
  line-height:1.85;
  color:#f9edf0;
  max-width:470px;
}

.vision-mini-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
  margin-top:28px;
}

.vision-mini{
  background:rgba(255,255,255,.14);
  border-radius:18px;
  padding:16px 16px 14px;
  backdrop-filter:blur(8px);
}

.vision-mini span{
  display:block;
  font-size:11px;
  font-weight:900;
  letter-spacing:.24em;
  color:#ffe6d5;
  margin-bottom:8px;
}

.vision-mini strong{
  display:block;
  font-size:16px;
  line-height:1.35;
  color:#fff;
  font-weight:800;
}

/* =========================
   GENERIC SECTIONS
========================= */
.section{
  padding:90px 0;
}

.section-white{
  background:#fff;
}

.section-head{
  margin-bottom:34px;
}

.section-head.left{
  margin-bottom:0;
}

.section-head small{
  display:inline-flex;
  padding:10px 16px;
  border-radius:999px;
  border:1px solid #efd8c7;
  background:#fff;
  color:#2a52ea;
  font-size:12px;
  font-weight:800;
  letter-spacing:.24em;
  text-transform:uppercase;
}

.section-head h2{
  margin:18px 0 0;
  font-size:48px;
  line-height:1.05;
  letter-spacing:-.04em;
  font-weight:900;
  color:#08122d;
  max-width:820px;
}

.section-head p{
  margin:18px 0 0;
  max-width:780px;
  font-size:18px;
  color:#5a687b;
}

/* =========================
   ABOUT SECTION
========================= */
.two-col{
  display:grid;
  grid-template-columns:1.02fr 1.22fr;
  gap:42px;
  align-items:stretch;
}

.card-grid{
  display:grid;
  gap:24px;
}

.two-up{
  grid-template-columns:repeat(2,1fr);
}

.dark-card{
  background:#020b2d;
  color:#fff;
  border-radius:34px;
  padding:34px 36px 38px;
  min-height:588px;
  box-shadow:0 22px 55px rgba(15,23,42,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

.dark-card small{
  display:block;
  margin-bottom:22px;
  font-size:13px;
  line-height:1;
  font-weight:800;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:#ffb45c;
}

.dark-card h2{
  margin:0 0 24px;
  font-size:58px;
  line-height:.98;
  letter-spacing:-.05em;
  font-weight:900;
  color:#fff;
  max-width:520px;
}

.dark-card p{
  margin:0;
  max-width:500px;
  font-size:18px;
  line-height:1.95;
  color:rgba(255,255,255,.88);
}

.info-card{
  position:relative;
  background:rgba(255,255,255,.72);
  border:1px solid #efd8c7;
  border-radius:30px;
  padding:28px;
  min-height:250px;
  box-shadow:0 14px 36px rgba(15,23,42,.05);
  backdrop-filter:blur(6px);
}

.info-card::before{
  content:"";
  width:56px;
  height:56px;
  border-radius:18px;
  display:block;
  margin-bottom:26px;
  background:linear-gradient(135deg,#e8f0ff 0%, #f5e3d4 100%);
}

.info-card h3{
  margin:0 0 14px;
  font-size:26px;
  line-height:1.25;
  letter-spacing:-.03em;
  font-weight:900;
  color:#08122d;
  max-width:280px;
}

.info-card p{
  margin:0;
  font-size:17px;
  line-height:1.9;
  color:#4f5d73;
}

/* =========================
   COUNTERS
========================= */
.four-up{
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}

.counter-card{
  background:linear-gradient(to bottom,#ffffff 0%, #fff6ef 100%);
  border:1px solid #efd8c7;
  border-radius:26px;
  padding:28px 24px;
  min-height:220px;
  box-shadow:0 12px 32px rgba(15,23,42,.05);
}

.counter-card strong{
  display:block;
  font-size:52px;
  line-height:.95;
  font-weight:900;
  letter-spacing:-.04em;
  color:#08122d;
}

.counter-card span{
  display:block;
  margin-top:12px;
  font-size:20px;
  line-height:1.3;
  font-weight:900;
  color:#2a52ea;
}

.counter-card p{
  margin:14px 0 0;
  font-size:15px;
  line-height:1.8;
  color:#5a687b;
}

/* =========================
   PROGRAMS SECTION
========================= */
.programs-section{
  padding:96px 0 90px;
}

.programs-head{
  max-width:980px;
  margin-bottom:42px;
}

.programs-head small{
  display:inline-block;
  margin-bottom:18px;
  font-size:12px;
  line-height:1;
  font-weight:800;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:#2a52ea;
}

.programs-head h2{
  margin:0;
  max-width:900px;
  font-size:72px;
  line-height:.98;
  letter-spacing:-.055em;
  font-weight:900;
  color:#08122d;
}

.programs-head p{
  margin:24px 0 0;
  max-width:980px;
  font-size:18px;
  line-height:1.95;
  color:#4f5d73;
}

.programs-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
}

.program-card{
  display:flex;
  align-items:flex-start;
  gap:18px;
  min-height:118px;
  padding:28px 26px;
  background:rgba(255,255,255,.78);
  border:1px solid #d9e2ec;
  border-radius:30px;
  box-shadow:0 10px 24px rgba(15,23,42,.04), 0 2px 4px rgba(15,23,42,.03);
}

.program-dot{
  flex:0 0 16px;
  width:16px;
  height:16px;
  border-radius:50%;
  margin-top:4px;
  background:linear-gradient(135deg,#2a52ea 0%, #6d5ae8 55%, #f5762c 100%);
  box-shadow:0 0 0 4px rgba(42,82,234,.05);
}

.program-card h3{
  margin:0;
  font-size:20px;
  line-height:1.55;
  letter-spacing:-.02em;
  font-weight:800;
  color:#08122d;
  max-width:320px;
}

/* =========================
   DONATION SECTION
========================= */
.donation-section{
  padding:96px 0;
  background:#ffffff;
}

.donation-head{
  max-width:920px;
  margin-bottom:38px;
}

.donation-head small{
  display:inline-flex;
  padding:10px 16px;
  border-radius:999px;
  border:1px solid #efd8c7;
  background:#fff;
  color:#2a52ea;
  font-size:12px;
  font-weight:800;
  letter-spacing:.24em;
  text-transform:uppercase;
}

.donation-head h2{
  margin:18px 0 0;
  font-size:54px;
  line-height:1.04;
  letter-spacing:-.045em;
  font-weight:900;
  color:#08122d;
  max-width:760px;
}

.donation-head p{
  margin:18px 0 0;
  max-width:860px;
  font-size:18px;
  line-height:1.9;
  color:#556477;
}

.donation-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}

.donation-ui-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  background:#fff;
  border:1px solid #ecd7c8;
  border-radius:30px;
  padding:28px;
  box-shadow:0 14px 36px rgba(15,23,42,.05);
  min-height:360px;
}

.donation-badge{
  display:inline-flex;
  align-self:flex-start;
  padding:8px 12px;
  border-radius:999px;
  background:#fff4eb;
  color:#c45a1a;
  font-size:11px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.donation-ui-card h3{
  margin:18px 0 12px;
  font-size:28px;
  line-height:1.15;
  font-weight:900;
  color:#08122d;
}

.donation-ui-card p{
  margin:0 0 18px;
  font-size:16px;
  line-height:1.9;
  color:#556477;
}

.donation-meta{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:8px;
  font-size:14px;
  font-weight:800;
  color:#0f172a;
}

.donation-meta span:last-child{
  text-align:right;
}

.donation-progress{
  margin-top:14px;
  height:12px;
  background:#e8edf4;
  border-radius:999px;
  overflow:hidden;
}

.donation-progress span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(135deg,#2a52ea 0%, #5b45e8 58%, #f5762c 100%);
}

.donation-bottom{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:14px;
  margin-top:18px;
}

.donation-funded{
  font-size:12px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#2a52ea;
  white-space:nowrap;
}

.donation-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:12px 16px;
  border-radius:14px;
  background:#071226;
  color:#fff;
  font-size:14px;
  font-weight:800;
  width:100%;
}

@media (max-width: 1200px){
  .donation-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px){
  .donation-grid{
    grid-template-columns:1fr;
  }

  .donation-bottom{
    grid-template-columns:1fr;
  }

  .donation-meta{
    grid-template-columns:1fr;
  }

  .donation-meta span:last-child{
    text-align:left;
  }
}

/* =========================
   FOUNDER / NOTE
========================= */
.note-card{
  margin-top:24px;
  padding:24px;
  border:1px solid #ffe3cf;
  background:var(--orange-soft);
  border-radius:24px;
}

.note-card strong{
  display:block;
  color:#c2410c;
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:13px;
}

.founder-visual{
  min-height:360px;
  border-radius:32px;
  border:1px solid #ffe3cf;
  background:linear-gradient(135deg,#1d4ed8,#4f46e5,#f97316);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:22px;
  font-weight:900;
  box-shadow:0 28px 70px rgba(15,23,42,.16);
}

/* =========================
   GALLERY
========================= */
.gallery-slider{
  position:relative;
}

.gallery-track{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}

.gallery-item{
  min-height:280px;
  border-radius:28px;
  border:1px solid #ffe3cf;
  background:linear-gradient(135deg,#dbeafe,#fff,#ffedd5);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:20px;
  font-size:18px;
  font-weight:900;
  color:#334155;
  box-shadow:var(--shadow);
}

.gallery-item.static{
  min-height:250px;
}

.slider-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:46px;
  height:46px;
  border:none;
  border-radius:50%;
  background:#fff;
  box-shadow:var(--shadow);
  font-size:26px;
  font-weight:900;
  cursor:pointer;
  z-index:5;
}

.slider-btn.prev{
  left:-10px;
}

.slider-btn.next{
  right:-10px;
}

/* =========================
   IMPACT
========================= */
.impact-section{
  padding-top:20px;
}

.impact-box{
  background:linear-gradient(135deg,#020617,#0f172a,#172554);
  border-radius:34px;
  padding:42px;
  color:#fff;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:34px;
  border:1px solid #1f2937;
  box-shadow:0 30px 90px rgba(2,6,23,.32);
}

.impact-box h2{
  font-size:44px;
  line-height:1.1;
  margin:16px 0;
}

.impact-box p{
  color:#cbd5e1;
}

.impact-card{
  padding:28px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  border-radius:28px;
}

/* =========================
   FORMS
========================= */
.form-shell{
  background:#fff;
  border:1px solid #ffe3cf;
  border-radius:32px;
  padding:28px;
  box-shadow:var(--shadow);
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}

.form-grid input,
.form-grid textarea,
.form-grid select{
  width:100%;
  padding:16px 18px;
  border:1px solid #dbe4ef;
  border-radius:18px;
  font:inherit;
  outline:none;
  background:#fff;
}

.form-grid input:focus,
.form-grid textarea:focus,
.form-grid select:focus{
  border-color:#60a5fa;
  box-shadow:0 0 0 4px rgba(96,165,250,.12);
}

.form-grid textarea{
  min-height:130px;
  resize:vertical;
}

.span-2{
  grid-column:span 2;
}

/* =========================
   TIMELINE
========================= */
.timeline{
  display:grid;
  gap:20px;
}

.timeline-item{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:22px;
  background:#fff;
  border:1px solid #ffe3cf;
  border-radius:30px;
  padding:24px;
  box-shadow:var(--shadow);
}

.timeline-item p{
  color:#64748b;
}

.timeline-date{
  border-radius:22px;
  padding:22px;
  background:linear-gradient(135deg,#2563eb,#f97316);
  color:#fff;
  font-size:28px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}

/* =========================
   BLOG
========================= */
.blog-card{
  padding:28px;
  background:#fff;
  border:1px solid #ffe3cf;
  border-radius:28px;
  box-shadow:var(--shadow);
}

.blog-card span{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:#eff6ff;
  color:var(--blue);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.2em;
}

.blog-card h3{
  font-size:26px;
  line-height:1.2;
  margin:16px 0 10px;
  font-weight:900;
}

.blog-card p{
  color:#64748b;
}

.blog-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}

.blog-card{
  display:flex;
  flex-direction:column;
  background:#fff;
  border:1px solid #ffe3cf;
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow);
  min-height:280px;
}

.blog-card span{
  display:inline-flex;
  align-self:flex-start;
  padding:8px 12px;
  border-radius:999px;
  background:#eff6ff;
  color:var(--blue);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.2em;
}

.blog-card h3{
  margin:16px 0 12px;
  font-size:26px;
  line-height:1.2;
  font-weight:900;
  color:#08122d;
}

.blog-card p{
  margin:0;
  font-size:16px;
  line-height:1.85;
  color:#64748b;
}

@media (max-width: 1200px){
  .blog-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px){
  .blog-grid{
    grid-template-columns:1fr;
  }

  .blog-card{
    min-height:auto;
    padding:22px 20px;
  }

  .blog-card h3{
    font-size:22px;
  }
}

/* =========================
   TESTIMONIALS
========================= */
.testimonials-wrap{
  padding-top:20px;
}

.testimonial-card{
  padding:28px;
  background:#fff;
  border:1px solid #ffe3cf;
  border-radius:28px;
  box-shadow:var(--shadow);
}

.testimonial-card p{
  color:#64748b;
}

.testimonial-card .quote{
  font-size:60px;
  line-height:1;
  color:#fed7aa;
  font-weight:900;
}

.testimonial-card strong{
  display:block;
  margin-top:18px;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:13px;
}

.testimonial-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:24px;
}

.testimonial-card{
  background:#fff;
  border:1px solid #ffe3cf;
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:260px;
}

.testimonial-card .quote{
  font-size:60px;
  line-height:1;
  color:#fed7aa;
  font-weight:900;
}

.testimonial-card p{
  margin:10px 0 16px;
  font-size:16px;
  line-height:1.9;
  color:#64748b;
}

.testimonial-card strong{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:900;
  color:#0f172a;
}

@media (max-width:1200px){
  .testimonial-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:860px){
  .testimonial-grid{
    grid-template-columns:1fr;
  }
}

/* =========================
   FINAL CTA
========================= */
.final-cta-wrap{
  padding-top:30px;
}

.final-cta{
  display:grid;
  grid-template-columns:1fr auto;
  gap:30px;
  align-items:center;
  padding:40px;
  border-radius:36px;
  background:linear-gradient(135deg,#1d4ed8,#4f46e5,#f97316);
  color:#fff;
  box-shadow:0 36px 100px rgba(37,99,235,.22);
}

.final-cta h2{
  font-size:42px;
  line-height:1.1;
  margin:16px 0;
}

.final-cta p{
  color:#ffedd5;
}

.cta-buttons{
  display:flex;
  flex-direction:column;
  gap:14px;
}

/* =========================
   FOOTER
========================= */
.site-footer{
  background:#fff;
  border-top:1px solid #ffe3cf;
  padding:60px 0;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr 1fr;
  gap:28px;
}

.site-footer h3,
.site-footer h4{
  margin-top:0;
}

.site-footer p,
.site-footer li,
.site-footer a{
  color:#64748b;
}

.site-footer ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}

/* =========================
   INNER PAGES
========================= */
.inner-hero{
  padding:80px 0 30px;
  background:linear-gradient(to bottom,#f8fbff,#fff7ed);
}

.inner-hero h1{
  font-size:54px;
  line-height:1.1;
  margin:18px 0 12px;
}

.inner-hero p{
  color:#64748b;
  font-size:19px;
  max-width:780px;
}

.content-page{
  max-width:900px;
}

.content-page h2{
  font-size:34px;
  margin:0 0 10px;
}

.content-page p{
  color:#64748b;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 1200px){
  .hero-grid,
  .two-col,
  .impact-box,
  .final-cta,
  .footer-grid{
    grid-template-columns:1fr;
  }

  .focus-card{
    margin:0 0 28px 0;
    max-width:100%;
  }

  .vision-card{
    min-height:auto;
  }

  .hero-title{
    max-width:100%;
  }

  .hero-stats,
  .four-up{
    grid-template-columns:repeat(2,1fr);
  }

  .programs-head h2{
    font-size:58px;
    max-width:760px;
  }

  .programs-grid,
  .donation-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .dark-card{
    min-height:auto;
  }

  .donation-head h2{
    font-size:44px;
  }
}

@media (max-width: 860px){
  .container{
    width:min(100%, calc(100% - 28px));
  }

  .menu-toggle{
    display:block;
  }

  .nav{
    display:none;
    position:absolute;
    top:86px;
    left:14px;
    right:14px;
    background:#fff;
    border:1px solid #efd8c8;
    border-radius:22px;
    padding:18px;
    box-shadow:var(--shadow);
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }

  .nav.show{
    display:flex;
  }

  .nav-cta{
    display:none;
  }

  .brand{
    min-width:auto;
  }

  .brand-main{
    font-size:23px;
    max-width:260px;
  }

  .hero{
    padding:50px 0 24px;
  }

  .hero-title{
    font-size:clamp(46px, 13vw, 72px);
    line-height:.95;
  }

  .hero-desc{
    font-size:16px;
    line-height:1.8;
  }

  .hero-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .btn-dark,
  .btn-light{
    width:100%;
  }

  .hero-stats{
    grid-template-columns:1fr 1fr;
  }

  .vision-shell{
    padding:10px;
    border-radius:24px;
  }

  .vision-card{
    padding:24px 20px 18px;
    border-radius:20px;
  }

  .vision-card h2{
    font-size:26px;
  }

  .vision-mini-grid{
    grid-template-columns:1fr;
  }

  .two-up,
  .four-up,
  .programs-grid,
  .donation-grid,
  .form-grid{
    grid-template-columns:1fr;
  }

  .dark-card{
    padding:28px 22px 30px;
    border-radius:26px;
  }

  .dark-card h2{
    font-size:42px;
    max-width:100%;
  }

  .dark-card p{
    font-size:16px;
    line-height:1.85;
    max-width:100%;
  }

  .info-card{
    min-height:auto;
    border-radius:24px;
    padding:24px 22px;
  }

  .info-card h3{
    font-size:22px;
  }

  .info-card p{
    font-size:16px;
    line-height:1.8;
  }

  .counter-card{
    min-height:auto;
    padding:24px 20px;
  }

  .counter-card strong{
    font-size:42px;
  }

  .section-head h2{
    font-size:34px;
  }

  .programs-section,
  .donation-section{
    padding:72px 0;
  }

  .programs-head{
    margin-bottom:28px;
  }

  .programs-head h2{
    font-size:40px;
    line-height:1.04;
    max-width:100%;
  }

  .programs-head p{
    font-size:16px;
    line-height:1.85;
  }

  .program-card{
    min-height:auto;
    padding:22px 20px;
    border-radius:22px;
  }

  .program-card h3{
    font-size:18px;
    max-width:100%;
  }

  .program-dot{
    width:14px;
    height:14px;
    flex-basis:14px;
  }

  .donation-head{
    margin-bottom:28px;
  }

  .donation-head h2{
    font-size:34px;
    line-height:1.08;
    max-width:100%;
  }

  .donation-head p{
    font-size:16px;
    line-height:1.8;
  }

  .donation-ui-card{
    padding:22px 20px;
    border-radius:24px;
  }

  .donation-ui-card h3{
    font-size:24px;
  }

  .donation-meta{
    flex-direction:column;
    gap:4px;
  }

  .span-2{
    grid-column:span 1;
  }

  .timeline-item{
    grid-template-columns:1fr;
  }

  .timeline-date{
    min-height:100px;
  }

  .gallery-track{
    grid-template-columns:1fr;
  }

  .slider-btn{
    display:none;
  }
}

@media (max-width: 560px){
  .hero-stats{
    grid-template-columns:1fr;
  }

  .section-head h2{
    font-size:34px;
  }
}





.media-recognition-section{
  position:relative;
  overflow:hidden;
}
.media-proof-strip{
  margin:10px 0 28px;
  padding:24px 28px;
  border-radius:28px;
  background:linear-gradient(135deg,#0f172a,#1e3a8a 65%,#f97316 140%);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  box-shadow:0 28px 70px rgba(15,23,42,.18);
}
.media-proof-kicker{
  display:inline-block;
  margin-bottom:10px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.media-proof-strip h3{
  margin:0 0 8px;
  font-size:1.5rem;
  line-height:1.35;
}
.media-proof-strip p{
  margin:0;
  color:rgba(255,255,255,.84);
  line-height:1.8;
  max-width:780px;
}
.media-proof-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  white-space:nowrap;
  min-width:220px;
  padding:14px 22px;
  border-radius:16px;
  background:#fff;
  color:#0f172a;
  font-weight:800;
  text-decoration:none;
  box-shadow:0 16px 36px rgba(0,0,0,.16);
  border:none;
  cursor:pointer;
}

.media-grid-rich{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:22px;
}
.media-card-rich{
  padding:0;
  overflow:hidden;
  border-radius:26px;
  background:#fff;
  border:1px solid rgba(15,23,42,.06);
  box-shadow:0 16px 40px rgba(15,23,42,.06);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.media-card-rich:hover{
  transform:translateY(-5px);
  box-shadow:0 26px 55px rgba(15,23,42,.10);
  border-color:rgba(37,99,235,.14);
}
.media-card-rich.featured{
  background:linear-gradient(135deg,#fff7ed,#ffffff);
  border-color:rgba(249,115,22,.16);
}

.media-thumb{
  position:relative;
  display:block;
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  background:#e2e8f0;
  border:none;
  padding:0;
  cursor:pointer;
  text-align:left;
}
.media-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .45s ease;
  pointer-events:none;
}
.media-card-rich:hover .media-thumb img{
  transform:scale(1.06);
}
.media-video-thumb{
  appearance:none;
  -webkit-appearance:none;
}
.media-video-thumb::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(2,6,23,.58), rgba(2,6,23,.10));
  z-index:1;
  pointer-events:none;
}
.media-play{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:74px;
  height:74px;
  border-radius:999px;
  background:rgba(255,255,255,.94);
  color:#0f172a;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 20px 50px rgba(0,0,0,.22);
  z-index:2;
  pointer-events:none;
}
.media-play svg{
  width:34px;
  height:34px;
  margin-left:3px;
}
.media-overlay-label{
  position:absolute;
  left:16px;
  bottom:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(15,23,42,.78);
  color:#fff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  backdrop-filter:blur(8px);
  z-index:2;
  pointer-events:none;
}
.media-card-body{
  padding:24px;
}
.media-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
  flex-wrap:wrap;
}
.media-source{
  font-size:12px;
  font-weight:800;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:#ea580c;
}
.media-type{
  font-size:12px;
  font-weight:700;
  color:#475569;
  background:#f8fafc;
  border:1px solid rgba(15,23,42,.06);
  padding:7px 10px;
  border-radius:999px;
}
.media-card-body h3{
  margin:0 0 12px;
  font-size:1.2rem;
  line-height:1.5;
  color:#0f172a;
}
.media-card-body p{
  margin:0 0 18px;
  color:#475569;
  line-height:1.8;
}
.media-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:#1d4ed8;
  font-weight:800;
}
.media-link:hover{
  color:#ea580c;
}
.media-link-btn{
  background:none;
  border:none;
  padding:0;
  cursor:pointer;
  font:inherit;
}

.media-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:all .28s ease;
}
.media-modal.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.media-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,6,23,.76);
  backdrop-filter:blur(4px);
}
.media-modal-dialog{
  position:relative;
  z-index:2;
  width:min(1100px, 100%);
  border-radius:28px;
  background:#0b1120;
  box-shadow:0 30px 90px rgba(0,0,0,.45);
  padding:18px;
}
.media-modal-close{
  position:absolute;
  top:10px;
  right:12px;
  width:42px;
  height:42px;
  border:none;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  z-index:5;
}
.media-modal-frame-wrap{
  border-radius:20px;
  overflow:hidden;
  background:#000;
  aspect-ratio:16/9;
}
.media-modal-frame-wrap iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}
body.media-modal-open{
  overflow:hidden;
}

@media (max-width: 1100px){
  .founder-premium-grid,
  .founder-highlights,
  .credibility-metrics,
  .media-grid-rich{
    grid-template-columns:1fr;
  }
  .media-proof-strip{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media (max-width: 768px){
  .founder-message-card,
  .credibility-shell,
  .media-proof-strip,
  .media-modal-dialog{
    border-radius:22px;
    padding:20px;
  }
  .media-card-body{
    padding:20px;
  }
  .media-proof-btn{
    width:100%;
    min-width:0;
  }
  .media-modal{
    padding:14px;
  }
  .media-play{
    width:62px;
    height:62px;
  }
  .media-play svg{
    width:28px;
    height:28px;
  }
}

.media-video-launch{
  appearance:none;
  -webkit-appearance:none;
  text-align:left;
}

.media-video-launch .media-overlay-label{
  z-index:2;
}

.media-video-launch::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(2,6,23,.28), rgba(2,6,23,.04));
  z-index:1;
  pointer-events:none;
}

.media-inline-video-card{
  position:relative;
}

.media-inline-frame{
  width:100%;
  aspect-ratio:16/9;
  background:#000;
}

.media-inline-frame iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}

.media-thumb.is-hidden{
  display:none !important;
}


.founder-section-premium{
  padding:80px 0;
}

.founder-premium-grid{
  display:grid;
  grid-template-columns:1.25fr .95fr;
  gap:28px;
  align-items:start;
}

.founder-message-card{
  margin-top:28px;
  padding:28px;
  border-radius:28px;
  background:linear-gradient(135deg,#1e3772 0%, #233f86 100%);
  color:#fff;
  box-shadow:0 20px 50px rgba(18,33,78,.18);
}

.founder-message-top{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:16px;
}

.founder-badge{
  display:inline-flex;
  align-items:center;
  padding:10px 16px;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
  letter-spacing:.4px;
  background:#ff8c22;
  color:#fff;
}

.founder-badge-light{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
}

.founder-message-card blockquote{
  margin:0 0 16px;
  font-size:18px;
  line-height:1.7;
  font-weight:700;
}

.founder-message-card p{
  margin:0;
  font-size:16px;
  line-height:1.8;
  color:rgba(255,255,255,.92);
}

.founder-highlights{
  margin-top:20px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.founder-highlight{
  background:#fff;
  border:1px solid #e7ebf3;
  border-radius:20px;
  padding:22px 18px;
  box-shadow:0 10px 28px rgba(15,23,42,.05);
}

.founder-highlight strong{
  display:block;
  margin-bottom:10px;
  font-size:16px;
  color:#071c4d;
}

.founder-highlight span{
  display:block;
  font-size:15px;
  line-height:1.7;
  color:#5a6b8a;
}

.founder-credibility-panel .credibility-shell{
  padding:30px;
  border-radius:30px;
  background:linear-gradient(135deg,#f8fbff 0%, #fff7f0 100%);
  border:1px solid #e6edf8;
  box-shadow:0 18px 50px rgba(15,23,42,.07);
}

.credibility-label{
  display:inline-flex;
  align-items:center;
  padding:10px 16px;
  border-radius:999px;
  background:#e9eef9;
  color:#2150ff;
  font-size:13px;
  font-weight:800;
  letter-spacing:.6px;
  text-transform:uppercase;
  margin-bottom:18px;
}

.founder-credibility-panel h3{
  margin:6px 0 14px;
  font-size:24px;
  line-height:1.35;
  color:#071c4d;
}

.founder-credibility-panel p{
  margin:0 0 22px;
  font-size:16px;
  line-height:1.75;
  color:#51627f;
}

.credibility-wrapper{
  display:flex;
  flex-direction:column;
  gap:22px;
}

.credibility-image{
  width:100%;
}

.credibility-image img{
  display:block;
  width:100%;
  max-width:100%;
  height:420px;            /* image bigger */
  object-fit:cover;
  border-radius:22px;
  box-shadow:0 14px 38px rgba(0,0,0,.16);
}

.credibility-metrics{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.credibility-metric{
  background:#fff;
  border:1px solid #e7ebf3;
  border-radius:18px;
  padding:18px 14px;
  text-align:center;
  box-shadow:0 8px 24px rgba(15,23,42,.05);
}

.credibility-metric strong{
  display:block;
  margin-bottom:8px;
  font-size:30px;
  line-height:1.2;
  color:#071c4d;
}

.credibility-metric span{
  display:block;
  font-size:15px;
  line-height:1.5;
  color:#62728f;
}

@media (max-width: 1100px){
  .founder-premium-grid{
    grid-template-columns:1fr;
  }

  .credibility-image img{
    height:500px;
  }
}

@media (max-width: 767px){
  .founder-section-premium{
    padding:60px 0;
  }

  .founder-highlights{
    grid-template-columns:1fr;
  }

  .credibility-metrics{
    grid-template-columns:1fr;
  }

  .credibility-image img{
    height:340px;
    border-radius:18px;
  }

  .founder-credibility-panel .credibility-shell,
  .founder-message-card{
    padding:22px;
    border-radius:22px;
  }
}
