
:root {
  --primary: #0d47a1;
  --primary-dark: #082f6b;
  --primary-soft: #eaf2ff;
  --secondary: #1aa56d;
  --accent: #ffb54a;
  --ink: #102033;
  --muted: #64748b;
  --line: #dbe5f1;
  --surface: #ffffff;
  --surface-soft: #f7faff;
  --bg: #f4f7fb;
  --radius-xl: 30px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --shadow-sm: 0 10px 30px rgba(16,32,51,.06);
  --shadow-md: 0 20px 60px rgba(13,71,161,.14);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: 'Inter', sans-serif; color: var(--ink); background: var(--bg); overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { text-decoration: none; }
.page-shell { min-height: 100vh; display: flex; flex-direction: column; }
main { flex: 1; }
.topbar { background: var(--primary-dark); color: rgba(255,255,255,.92); font-size: .92rem; }
.topbar .wrap, .nav-wrap, .container-wide, .container-narrow { width: min(1240px, calc(100% - 32px)); margin: 0 auto; }
.topbar .wrap { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 10px 0; }
.social-mini, .contact-mini { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.social-mini a, .contact-mini a { color: rgba(255,255,255,.92); }
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.94); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(16,32,51,.06); }
.nav-wrap { display: flex; justify-content: space-between; align-items: center; gap: 18px; padding: 16px 0; }
.brand { display: flex; align-items: center; gap: 14px; min-width: 0; }
.brand img, .footer-brand img { width: 68px; height: 68px; border-radius: 18px; object-fit: contain; background: #fff; padding: 6px; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.brand-copy strong { display: block; font-family: 'Manrope', sans-serif; font-weight: 800; font-size: 1.1rem; color: var(--primary-dark); letter-spacing: -.03em; }
.brand-copy span { display: block; color: var(--muted); font-size: .8rem; max-width: 330px; line-height: 1.35; }
.nav-toggle { display: none; border: 1px solid var(--line); background: #fff; border-radius: 12px; padding: 10px 12px; cursor: pointer; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: var(--primary-dark); margin: 4px 0; }
.nav-links { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.nav-links a { color: var(--ink); font-weight: 600; padding: 12px 14px; border-radius: 999px; }
.nav-links a:hover, .nav-links a.active { background: var(--primary-soft); color: var(--primary); }
.btn-main, .btn-secondary, .btn-light { display: inline-flex; align-items: center; justify-content: center; gap: 10px; border-radius: 14px; padding: 14px 24px; font-weight: 700; transition: .25s ease; border: 1px solid transparent; }
.btn-main { background: linear-gradient(135deg, var(--primary), #245fd1); color: #fff; box-shadow: 0 14px 34px rgba(13,71,161,.2); }
.btn-main:hover { transform: translateY(-2px); color: #fff; }
.btn-secondary { background: #fff; color: var(--primary-dark); border-color: var(--line); }
.btn-secondary:hover { background: var(--primary-soft); }
.btn-light { background: rgba(255,255,255,.14); color: #fff; border-color: rgba(255,255,255,.18); }
.section { padding: 88px 0; }
.section-sm { padding: 64px 0; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; padding: 10px 14px; background: var(--primary-soft); color: var(--primary); border-radius: 999px; font-size: .85rem; font-weight: 800; letter-spacing: .04em; }
.eyebrow::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--secondary); }
.section-kicker { color: var(--secondary); text-transform: uppercase; letter-spacing: .18em; font-size: .74rem; font-weight: 800; margin-bottom: 10px; }
.section-title { font-family: 'Manrope', sans-serif; font-size: clamp(2rem, 4.5vw, 3.8rem); line-height: .98; letter-spacing: -.05em; color: var(--primary-dark); margin: 0 0 18px; }
.section-copy, .lead-copy { color: var(--muted); line-height: 1.85; font-size: 1rem; }
.section-header { display: flex; justify-content: space-between; gap: 28px; align-items: end; margin-bottom: 34px; }
.section-header > div:last-child { max-width: 460px; }
.hero-home { position: relative; padding: 72px 0 54px; background: radial-gradient(circle at top right, rgba(36,95,209,.18), transparent 32%), linear-gradient(180deg, #ffffff 0%, #f6f9ff 100%); }
.hero-grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 26px; align-items: stretch; }
.hero-copy { background: linear-gradient(135deg, var(--primary-dark), #2f65d1 80%); color: #fff; border-radius: 34px; padding: 48px; position: relative; overflow: hidden; box-shadow: var(--shadow-md); }
.hero-copy::after { content: ""; position: absolute; width: 280px; height: 280px; right: -90px; top: -90px; background: rgba(255,255,255,.08); border-radius: 50%; }
.hero-copy h1 { font-family: 'Manrope', sans-serif; font-size: clamp(2.6rem, 5vw, 5.2rem); line-height: .96; letter-spacing: -.06em; margin: 18px 0 18px; }
.hero-copy p { color: rgba(255,255,255,.88); line-height: 1.9; max-width: 680px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
.hero-visual { display: grid; grid-template-rows: minmax(420px, 1fr) auto; gap: 18px; }
.hero-photo { background: #dfe9f8; border-radius: 34px; overflow: hidden; min-height: 420px; box-shadow: var(--shadow-sm); }
.hero-photo img, .media-card img, .program-card img, .support-card img, .story-photo img, .impact-photo img { width: 100%; height: 100%; object-fit: cover; }
.mini-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.stat-box, .card, .info-card, .program-card, .support-card, .team-card, .contact-card, .donation-card, .quote-card, .timeline-card { background: #fff; border: 1px solid var(--line); border-radius: 24px; box-shadow: var(--shadow-sm); }
.stat-box { padding: 22px 18px; }
.stat-box strong { display: block; color: var(--primary); font-size: 1.8rem; font-family: 'Manrope', sans-serif; }
.stat-box span { color: var(--muted); line-height: 1.65; font-size: .95rem; }
.grid-2 { display: grid; grid-template-columns: 1.03fr .97fr; gap: 24px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.card, .quote-card, .timeline-card { padding: 28px; }
.card h3, .info-card h3, .program-card h3, .support-card h3, .team-card h3, .contact-card h3, .donation-card h3, .quote-card h3, .timeline-card h3 { font-family: 'Manrope', sans-serif; font-size: 1.45rem; color: var(--primary-dark); margin: 0 0 12px; letter-spacing: -.03em; }
.icon-badge { width: 52px; height: 52px; border-radius: 16px; display: inline-flex; align-items: center; justify-content: center; background: var(--primary-soft); color: var(--primary); font-weight: 800; margin-bottom: 14px; }
.highlight-panel { background: linear-gradient(135deg, var(--primary-dark), #225bc5); color: #fff; padding: 34px; border-radius: 28px; box-shadow: var(--shadow-md); }
.highlight-panel h3, .highlight-panel p, .highlight-panel li { color: #fff; }
.highlight-panel ul, .donation-card ul { padding-left: 18px; line-height: 1.9; margin: 20px 0 0; }
.value-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 18px; }
.value-pill { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 16px; font-weight: 700; text-align: center; color: var(--primary-dark); }
.program-card, .support-card, .team-card { overflow: hidden; }
.program-card img { height: 240px; }
.program-body, .support-body, .team-body { padding: 24px; }
.program-tag, .team-role { display: inline-flex; align-items: center; gap: 8px; font-size: .75rem; text-transform: uppercase; letter-spacing: .14em; font-weight: 800; color: var(--secondary); margin-bottom: 10px; }
.program-tag::before, .team-role::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--secondary); }
.banner-panel { background: linear-gradient(135deg, var(--primary-dark), #3166d4); color: #fff; border-radius: 32px; padding: 40px; position: relative; overflow: hidden; }
.banner-panel p, .banner-panel h2 { color: #fff; }
.banner-panel::after, .donation-card::after { content: ""; position: absolute; width: 320px; height: 320px; right: -100px; bottom: -120px; border-radius: 50%; background: rgba(255,255,255,.07); }
.page-hero { position: relative; min-height: 420px; display: grid; place-items: center; text-align: center; color: #fff; overflow: hidden; }
.page-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(.42); }
.page-hero .inner { position: relative; z-index: 2; width: min(980px, calc(100% - 32px)); }
.page-hero h1 { font-family: 'Manrope', sans-serif; font-size: clamp(2.8rem, 5vw, 4.8rem); line-height: .98; letter-spacing: -.05em; margin: 14px 0 16px; }
.page-hero p { color: rgba(255,255,255,.88); line-height: 1.9; font-size: 1.03rem; }
.media-split, .contact-layout, .story-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: 24px; align-items: stretch; }
.media-card, .copy-card, .story-photo, .story-copy, .impact-photo, .impact-copy { background: #fff; border: 1px solid var(--line); border-radius: 28px; overflow: hidden; box-shadow: var(--shadow-sm); }
.copy-card, .story-copy, .impact-copy { padding: 34px; }
.copy-card .section-title { font-size: clamp(2rem, 3.4vw, 3.2rem); }
.support-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.support-card img { height: 250px; }
.support-body p, .timeline-card p { color: var(--muted); line-height: 1.85; }
.team-card img { width: 100%; height: 320px; object-fit: cover; }
.team-social { display: flex; gap: 10px; margin-top: 18px; }
.team-social a { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 50%; color: var(--primary-dark); background: var(--surface-soft); }
.contact-card { padding: 28px; }
.contact-list { display: grid; gap: 16px; margin-top: 18px; }
.contact-item { padding: 18px; border: 1px solid var(--line); border-radius: 18px; background: var(--surface-soft); }
.contact-item strong { display: block; color: var(--primary-dark); margin-bottom: 8px; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.form-grid .full { grid-column: 1 / -1; }
.input, textarea { width: 100%; border: 1px solid var(--line); border-radius: 14px; padding: 14px 16px; font: inherit; background: #fff; color: var(--ink); }
textarea { min-height: 160px; resize: vertical; }
.donation-card { padding: 32px; background: linear-gradient(135deg, var(--primary-dark), #245fd1); color: #fff; overflow: hidden; position: relative; }
.donation-card h3, .donation-card p, .donation-card li { color: #fff; }
.site-footer { margin-top: 40px; background: #092a57; color: rgba(255,255,255,.85); }
.footer-grid { display: grid; grid-template-columns: 1.2fr .8fr .9fr .9fr; gap: 24px; padding: 72px 0 34px; }
.footer-brand { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.footer-brand strong { display: block; color: #fff; font-family: 'Manrope', sans-serif; font-size: 1.15rem; }
.footer-title { color: #fff; font-weight: 800; margin-bottom: 14px; }
.footer-links, .footer-links li { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 10px; }
.footer-links a { color: rgba(255,255,255,.82); }
.footer-links a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); padding: 18px 0 28px; display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.list-clean { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.list-clean li { display: flex; gap: 12px; color: var(--muted); line-height: 1.75; }
.list-clean li::before { content: '•'; color: var(--secondary); font-weight: 900; }
.founder-quote { font-family: 'Manrope', sans-serif; font-size: clamp(1.5rem, 2.5vw, 2.2rem); line-height: 1.3; color: var(--primary-dark); }
.reveal { opacity: 0; transform: translateY(24px); transition: .8s ease; }
.reveal.show { opacity: 1; transform: none; }
@media (max-width: 1100px) { .hero-grid, .grid-2, .media-split, .contact-layout, .story-grid, .section-header, .footer-grid { grid-template-columns: 1fr; } .section-header { display: grid; align-items: start; } .support-grid { grid-template-columns: 1fr 1fr; } .grid-3, .grid-4 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 900px) { .nav-toggle { display: block; } .nav-links { position: absolute; left: 16px; right: 16px; top: calc(100% + 10px); background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 12px; box-shadow: var(--shadow-sm); display: none; flex-direction: column; align-items: stretch; } .nav-links.open { display: flex; } .nav-links a { width: 100%; } .brand-copy span { display: none; } .hero-copy { padding: 34px 28px; } .mini-stats, .support-grid, .grid-3, .grid-4, .value-list, .form-grid { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .topbar .wrap { justify-content: center; } .contact-mini { justify-content: center; } .social-mini { display: none; } .section, .section-sm { padding: 68px 0; } .hero-home { padding-top: 42px; } .hero-copy h1, .page-hero h1 { line-height: 1; } .hero-photo { min-height: 320px; } .page-hero { min-height: 360px; } .copy-card, .card, .contact-card, .support-body, .program-body, .donation-card, .story-copy, .impact-copy { padding: 22px; } }

.team-showcase { background: linear-gradient(180deg, #f7faff 0%, #eef4ff 100%); }
.team-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 22px; }
.team-grid-featured .team-card.featured { grid-column: span 2; display: grid; grid-template-columns: .95fr 1.05fr; align-items: stretch; }
.team-grid-featured .team-card.featured img { height: 100%; min-height: 100%; }
.team-grid-featured .team-card.featured .team-body { display: flex; flex-direction: column; justify-content: center; }
.team-card { position: relative; transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease; }
.team-card::before { content: ""; position: absolute; inset: 0; border-radius: 24px; padding: 1px; background: linear-gradient(135deg, rgba(22,63,159,.18), rgba(77,121,226,.05)); -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
.team-card:hover { transform: translateY(-8px); box-shadow: 0 20px 50px rgba(12, 31, 77, .12); }
.team-card img { width: 100%; height: 340px; object-fit: cover; }
.team-body { display: flex; flex-direction: column; gap: 6px; }
.team-body h3 { margin-bottom: 2px; }
.team-role { color: var(--secondary); }
.team-role::before { background: var(--secondary); }
.team-social a:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.team-cta { margin-top: 26px; display: flex; justify-content: center; }
@media (max-width: 1100px) { .team-grid, .team-grid-featured { grid-template-columns: 1fr 1fr; } .team-grid-featured .team-card.featured { grid-column: span 2; } }
@media (max-width: 900px) { .team-grid, .team-grid-featured { grid-template-columns: 1fr; } .team-grid-featured .team-card.featured { grid-column: auto; grid-template-columns: 1fr; } .team-grid-featured .team-card.featured img { height: 340px; } }
