/* =============================================
   Mother India Foundation — Main Stylesheet
   Brand Color: #1a6fd4 | Accent: #f5c800
   ============================================= */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --blue: #1a6fd4;
  --dark-blue: #0d4fa0;
  --navy: #1a3a6b;
  --yellow: #f5c800;
  --green: #25d366;
  --text: #333;
  --muted: #666;
  --light-bg: #f7f9ff;
  --white: #fff;
  --radius: 14px;
  --shadow: 0 4px 20px rgba(26,111,212,0.12);
  --header-h: 87px;
}

/* =============================================
   TOPBAR
   ============================================= */
.topbar { background:var(--navy); color:rgba(255,255,255,0.85); font-family:'DM Sans',sans-serif; font-size:0.78rem; position:fixed; top:0; left:0; width:100%; z-index:1001; }
.topbar-inner { display:flex; align-items:center; justify-content:space-between; padding:7px 24px; flex-wrap:wrap; gap:8px; }
.topbar-left, .topbar-right { display:flex; align-items:center; gap:16px; }
.topbar-left a, .topbar-right a { color:rgba(255,255,255,0.8); display:flex; align-items:center; gap:5px; transition:color 0.2s; }
.topbar-left a:hover, .topbar-right a:hover { color:#fff; }
.topbar-tag { display:flex; align-items:center; gap:5px; color:var(--yellow); font-weight:700; }

/* =============================================
   HEADER
   ============================================= */
.header { position:fixed; top:36px; width:100%; z-index:1000; background:#fff; box-shadow:0 2px 20px rgba(26,111,212,0.1); transition:all 0.3s; }
.header.scrolled { box-shadow:0 4px 28px rgba(26,111,212,0.18); }
.header-inner { display:flex; align-items:center; justify-content:space-between; padding:12px 24px; gap:16px; }
.header-spacer { height:calc(var(--header-h) + 36px); display:none; } /* use only on non-hero pages */

.logo-img { height:60px; width:auto; object-fit:contain; filter:drop-shadow(0 2px 8px rgba(26,111,212,0.2)); transition:transform 0.3s; border-radius:50%; }
.logo-img:hover { transform:scale(1.05); }

/* =============================================
   MAIN NAV
   ============================================= */
.nav { display:flex; align-items:center; gap:2px; }
.nav-item { position:relative; }
.nav-link { display:flex; align-items:center; gap:5px; color:#333; font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:700; padding:8px 14px; border-radius:6px; transition:all 0.25s; white-space:nowrap; cursor:pointer; }
.nav-link:hover, .nav-item:hover > .nav-link, .nav-item.active > .nav-link { color:var(--blue); background:#eef4fd; }
.nav-item.active > .nav-link { color:var(--blue); }
.nav-arrow { font-size:0.65rem; transition:transform 0.3s; margin-left:2px; }
.nav-item:hover .nav-arrow { transform:rotate(180deg); }

/* =============================================
   STANDARD DROPDOWN
   ============================================= */
.dropdown-menu { position:absolute; top:calc(100% + 8px); left:0; min-width:220px; background:#fff; border-radius:12px; box-shadow:0 8px 40px rgba(26,111,212,0.15); padding:8px; opacity:0; visibility:hidden; transform:translateY(10px); transition:all 0.25s ease; z-index:500; border-top:3px solid var(--blue); }
.nav-item:hover .dropdown-menu { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown-menu a { display:flex; align-items:center; gap:10px; padding:9px 14px; border-radius:8px; font-family:'DM Sans',sans-serif; font-size:0.85rem; font-weight:600; color:#444; transition:all 0.2s; }
.dropdown-menu a:hover { background:#eef4fd; color:var(--blue); padding-left:18px; }
.dropdown-menu a i { width:16px; color:var(--blue); font-size:0.85rem; }
.dropdown-divider { height:1px; background:#f0f4f8; margin:6px 0; }
.dropdown-cta { background:linear-gradient(135deg,var(--blue),var(--dark-blue)) !important; color:#fff !important; border-radius:8px !important; justify-content:center; font-weight:700 !important; margin-top:4px; }
.dropdown-cta:hover { opacity:0.9; padding-left:14px !important; }
.dropdown-cta i { color:#fff !important; }

/* =============================================
   MEGA MENU
   ============================================= */
.mega-menu { position:absolute; top:calc(100% + 6px); left:50%; transform:translateX(-50%) translateY(8px); width:700px; background:#fff; border-radius:12px; box-shadow:0 8px 32px rgba(26,111,212,0.15); padding:0; opacity:0; visibility:hidden; transition:all 0.25s ease; z-index:500; border-top:3px solid var(--blue); overflow:hidden; }
.nav-item:hover .mega-menu { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.mega-menu-inner { display:grid; grid-template-columns:1fr 1fr 1fr 1.1fr; }
.mega-col { padding:18px 18px; border-right:1px solid #f0f4f8; }
.mega-col:last-child { border-right:none; }
.mega-heading { font-family:'DM Sans',sans-serif; font-size:0.68rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; color:var(--blue); margin-bottom:10px; padding-bottom:6px; border-bottom:2px solid #eef4fd; }
.mega-col ul { list-style:none; display:flex; flex-direction:column; gap:4px; }
.mega-col ul li a { display:flex; align-items:center; gap:8px; padding:5px 8px; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:0.82rem; font-weight:600; color:#444; transition:all 0.2s; }
.mega-col ul li a:hover { background:#eef4fd; color:var(--blue); padding-left:14px; }
.mega-col ul li a i { width:16px; color:var(--blue); font-size:0.82rem; flex-shrink:0; }
.mega-highlight-col { background:var(--light-bg); border-right:none !important; display:flex; align-items:center; justify-content:center; }
.mega-cta-card { text-align:center; padding:8px; }
.mega-cta-card img { width:100%; height:90px; object-fit:cover; border-radius:8px; margin-bottom:10px; }
.mega-cta-card h4 { font-family:'Playfair Display',serif; font-size:1rem; font-weight:900; color:var(--navy); margin-bottom:6px; }
.mega-cta-card p { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:#666; line-height:1.6; margin-bottom:14px; }
.mega-cta-btn { display:inline-block; padding:8px 20px; background:var(--blue); color:#fff; border-radius:30px; font-family:'DM Sans',sans-serif; font-size:0.82rem; font-weight:700; transition:all 0.25s; }
.mega-cta-btn:hover { background:var(--dark-blue); transform:translateY(-2px); }
.mega-stats-card { text-align:center; padding:8px; width:100%; }
.mega-stat { margin-bottom:16px; }
.mega-stat span { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:900; color:var(--blue); display:block; line-height:1; }
.mega-stat p { font-family:'DM Sans',sans-serif; font-size:0.78rem; color:#888; margin-top:2px; }

/* =============================================
   HEADER ACTIONS
   ============================================= */
.header-actions { display:flex; align-items:center; gap:10px; }
.header-search-btn { background:none; border:none; cursor:pointer; color:#555; font-size:1rem; width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all 0.25s; }
.header-search-btn:hover { background:#eef4fd; color:var(--blue); }
.nav-donate { font-family:'DM Sans',sans-serif !important; font-weight:800 !important; font-size:0.88rem !important; padding:10px 22px !important; border-radius:50px !important; background:linear-gradient(135deg,var(--blue),var(--dark-blue)) !important; color:#fff !important; box-shadow:0 4px 16px rgba(26,111,212,0.35); white-space:nowrap; display:inline-flex; align-items:center; gap:8px; transition:all 0.3s !important; }
.nav-donate:hover { transform:translateY(-2px) scale(1.04) !important; box-shadow:0 8px 24px rgba(26,111,212,0.45) !important; }

/* =============================================
   SEARCH BAR
   ============================================= */
.header-search-bar { background:#fff; border-top:1px solid #eef4fd; padding:0; max-height:0; overflow:hidden; transition:max-height 0.35s ease, padding 0.35s ease; }
.header-search-bar.open { max-height:80px; padding:14px 0; }
.search-form { display:flex; align-items:center; gap:10px; background:#f7f9ff; border-radius:50px; padding:8px 8px 8px 20px; border:2px solid #e0e8f5; transition:border-color 0.25s; }
.search-form:focus-within { border-color:var(--blue); }
.search-form input { flex:1; border:none; background:transparent; font-family:'DM Sans',sans-serif; font-size:0.95rem; color:#333; outline:none; }
.search-form button { background:none; border:none; cursor:pointer; color:#888; font-size:1rem; padding:6px 10px; border-radius:50px; transition:all 0.25s; }
.search-form button:hover { color:var(--blue); }
.search-form button[type="submit"] { background:var(--blue); color:#fff; padding:8px 18px; border-radius:50px; }

/* =============================================
   HAMBURGER
   ============================================= */
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.hamburger span { display:block; width:24px; height:3px; background:var(--blue); border-radius:4px; transition:all 0.3s; }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,6px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-6px); }

/* =============================================
   MOBILE NAV
   ============================================= */
@media (max-width:1024px) {
  .nav { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:#fff; flex-direction:column; align-items:flex-start; padding:80px 24px 40px; overflow-y:auto; z-index:999; gap:0; transform:translateX(-100%); transition:transform 0.35s ease; }
  .nav.nav-open { display:flex; transform:translateX(0); }
  .hamburger { display:flex; z-index:1001; position:relative; }
  .nav-item { width:100%; }
  .nav-link { width:100%; padding:14px 16px; border-radius:10px; font-size:1rem; border-bottom:1px solid #f0f4f8; }
  .nav-arrow { margin-left:auto; }
  .mega-menu, .dropdown-menu { position:static; transform:none; width:100%; box-shadow:none; border-radius:0; border-top:none; border-left:3px solid var(--blue); margin-left:16px; opacity:1; visibility:visible; display:none; background:#f7f9ff; }
  .nav-item.mobile-open .mega-menu,
  .nav-item.mobile-open .dropdown-menu { display:block; }
  .mega-menu-inner { grid-template-columns:1fr; }
  .mega-col { border-right:none; border-bottom:1px solid #e8f0fe; padding:16px; }
  .mega-highlight-col { display:none; }
  .topbar { display:none; }
  .header-spacer { height:var(--header-h); }
}
@media (max-width:768px) {
  .header-inner { padding:10px 16px; }
  .logo-img { height:50px; }
}

body { font-family:'Poppins',sans-serif; color:var(--text); overflow-x:hidden; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; height:auto; }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ---- BUTTONS ---- */
.btn { display:inline-flex; align-items:center; gap:8px; padding:12px 28px; border-radius:50px; font-weight:700; font-size:0.95rem; cursor:pointer; transition:all 0.3s; border:none; }
.btn-primary { background:linear-gradient(135deg,var(--blue),var(--dark-blue)); color:#fff; box-shadow:0 4px 16px rgba(26,111,212,0.35); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(26,111,212,0.45); }
.btn-outline { background:transparent; color:#fff; border:2px solid #fff; }
.btn-outline:hover { background:#fff; color:var(--navy); }
.btn-yellow { background:var(--yellow); color:#222; font-weight:800; }
.btn-yellow:hover { background:#e6b800; transform:translateY(-2px); }
.btn-ghost { background:transparent; color:var(--blue); border:2px solid var(--blue); }
.btn-ghost:hover { background:var(--blue); color:#fff; }
.btn-lg { padding:16px 40px; font-size:1.05rem; }

/* ---- HEADER ---- */
.header { position:fixed; top:0; width:100%; z-index:1000; background:#fff; box-shadow:0 4px 24px rgba(26,111,212,0.12); border-bottom:3px solid var(--blue); transition:all 0.3s; }
.header-inner { display:flex; align-items:center; justify-content:space-between; padding:10px 24px; gap:16px; }
.logo-img { height:64px; width:auto; object-fit:contain; filter:drop-shadow(0 4px 12px rgba(26,111,212,0.25)); transition:transform 0.3s; border-radius:50%; }
.logo-img:hover { transform:scale(1.06); }
.nav { display:flex; align-items:center; gap:4px; }
.nav-link { display:flex; align-items:center; gap:5px; color:#444; font-family:'Nunito','Poppins',sans-serif; font-size:0.88rem; font-weight:800; padding:7px 13px; border-radius:50px; transition:all 0.25s; }
.nav-icon { font-size:0.85rem; color:var(--blue); transition:transform 0.3s; }
.nav-link:hover { background:#eef4fd; color:var(--blue); transform:translateY(-2px); }
.nav-link.active { background:var(--blue); color:#fff; box-shadow:0 4px 12px rgba(26,111,212,0.3); }
.nav-link.active .nav-icon { color:#fff; }
.nav-donate { font-family:'Nunito','Poppins',sans-serif !important; font-weight:900 !important; font-size:0.9rem !important; padding:10px 22px !important; border-radius:50px !important; background:linear-gradient(135deg,var(--blue),var(--dark-blue)) !important; color:#fff !important; box-shadow:0 4px 16px rgba(26,111,212,0.35); white-space:nowrap; }
.nav-donate:hover { transform:translateY(-3px) scale(1.05) !important; }
.header-actions { display:flex; align-items:center; gap:12px; }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.hamburger span { display:block; width:24px; height:3px; background:var(--blue); border-radius:4px; transition:all 0.3s; }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,6px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-6px); }

/* ---- HERO ---- */
.hero { margin-top:0; min-height:100vh; position:relative; overflow:hidden; background:#0a0a1a; }
.hero-slides { width:100%; min-height:100vh; position:relative; }
.hero-slide { position:absolute; inset:0; min-height:100vh; display:flex; align-items:center; opacity:0; transition:opacity 0.9s ease; pointer-events:none; }
.hero-slide.active { opacity:1; position:relative; pointer-events:auto; min-height:100vh; }
.hero-slide-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to right,rgba(0,0,0,0.78) 45%,rgba(0,0,0,0.3) 100%); z-index:1; }
.hero-content { position:relative; z-index:2; padding:160px 60px 80px; max-width:700px; }
.hero-tag { font-size:1.1rem; font-weight:800; color:#fff; letter-spacing:0.04em; margin-bottom:6px; text-transform:uppercase; }
.hero-script { font-family:'Dancing Script',cursive; font-size:5rem; font-weight:700; color:var(--yellow); line-height:1.1; margin-bottom:20px; text-shadow:2px 4px 16px rgba(0,0,0,0.3); }
.hero-sub { color:rgba(255,255,255,0.88); font-family:'DM Sans',sans-serif; font-size:1rem; margin-bottom:32px; line-height:1.75; max-width:500px; }
.hero-btns { display:flex; gap:16px; flex-wrap:wrap; }
.hero-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:10; width:48px; height:48px; border-radius:50%; border:2px solid rgba(255,255,255,0.5); background:rgba(0,0,0,0.3); color:#fff; font-size:1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.3s; backdrop-filter:blur(4px); }
.hero-arrow:hover { background:var(--blue); border-color:var(--blue); }
.hero-arrow-prev { left:24px; }
.hero-arrow-next { right:24px; }
.hero-dots { position:absolute; bottom:28px; left:50%; transform:translateX(-50%); z-index:10; display:flex; gap:10px; }
.hero-dot { width:10px; height:10px; border-radius:50%; border:2px solid rgba(255,255,255,0.6); background:transparent; cursor:pointer; transition:all 0.3s; padding:0; }
.hero-dot.active { background:#fff; border-color:#fff; width:28px; border-radius:6px; }

/* ---- HEROF BANNER ---- */
.herof-wrapper { position:relative; z-index:10; margin-top:-48px; width:100%; overflow:visible; }
.herof-img { width:100%; height:auto; display:block; }

/* ---- ABOUT SECTION ---- */
.about-wrapper { padding:40px 60px 10px; background:#fff; }
.about-section { display:flex; align-items:stretch; background:#fff; overflow:hidden; }
.about-content-col { width:55%; padding:50px 52px; display:flex; flex-direction:column; justify-content:center; gap:16px; }
.about-image-col { width:45%; flex-shrink:0; overflow:hidden; }
.about-img { width:100%; height:100%; object-fit:cover; display:block; }
.about-eyebrow { font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue); }
.about-org-name { font-family:'Playfair Display',serif; font-size:3rem; font-weight:900; color:#111; line-height:1.15; }
.about-org-name em { color:var(--blue); font-style:italic; }
.about-para { font-family:'DM Sans',sans-serif; font-size:1rem; color:#4a4a4a; line-height:1.85; }
.about-tax { font-family:'DM Sans',sans-serif; font-size:0.82rem; color:#555; background:#eef4fd; padding:10px 14px; border-left:3px solid var(--blue); }
.about-actions { display:flex; align-items:center; gap:20px; flex-wrap:wrap; margin-top:4px; }
.about-donate-btn { font-family:'DM Sans',sans-serif; display:inline-flex; align-items:center; gap:8px; font-weight:700; padding:12px 28px; border-radius:50px; background:var(--blue); color:#fff; box-shadow:0 4px 14px rgba(26,111,212,0.35); transition:all 0.3s; }
.about-donate-btn:hover { background:var(--dark-blue); transform:translateY(-2px); }
.about-contact { font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:700; color:var(--green); display:flex; align-items:center; gap:6px; }

/* ---- MISSION SECTION ---- */
.mission-section { padding:80px 60px; background:#fff url('../../asset/msn.png') no-repeat center center; background-size:cover; }
.mission-header { text-align:center; margin-bottom:56px; }
.mission-eyebrow { font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue); margin-bottom:10px; }
.mission-header h2 { font-family:'Playfair Display',serif; font-size:2.6rem; font-weight:900; color:#111; margin-bottom:12px; }
.mission-header h2 span { color:var(--blue); font-style:italic; }
.mission-sub { font-family:'DM Sans',sans-serif; font-size:1rem; color:#777; max-width:520px; margin:0 auto; line-height:1.7; }
.mission-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:40px 32px; max-width:1100px; margin:0 auto; }
.mission-card { text-align:center; padding:10px 16px; }
.mission-icon-wrap { width:80px; height:80px; margin:0 auto 20px; display:flex; align-items:center; justify-content:center; position:relative; }
.mission-icon-wrap::before { content:''; position:absolute; inset:0; border-radius:50%; background:radial-gradient(circle,rgba(26,111,212,0.1) 0%,transparent 70%); }
.mission-icon-wrap i { font-size:2.4rem; color:var(--navy); position:relative; z-index:1; }
.mission-card h4 { font-family:'DM Sans',sans-serif; font-size:1.05rem; font-weight:800; color:var(--blue); margin-bottom:10px; }
.mission-card p { font-family:'DM Sans',sans-serif; font-size:0.88rem; color:#666; line-height:1.75; }

/* ---- QTS BANNER ---- */
.qts-banner { width:100%; line-height:0; }
.qts-img { width:100%; height:auto; display:block; }

/* ---- PROGRAMS SECTION ---- */
.programs-section { padding:70px 60px; background:var(--light-bg) url('../../asset/prs.png') no-repeat center center; background-size:cover; overflow:hidden; }
.programs-top { display:flex; align-items:flex-start; justify-content:space-between; gap:40px; margin-bottom:48px; }
.programs-heading { max-width:340px; }
.programs-heading h2 { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:900; color:var(--navy); line-height:1.2; margin-bottom:16px; }
.programs-heading h2 span { color:var(--blue); }
.programs-heading p { font-family:'DM Sans',sans-serif; font-size:0.88rem; color:#666; line-height:1.75; }
.programs-stats { display:flex; flex-direction:column; align-items:flex-start; gap:24px; padding-top:8px; }
.prog-stat-label { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:#888; font-weight:500; }
.prog-stat-num { font-family:'Playfair Display',serif; font-size:2.8rem; font-weight:900; color:var(--blue); line-height:1; }
.prog-slider-arrows { display:flex; gap:10px; }
.prog-arrow { width:40px; height:40px; border-radius:50%; border:2px solid var(--blue); background:#fff; color:var(--blue); font-size:0.9rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.25s; box-shadow:0 2px 8px rgba(26,111,212,0.2); }
.prog-arrow:hover { background:var(--blue); color:#fff; transform:scale(1.1); }
.prog-track-wrap { overflow:hidden; padding-bottom:12px; margin-bottom:-12px; }
.prog-track { display:flex; gap:20px; transition:transform 0.45s cubic-bezier(0.4,0,0.2,1); padding-bottom:4px; }
.prog-card { min-width:260px; max-width:260px; background:#fff; border-radius:var(--radius); overflow:visible; box-shadow:0 2px 16px rgba(0,0,0,0.07); display:flex; flex-direction:column; flex-shrink:0; transition:transform 0.3s,box-shadow 0.3s; cursor:pointer; }
.prog-card > *:first-child { border-radius:var(--radius) var(--radius) 0 0; overflow:hidden; }
.prog-card:hover { transform:translateY(-6px); box-shadow:0 10px 28px rgba(26,111,212,0.14); }
.prog-card-text { padding:20px 18px 14px; flex:1; }
.prog-card-text h4 { font-family:'DM Sans',sans-serif; font-size:0.95rem; font-weight:700; color:var(--navy); margin-bottom:8px; line-height:1.4; }
.prog-card-text p { font-family:'DM Sans',sans-serif; font-size:0.82rem; color:#777; line-height:1.65; }
.prog-tag { display:inline-block; margin-top:10px; background:#eef4fd; color:var(--blue); font-size:0.72rem; font-weight:700; padding:4px 10px; border-radius:20px; }
.prog-card-img { height:170px; overflow:hidden; }
.prog-card-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.4s; }
.prog-card:hover .prog-card-img img { transform:scale(1.06); }
.prog-know-btn { display:block; text-align:center; margin:14px 18px 18px; padding:9px 0; border:2px solid var(--navy); border-radius:30px; font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:700; letter-spacing:0.08em; color:var(--navy); transition:all 0.25s; position:relative; z-index:2; }
.prog-know-btn:hover { background:transparent; border-color:var(--navy); color:var(--navy); }

/* ---- GALLERY ---- */
.gallery-section { padding:80px 0; background:var(--light-bg); }
.gallery-section .container { text-align:center; margin-bottom:40px; }
.gallery-eyebrow { font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue); margin-bottom:10px; }
.gallery-heading { font-family:'Playfair Display',serif; font-size:2.4rem; font-weight:900; color:#111; margin-bottom:12px; }
.gallery-heading span { color:var(--blue); font-style:italic; }
.gallery-sub { font-family:'DM Sans',sans-serif; font-size:0.95rem; color:#777; max-width:480px; margin:0 auto; line-height:1.7; }
.gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:220px; gap:8px; padding:0 8px; }
.gallery-item { position:relative; overflow:hidden; border-radius:10px; cursor:pointer; }
.gallery-item.gallery-tall { grid-row:span 2; }
.gallery-item.gallery-wide { grid-column:span 2; }
.gallery-item img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.5s ease; }
.gallery-item:hover img { transform:scale(1.08); }
.gallery-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(10,30,80,0.82) 0%,rgba(10,30,80,0.2) 60%,transparent 100%); opacity:0; transition:opacity 0.35s ease; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay i { font-size:1.6rem; color:#fff; background:rgba(26,111,212,0.7); width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.gallery-overlay span { font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:700; color:#fff; }
.gallery-filter-btns { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; margin-bottom:32px; }
.filter-btn { padding:8px 20px; border-radius:30px; border:2px solid var(--blue); background:transparent; color:var(--blue); font-weight:700; font-size:0.85rem; cursor:pointer; transition:all 0.25s; }
.filter-btn.active, .filter-btn:hover { background:var(--blue); color:#fff; }

/* ---- LIGHTBOX ---- */
.lightbox { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.92); z-index:9999; align-items:center; justify-content:center; backdrop-filter:blur(6px); }
.lightbox.active { display:flex; }
.lightbox-img-wrap { position:relative; max-width:90vw; max-height:88vh; display:flex; flex-direction:column; align-items:center; gap:12px; }
.lightbox-img-wrap img { max-width:90vw; max-height:80vh; object-fit:contain; border-radius:10px; box-shadow:0 20px 60px rgba(0,0,0,0.6); }
.lightbox-caption { font-family:'DM Sans',sans-serif; font-size:0.9rem; color:rgba(255,255,255,0.75); text-align:center; }
.lightbox-close { position:fixed; top:20px; right:24px; background:rgba(255,255,255,0.15); border:none; color:#fff; width:44px; height:44px; border-radius:50%; font-size:1.2rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.25s; z-index:10000; }
.lightbox-close:hover { background:var(--blue); }
.lightbox-nav { position:fixed; top:50%; transform:translateY(-50%); background:rgba(255,255,255,0.15); border:none; color:#fff; width:48px; height:48px; border-radius:50%; font-size:1.1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.25s; z-index:10000; }
.lightbox-nav:hover { background:var(--blue); }
.lightbox-prev { left:20px; }
.lightbox-next { right:20px; }

/* ---- EVENTS ---- */
.events-section { padding:80px 0; background:#fff; }
.events-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:40px; }
.events-eyebrow { font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue); margin-bottom:8px; }
.events-heading { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:900; color:#111; }
.events-heading span { color:var(--blue); font-style:italic; }
.events-arrows { display:flex; gap:10px; }
.events-arrow { width:40px; height:40px; border-radius:50%; border:2px solid var(--blue); background:transparent; color:var(--blue); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.25s; }
.events-arrow:hover { background:var(--blue); color:#fff; }
.events-track-wrap { overflow:hidden; }
.events-track { display:flex; gap:24px; transition:transform 0.45s cubic-bezier(0.4,0,0.2,1); }
.event-card { min-width:320px; max-width:320px; background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); flex-shrink:0; transition:transform 0.3s,box-shadow 0.3s; }
.event-card:hover { transform:translateY(-6px); box-shadow:0 12px 32px rgba(26,111,212,0.15); }
.event-img-wrap { position:relative; height:200px; overflow:hidden; }
.event-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.event-card:hover .event-img-wrap img { transform:scale(1.06); }
.event-tag { position:absolute; top:14px; left:14px; background:var(--blue); color:#fff; font-size:0.72rem; font-weight:700; padding:4px 12px; border-radius:20px; }
.event-body { padding:20px; }
.event-body h4 { font-family:'DM Sans',sans-serif; font-size:0.95rem; font-weight:700; color:var(--navy); margin-bottom:8px; line-height:1.4; }
.event-body p { font-family:'DM Sans',sans-serif; font-size:0.82rem; color:#777; line-height:1.65; margin-bottom:16px; }
.event-footer { display:flex; align-items:center; justify-content:space-between; }
.event-date { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:#888; display:flex; align-items:center; gap:6px; }
.event-btn { font-family:'DM Sans',sans-serif; font-size:0.8rem; font-weight:700; color:var(--blue); border:2px solid var(--blue); padding:6px 16px; border-radius:20px; transition:all 0.25s; }
.event-btn:hover { background:var(--blue); color:#fff; }

/* ---- TESTIMONIALS ---- */
.testimonials-section { display:flex; min-height:500px; }
.testi-left { width:40%; background:linear-gradient(135deg,var(--navy),var(--blue)); color:#fff; padding:60px 48px; display:flex; align-items:center; flex-shrink:0; }
.testi-left-inner { max-width:360px; width:100%; }
.testi-badge { display:flex; align-items:center; gap:12px; margin-bottom:24px; }
.testi-badge i { font-size:1.5rem; color:var(--yellow); }
.testi-badge-label { font-size:0.75rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.7); }
.testi-badge-title { font-size:0.9rem; font-weight:700; color:#fff; }
.testi-left-inner h2 { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:900; line-height:1.2; margin-bottom:16px; }
.testi-left-inner h2 span { color:var(--yellow); }
.testi-left-inner p { font-family:'DM Sans',sans-serif; font-size:0.9rem; color:rgba(255,255,255,0.8); line-height:1.75; margin-bottom:28px; }
.testi-stats { display:flex; gap:32px; margin-bottom:28px; }
.testi-stat span { font-family:'Playfair Display',serif; font-size:2rem; font-weight:900; color:var(--yellow); display:block; }
.testi-stat p { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:rgba(255,255,255,0.7); }
.testi-arrows { display:flex; gap:10px; }
.testi-arrow { width:40px; height:40px; border-radius:50%; border:2px solid rgba(255,255,255,0.4); background:transparent; color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.25s; }
.testi-arrow:hover { background:rgba(255,255,255,0.2); }
.testi-right { width:60%; background:var(--light-bg); padding:60px 40px; overflow:hidden; min-width:0; }
.testi-track-wrap { overflow:hidden; }
.testi-track { display:flex; gap:20px; transition:transform 0.45s cubic-bezier(0.4,0,0.2,1); }
.testi-card { min-width:300px; max-width:300px; background:#fff; border-radius:var(--radius); padding:28px; box-shadow:var(--shadow); flex-shrink:0; }
.testi-stars { color:var(--yellow); font-size:0.9rem; margin-bottom:12px; display:flex; gap:3px; }
.testi-quote { font-size:1.8rem; color:var(--blue); opacity:0.3; margin-bottom:8px; }
.testi-card p { font-family:'DM Sans',sans-serif; font-size:0.88rem; color:#555; line-height:1.8; margin-bottom:20px; }
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--blue),var(--navy)); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1rem; flex-shrink:0; overflow:hidden; }
.testi-avatar img { width:100%; height:100%; object-fit:cover; }
.testi-author strong { font-family:'DM Sans',sans-serif; font-size:0.9rem; font-weight:700; color:#222; display:block; }
.testi-author span { font-family:'DM Sans',sans-serif; font-size:0.78rem; color:#888; }

/* ---- VOLUNTEER SECTION ---- */
.volunteer-section { padding:80px 60px; background:linear-gradient(135deg,#f0f6ff,#e8f0fe); }
.volunteer-inner { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; max-width:1100px; margin:0 auto; }
.volunteer-eyebrow { font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue); margin-bottom:10px; }
.volunteer-text h2 { font-family:'Playfair Display',serif; font-size:2.4rem; font-weight:900; color:#111; margin-bottom:16px; }
.volunteer-text h2 span { color:var(--blue); font-style:italic; }
.volunteer-text p { font-family:'DM Sans',sans-serif; font-size:0.95rem; color:#555; line-height:1.8; margin-bottom:20px; }
.volunteer-perks { list-style:none; display:flex; flex-direction:column; gap:10px; }
.volunteer-perks li { font-family:'DM Sans',sans-serif; font-size:0.9rem; color:#444; display:flex; align-items:center; gap:10px; }
.volunteer-perks li i { color:var(--blue); }
.volunteer-form-wrap { background:#fff; border-radius:20px; padding:36px; box-shadow:0 8px 32px rgba(26,111,212,0.12); }
.volunteer-form h3 { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:var(--navy); margin-bottom:24px; }
.vform-group { margin-bottom:16px; }
.vform-group label { display:block; font-family:'DM Sans',sans-serif; font-size:0.82rem; font-weight:700; color:#555; margin-bottom:6px; }
.vform-group input, .vform-group select, .vform-group textarea { width:100%; padding:11px 16px; border:2px solid #e0e8f5; border-radius:10px; font-family:'DM Sans',sans-serif; font-size:0.9rem; color:#333; transition:border-color 0.25s; background:#fff; }
.vform-group input:focus, .vform-group select:focus, .vform-group textarea:focus { outline:none; border-color:var(--blue); }
.vform-group textarea { resize:vertical; min-height:90px; }
.vform-submit { width:100%; padding:14px; background:linear-gradient(135deg,var(--blue),var(--dark-blue)); color:#fff; border:none; border-radius:50px; font-family:'DM Sans',sans-serif; font-size:1rem; font-weight:700; cursor:pointer; transition:all 0.3s; display:flex; align-items:center; justify-content:center; gap:8px; }
.vform-submit:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(26,111,212,0.4); }

/* ---- CAMPAIGNS ---- */
.campaigns-section { padding:80px 0; background:#fff; }
.section-header { text-align:center; margin-bottom:48px; }
.section-eyebrow { font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue); margin-bottom:10px; }
.section-title { font-family:'Playfair Display',serif; font-size:2.4rem; font-weight:900; color:#111; margin-bottom:12px; }
.section-title span { color:var(--blue); font-style:italic; }
.section-sub { font-family:'DM Sans',sans-serif; font-size:0.95rem; color:#777; max-width:520px; margin:0 auto; line-height:1.7; }
.campaigns-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.campaign-card { background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); transition:transform 0.3s,box-shadow 0.3s; }
.campaign-card:hover { transform:translateY(-6px); box-shadow:0 12px 32px rgba(26,111,212,0.15); }
.campaign-img { height:220px; overflow:hidden; position:relative; }
.campaign-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.campaign-card:hover .campaign-img img { transform:scale(1.06); }
.campaign-badge { position:absolute; top:14px; left:14px; background:var(--blue); color:#fff; font-size:0.72rem; font-weight:700; padding:4px 12px; border-radius:20px; }
.campaign-badge.urgent { background:#e74c3c; }
.campaign-body { padding:20px; }
.campaign-body h4 { font-family:'DM Sans',sans-serif; font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:8px; line-height:1.4; }
.campaign-body p { font-family:'DM Sans',sans-serif; font-size:0.85rem; color:#777; line-height:1.65; margin-bottom:16px; }
.campaign-progress { margin-bottom:16px; }
.progress-bar-wrap { background:#e8f0fe; border-radius:10px; height:8px; overflow:hidden; margin-bottom:8px; }
.progress-bar-fill { height:100%; background:linear-gradient(90deg,var(--blue),var(--dark-blue)); border-radius:10px; transition:width 1s ease; }
.progress-stats { display:flex; justify-content:space-between; font-family:'DM Sans',sans-serif; font-size:0.78rem; color:#888; }
.progress-stats strong { color:var(--blue); }
.campaign-footer { display:flex; align-items:center; justify-content:space-between; gap:10px; }
.campaign-donors { font-family:'DM Sans',sans-serif; font-size:0.78rem; color:#888; display:flex; align-items:center; gap:5px; }
.campaign-share { display:flex; gap:8px; }
.share-btn { width:30px; height:30px; border-radius:50%; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:0.75rem; transition:all 0.25s; }
.share-fb { background:#1877f2; color:#fff; }
.share-wa { background:#25d366; color:#fff; }
.share-tw { background:#1da1f2; color:#fff; }
.donate-campaign-btn { display:block; text-align:center; margin:16px 20px 20px; padding:11px; background:linear-gradient(135deg,var(--blue),var(--dark-blue)); color:#fff; border-radius:50px; font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:700; transition:all 0.3s; }
.donate-campaign-btn:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(26,111,212,0.4); }

/* ---- IMPACT COUNTER ---- */
.impact-section { padding:70px 0; background:linear-gradient(135deg,var(--navy),var(--blue)); color:#fff; }
.impact-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.impact-item { text-align:center; padding:32px 20px; }
.impact-icon { font-size:2.5rem; color:var(--yellow); margin-bottom:16px; }
.impact-num { font-family:'Playfair Display',serif; font-size:3rem; font-weight:900; color:#fff; display:block; line-height:1; margin-bottom:8px; }
.impact-item p { font-family:'DM Sans',sans-serif; font-size:0.9rem; color:rgba(255,255,255,0.8); }

/* ---- DONATE PAGE ---- */
.donate-page { padding:80px 0; background:var(--light-bg); }
.donate-grid { display:grid; grid-template-columns:1.2fr 1fr; gap:48px; align-items:start; }
.donate-form-card { background:#fff; border-radius:20px; padding:40px; box-shadow:0 8px 32px rgba(26,111,212,0.1); }
.donate-form-card h2 { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:900; color:var(--navy); margin-bottom:8px; }
.donate-form-card p { font-family:'DM Sans',sans-serif; font-size:0.9rem; color:#777; margin-bottom:28px; }
.donate-type-tabs { display:flex; gap:0; margin-bottom:28px; border:2px solid var(--blue); border-radius:50px; overflow:hidden; }
.donate-tab { flex:1; padding:10px; text-align:center; font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:700; cursor:pointer; transition:all 0.25s; background:transparent; color:var(--blue); border:none; }
.donate-tab.active { background:var(--blue); color:#fff; }
.amount-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:20px; }
.amount-btn { padding:12px; border:2px solid #e0e8f5; border-radius:10px; background:#fff; font-family:'DM Sans',sans-serif; font-size:0.95rem; font-weight:700; color:var(--navy); cursor:pointer; transition:all 0.25s; text-align:center; }
.amount-btn:hover, .amount-btn.active { border-color:var(--blue); background:#eef4fd; color:var(--blue); }
.custom-amount-wrap { position:relative; margin-bottom:20px; }
.custom-amount-wrap span { position:absolute; left:16px; top:50%; transform:translateY(-50%); font-weight:700; color:var(--blue); font-size:1.1rem; }
.custom-amount-wrap input { width:100%; padding:12px 16px 12px 36px; border:2px solid #e0e8f5; border-radius:10px; font-size:1rem; font-weight:700; color:var(--navy); }
.custom-amount-wrap input:focus { outline:none; border-color:var(--blue); }
.donate-info-card { background:linear-gradient(135deg,var(--navy),var(--blue)); color:#fff; border-radius:20px; padding:36px; }
.donate-info-card h3 { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:900; margin-bottom:20px; }
.donate-impact-list { list-style:none; display:flex; flex-direction:column; gap:14px; margin-bottom:28px; }
.donate-impact-list li { display:flex; align-items:flex-start; gap:12px; font-family:'DM Sans',sans-serif; font-size:0.88rem; color:rgba(255,255,255,0.9); line-height:1.6; }
.donate-impact-list li i { color:var(--yellow); font-size:1rem; margin-top:2px; flex-shrink:0; }
.trust-badges { display:flex; flex-wrap:wrap; gap:10px; }
.trust-badge { background:rgba(255,255,255,0.15); color:#fff; font-family:'DM Sans',sans-serif; font-size:0.78rem; font-weight:700; padding:6px 14px; border-radius:20px; display:flex; align-items:center; gap:6px; }

/* ---- BLOG ---- */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.blog-card { background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); transition:transform 0.3s,box-shadow 0.3s; }
.blog-card:hover { transform:translateY(-6px); box-shadow:0 12px 32px rgba(26,111,212,0.15); }
.blog-img { height:200px; overflow:hidden; position:relative; }
.blog-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.blog-card:hover .blog-img img { transform:scale(1.06); }
.blog-cat { position:absolute; top:14px; left:14px; background:var(--blue); color:#fff; font-size:0.72rem; font-weight:700; padding:4px 12px; border-radius:20px; }
.blog-body { padding:20px; }
.blog-meta { display:flex; align-items:center; gap:12px; font-family:'DM Sans',sans-serif; font-size:0.78rem; color:#aaa; margin-bottom:10px; }
.blog-body h4 { font-family:'DM Sans',sans-serif; font-size:0.98rem; font-weight:700; color:var(--navy); margin-bottom:8px; line-height:1.4; }
.blog-body p { font-family:'DM Sans',sans-serif; font-size:0.85rem; color:#777; line-height:1.65; margin-bottom:16px; }
.blog-read-more { font-family:'DM Sans',sans-serif; font-size:0.85rem; font-weight:700; color:var(--blue); display:flex; align-items:center; gap:6px; transition:gap 0.25s; }
.blog-read-more:hover { gap:10px; }

/* ---- CONTACT ---- */
.contact-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:48px; align-items:start; }
.contact-info-card { background:linear-gradient(135deg,var(--navy),var(--blue)); color:#fff; border-radius:20px; padding:40px; }
.contact-info-card h3 { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:900; margin-bottom:8px; }
.contact-info-card p { font-family:'DM Sans',sans-serif; font-size:0.9rem; color:rgba(255,255,255,0.8); margin-bottom:28px; line-height:1.7; }
.contact-info-list { list-style:none; display:flex; flex-direction:column; gap:18px; margin-bottom:28px; }
.contact-info-list li { display:flex; align-items:flex-start; gap:14px; font-family:'DM Sans',sans-serif; font-size:0.9rem; color:rgba(255,255,255,0.9); }
.contact-info-list li i { color:var(--yellow); font-size:1.1rem; margin-top:2px; flex-shrink:0; }
.contact-form-card { background:#fff; border-radius:20px; padding:40px; box-shadow:0 8px 32px rgba(26,111,212,0.1); }
.contact-form-card h3 { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:900; color:var(--navy); margin-bottom:24px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-family:'DM Sans',sans-serif; font-size:0.82rem; font-weight:700; color:#555; margin-bottom:6px; }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:11px 16px; border:2px solid #e0e8f5; border-radius:10px; font-family:'DM Sans',sans-serif; font-size:0.9rem; color:#333; transition:border-color 0.25s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:var(--blue); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-submit { width:100%; padding:14px; background:linear-gradient(135deg,var(--blue),var(--dark-blue)); color:#fff; border:none; border-radius:50px; font-family:'DM Sans',sans-serif; font-size:1rem; font-weight:700; cursor:pointer; transition:all 0.3s; display:flex; align-items:center; justify-content:center; gap:8px; }
.form-submit:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(26,111,212,0.4); }
.map-wrap { border-radius:var(--radius); overflow:hidden; margin-top:40px; }
.map-wrap iframe { width:100%; height:350px; border:none; display:block; }

/* ---- NEWSLETTER ---- */
.newsletter-section { background:linear-gradient(135deg,var(--navy),var(--blue)); padding:50px 0; }
.newsletter-inner { display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.newsletter-text h3 { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:900; color:#fff; margin-bottom:6px; }
.newsletter-text p { font-family:'DM Sans',sans-serif; font-size:0.9rem; color:rgba(255,255,255,0.8); }
.newsletter-form { display:flex; gap:12px; flex:1; max-width:500px; }
.newsletter-form input { flex:1; padding:12px 20px; border-radius:50px; border:none; font-family:'DM Sans',sans-serif; font-size:0.9rem; }
.newsletter-form input:focus { outline:none; }

/* ---- FOOTER ---- */
.footer { background:#0d1b2e; color:#fff; padding:60px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:40px; padding-bottom:48px; }
.footer-logo-img { height:64px; width:64px; object-fit:contain; border-radius:50%; background:#fff; padding:4px; box-shadow:0 4px 16px rgba(0,0,0,0.3); margin-bottom:12px; display:block; }
.footer-about-text { font-family:'DM Sans',sans-serif; font-size:0.85rem; color:rgba(255,255,255,0.65); line-height:1.8; margin-bottom:20px; }
.footer-social { display:flex; gap:10px; }
.footer-social a { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,0.1); color:#fff; display:flex; align-items:center; justify-content:center; font-size:0.9rem; transition:all 0.25s; }
.footer-social a:hover { background:var(--blue); transform:translateY(-3px); }
.footer-heading { font-family:'DM Sans',sans-serif; font-size:0.9rem; font-weight:800; color:#fff; letter-spacing:0.08em; text-transform:uppercase; margin-bottom:20px; padding-bottom:10px; border-bottom:2px solid rgba(255,255,255,0.1); }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-family:'DM Sans',sans-serif; font-size:0.85rem; color:rgba(255,255,255,0.65); display:flex; align-items:center; gap:8px; transition:all 0.25s; }
.footer-links a:hover { color:#fff; padding-left:4px; }
.footer-links a i { font-size:0.65rem; color:var(--blue); }
.footer-contact-list { list-style:none; display:flex; flex-direction:column; gap:14px; margin-bottom:20px; }
.footer-contact-list li { font-family:'DM Sans',sans-serif; font-size:0.85rem; color:rgba(255,255,255,0.65); display:flex; align-items:flex-start; gap:10px; }
.footer-contact-list li i { color:var(--blue); margin-top:2px; flex-shrink:0; }
.footer-contact-list a { color:rgba(255,255,255,0.65); transition:color 0.25s; }
.footer-contact-list a:hover { color:#fff; }
.footer-trust-badges { display:flex; flex-wrap:wrap; gap:8px; }
.footer-stats-bar { background:rgba(255,255,255,0.05); border-top:1px solid rgba(255,255,255,0.08); padding:28px 0; }
.footer-stats-inner { display:flex; justify-content:space-around; flex-wrap:wrap; gap:20px; }
.footer-stat { text-align:center; }
.footer-stat span { font-family:'Playfair Display',serif; font-size:2rem; font-weight:900; color:var(--yellow); display:block; }
.footer-stat p { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:rgba(255,255,255,0.6); }
.footer-bottom { background:rgba(0,0,0,0.3); padding:20px 0; }
.footer-bottom-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.footer-bottom p { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:rgba(255,255,255,0.5); }

/* ---- WHATSAPP FLOAT ---- */
.whatsapp-float { position:fixed; bottom:28px; right:28px; z-index:999; width:56px; height:56px; border-radius:50%; background:#25d366; color:#fff; display:flex; align-items:center; justify-content:center; font-size:1.6rem; box-shadow:0 4px 20px rgba(37,211,102,0.5); transition:all 0.3s; animation:pulse-wa 2s infinite; }
.whatsapp-float:hover { transform:scale(1.1); box-shadow:0 8px 28px rgba(37,211,102,0.6); }
@keyframes pulse-wa { 0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.5)} 50%{box-shadow:0 4px 32px rgba(37,211,102,0.8)} }

/* ---- FLASH MESSAGES ---- */
.flash-message { position:fixed; top:100px; right:24px; z-index:9998; background:#fff; border-radius:12px; padding:16px 20px; box-shadow:0 8px 32px rgba(0,0,0,0.15); display:flex; align-items:center; gap:12px; font-family:'DM Sans',sans-serif; font-size:0.9rem; font-weight:600; max-width:380px; animation:slideInRight 0.4s ease; }
.flash-success { border-left:4px solid #27ae60; color:#27ae60; }
.flash-error { border-left:4px solid #e74c3c; color:#e74c3c; }
.flash-close { background:none; border:none; cursor:pointer; color:#aaa; margin-left:auto; font-size:1rem; }
@keyframes slideInRight { from{transform:translateX(100%);opacity:0} to{transform:translateX(0);opacity:1} }

/* ---- PAGE HERO ---- */
.page-hero { background:linear-gradient(135deg,var(--navy),var(--blue)); color:#fff; padding:80px 0 60px; text-align:center; margin-top:calc(var(--header-h) + 36px); }
.page-hero h1 { font-family:'Playfair Display',serif; font-size:3rem; font-weight:900; margin-bottom:12px; }
.page-hero p { font-family:'DM Sans',sans-serif; font-size:1rem; color:rgba(255,255,255,0.85); max-width:560px; margin:0 auto 20px; line-height:1.7; }
.breadcrumb { display:flex; align-items:center; justify-content:center; gap:8px; font-family:'DM Sans',sans-serif; font-size:0.85rem; color:rgba(255,255,255,0.7); }
.breadcrumb a { color:rgba(255,255,255,0.7); transition:color 0.25s; }
.breadcrumb a:hover { color:#fff; }
.breadcrumb i { font-size:0.6rem; }

/* ---- HELP SLIDER SECTION ---- */
.help-slider-section { background:transparent; padding:0; display:block; overflow:visible; max-width:100%; position:relative; }
.help-slider-bg { width:100%; height:auto; display:block; position:relative; z-index:0; pointer-events:none; }
.help-slider-content { position:absolute; top:0; left:0; width:100%; height:100%; display:flex; align-items:center; z-index:1; padding:70px 0; }
.help-slider-left { width:40%; flex-shrink:0; padding:0 40px 0 calc((100vw - 1200px) / 2 + 24px); }
.help-slider-left h2 { font-size:1.7rem; font-weight:800; line-height:1.3; margin-bottom:16px; color:#222; }
.help-slider-left h2 .highlight { font-family:'Nunito',cursive; font-style:italic; color:var(--blue); }
.help-slider-left p { font-size:0.9rem; color:#fff; line-height:1.75; margin-bottom:28px; }
.help-slider-right { width:60%; overflow:hidden; position:relative; }
.hslider-track-wrapper { position:relative; }
.hslider-track { display:flex; gap:20px; transition:transform 0.45s cubic-bezier(0.4,0,0.2,1); will-change:transform; padding:10px 4px; }
.hslide-card { min-width:240px; max-width:240px; background:#fff; border-radius:var(--radius); overflow:visible; box-shadow:0 4px 20px rgba(0,0,0,0.08); flex-shrink:0; transition:transform 0.3s,box-shadow 0.3s; cursor:pointer; display:block; text-decoration:none; color:inherit; }
.hslide-card:hover { transform:translateY(-6px); box-shadow:0 12px 32px rgba(26,111,212,0.15); }
.hslide-img-wrap { position:relative; height:200px; overflow:hidden; border-radius:var(--radius) var(--radius) 0 0; }
.hslide-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.hslide-card:hover .hslide-img-wrap img { transform:scale(1.05); }
.hslide-badge { position:absolute; top:16px; right:0; background:var(--yellow); color:#222; font-weight:900; font-size:0.85rem; line-height:1.2; padding:8px 14px; text-transform:uppercase; border-radius:6px 0 0 6px; }
.hslide-body { padding:16px 18px 18px; }
.hslide-body h4 { font-size:0.82rem; font-weight:800; color:#222; letter-spacing:0.03em; margin-bottom:6px; text-transform:uppercase; }
.hslide-body p { font-size:0.82rem; color:#777; margin-bottom:12px; }
.hslide-bar { height:3px; background:var(--yellow); border-radius:4px; width:40px; }
.hslider-btn { position:absolute; top:50%; transform:translateY(-50%); z-index:10; width:38px; height:38px; border-radius:50%; border:none; background:#fff; color:var(--blue); font-size:0.9rem; cursor:pointer; box-shadow:0 4px 14px rgba(0,0,0,0.15); display:flex; align-items:center; justify-content:center; transition:all 0.25s; }
.hslider-btn:hover { background:var(--blue); color:#fff; }
.hslider-prev { left:8px; }
.hslider-next { left:54px; }
.btn-slider-donate { background:var(--blue); color:#fff; font-weight:800; font-size:0.88rem; padding:12px 22px; border-radius:50px; display:inline-flex; align-items:center; gap:8px; transition:all 0.3s; box-shadow:0 4px 14px rgba(26,111,212,0.35); }
.btn-slider-donate:hover { background:var(--dark-blue); transform:translateY(-2px); }

/* ---- ADMIN PANEL ---- */
.admin-body { font-family:'DM Sans','Poppins',sans-serif; background:#f0f4f8; min-height:100vh; }
.admin-sidebar { position:fixed; left:0; top:0; width:260px; height:100vh; background:linear-gradient(180deg,var(--navy),#0d1b2e); color:#fff; overflow-y:auto; z-index:100; transition:transform 0.3s; }
.admin-sidebar-logo { padding:24px 20px; border-bottom:1px solid rgba(255,255,255,0.1); display:flex; align-items:center; gap:12px; }
.admin-sidebar-logo img { height:48px; width:48px; object-fit:contain; border-radius:50%; background:#fff; padding:3px; box-shadow:0 2px 8px rgba(0,0,0,0.3); flex-shrink:0; }
.admin-sidebar-logo span { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:#fff; line-height:1.2; }
.admin-nav { padding:16px 0; }
.admin-nav-section { padding:8px 20px 4px; font-size:0.68rem; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; color:rgba(255,255,255,0.4); }
.admin-nav-link { display:flex; align-items:center; gap:12px; padding:11px 20px; color:rgba(255,255,255,0.75); font-size:0.88rem; font-weight:600; transition:all 0.25s; border-left:3px solid transparent; }
.admin-nav-link:hover, .admin-nav-link.active { background:rgba(255,255,255,0.1); color:#fff; border-left-color:var(--yellow); }
.admin-nav-link i { width:18px; text-align:center; font-size:0.9rem; }
.admin-main { margin-left:260px; padding:24px; min-height:100vh; }
.admin-topbar { background:#fff; border-radius:12px; padding:16px 24px; display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; box-shadow:0 2px 12px rgba(0,0,0,0.06); }
.admin-topbar h1 { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:900; color:var(--navy); }
.admin-user { display:flex; align-items:center; gap:10px; font-size:0.88rem; color:#555; }
.admin-user i { color:var(--blue); }
.admin-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:28px; }
.admin-stat-card { background:#fff; border-radius:12px; padding:24px; box-shadow:0 2px 12px rgba(0,0,0,0.06); display:flex; align-items:center; gap:16px; }
.admin-stat-icon { width:52px; height:52px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; flex-shrink:0; }
.admin-stat-icon.blue { background:#eef4fd; color:var(--blue); }
.admin-stat-icon.green { background:#e8f8f0; color:#27ae60; }
.admin-stat-icon.orange { background:#fff3e0; color:#f39c12; }
.admin-stat-icon.red { background:#fdecea; color:#e74c3c; }
.admin-stat-info h3 { font-size:1.8rem; font-weight:900; color:var(--navy); line-height:1; }
.admin-stat-info p { font-size:0.8rem; color:#888; margin-top:4px; }
.admin-card { background:#fff; border-radius:12px; padding:24px; box-shadow:0 2px 12px rgba(0,0,0,0.06); margin-bottom:24px; }
.admin-card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; padding-bottom:16px; border-bottom:2px solid #f0f4f8; }
.admin-card-header h3 { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--navy); }
.admin-table { width:100%; border-collapse:collapse; }
.admin-table th { background:#f7f9ff; padding:10px 14px; text-align:left; font-size:0.78rem; font-weight:700; color:#888; letter-spacing:0.08em; text-transform:uppercase; }
.admin-table td { padding:12px 14px; border-bottom:1px solid #f0f4f8; font-size:0.88rem; color:#444; vertical-align:middle; }
.admin-table tr:hover td { background:#f7f9ff; }
.badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:0.72rem; font-weight:700; }
.badge-success { background:#e8f8f0; color:#27ae60; }
.badge-warning { background:#fff3e0; color:#f39c12; }
.badge-danger { background:#fdecea; color:#e74c3c; }
.badge-info { background:#eef4fd; color:var(--blue); }
.admin-btn { display:inline-flex; align-items:center; gap:6px; padding:7px 16px; border-radius:8px; font-size:0.8rem; font-weight:700; cursor:pointer; border:none; transition:all 0.25s; }
.admin-btn-primary { background:var(--blue); color:#fff; }
.admin-btn-primary:hover { background:var(--dark-blue); }
.admin-btn-danger { background:#fdecea; color:#e74c3c; }
.admin-btn-danger:hover { background:#e74c3c; color:#fff; }
.admin-btn-success { background:#e8f8f0; color:#27ae60; }
.admin-btn-success:hover { background:#27ae60; color:#fff; }
.admin-form-group { margin-bottom:18px; }
.admin-form-group label { display:block; font-size:0.82rem; font-weight:700; color:#555; margin-bottom:6px; }
.admin-form-group input, .admin-form-group select, .admin-form-group textarea { width:100%; padding:10px 14px; border:2px solid #e0e8f5; border-radius:8px; font-family:'DM Sans',sans-serif; font-size:0.9rem; color:#333; transition:border-color 0.25s; }
.admin-form-group input:focus, .admin-form-group select:focus, .admin-form-group textarea:focus { outline:none; border-color:var(--blue); }
.admin-form-group textarea { resize:vertical; min-height:120px; }
.admin-form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.admin-login-page { min-height:100vh; background:linear-gradient(135deg,var(--navy),var(--blue)); display:flex; align-items:center; justify-content:center; }
.admin-login-card { background:#fff; border-radius:20px; padding:48px 40px; width:100%; max-width:420px; box-shadow:0 20px 60px rgba(0,0,0,0.3); }
.admin-login-card .logo-wrap { text-align:center; margin-bottom:28px; }
.admin-login-card .logo-wrap img { height:64px; border-radius:50%; }
.admin-login-card h2 { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:900; color:var(--navy); text-align:center; margin-bottom:6px; }
.admin-login-card p { font-size:0.88rem; color:#888; text-align:center; margin-bottom:28px; }

/* ---- ANIMATIONS ---- */
.fade-in { opacity:0; transform:translateY(30px); transition:opacity 0.6s ease,transform 0.6s ease; }
.fade-in.visible { opacity:1; transform:translateY(0); }

/* ---- RESPONSIVE ---- */
@media (max-width:1024px) {
  .campaigns-grid, .blog-grid { grid-template-columns:repeat(2,1fr); }
  .impact-grid { grid-template-columns:repeat(2,1fr); }
  .admin-stats-grid { grid-template-columns:repeat(2,1fr); }
  .admin-main { margin-left:0; }
  .admin-sidebar { transform:translateX(-100%); }
  .admin-sidebar.open { transform:translateX(0); }
}
@media (max-width:768px) {
  .header-inner { padding:10px 16px; }
  .nav { display:none; position:fixed; top:87px; left:0; right:0; background:#fff; flex-direction:column; padding:20px; box-shadow:0 8px 24px rgba(0,0,0,0.1); z-index:999; gap:8px; }
  .nav.nav-open { display:flex; }
  .hamburger { display:flex; }
  .hero-content { padding:120px 24px 60px; }
  .hero-script { font-size:3rem; }
  .about-wrapper { padding:24px 16px; }
  .about-section { flex-direction:column-reverse; }
  .about-image-col, .about-content-col { width:100%; }
  .about-content-col { padding:32px 24px; }
  .mission-section { padding:50px 20px; }
  .mission-grid { grid-template-columns:repeat(2,1fr); gap:32px 20px; }
  .programs-section { padding:40px 16px; }
  .programs-top { flex-direction:column; }
  .programs-heading { max-width:100%; }
  .testimonials-section { flex-direction:column; }
  .testi-left, .testi-right { width:100%; }
  .volunteer-section { padding:50px 20px; }
  .volunteer-inner { grid-template-columns:1fr; gap:32px; }
  .donate-grid { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .campaigns-grid, .blog-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .newsletter-inner { flex-direction:column; }
  .newsletter-form { flex-direction:column; max-width:100%; }
  .help-slider-section { overflow:hidden; }
  .help-slider-bg { position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; }
  .help-slider-content { position:relative; flex-direction:column; padding:40px 20px; background:rgba(15,30,60,0.75); gap:32px; }
  .help-slider-left { width:100%; padding:0; }
  .help-slider-left h2 { color:#fff; font-size:1.4rem; }
  .help-slider-right { width:100%; }
  .page-hero h1 { font-size:2rem; }
  .form-row { grid-template-columns:1fr; }
  .admin-form-row { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .mission-grid { grid-template-columns:1fr; }
  .impact-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:1fr; }
  .amount-grid { grid-template-columns:repeat(2,1fr); }
}

/* =============================================
   FOOTER — matching original HTML design
   ============================================= */
.footer { background:#0d1b2e; color:rgba(255,255,255,0.75); font-family:'DM Sans',sans-serif; }

/* Top bar */
.footer-topbar { background:#0a1525; border-bottom:1px solid rgba(255,255,255,0.07); padding:10px 0; }
.footer-topbar-inner { display:flex; align-items:center; justify-content:center; gap:32px; flex-wrap:wrap; font-size:0.82rem; }
.footer-topbar-inner span { display:flex; align-items:center; gap:7px; color:rgba(255,255,255,0.7); }
.footer-topbar-inner i { color:var(--blue); }

/* Main grid */
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:40px; padding:52px 0 40px; }

/* Brand col */
.footer-logo-img { height:64px; width:64px; object-fit:contain; border-radius:50%; background:#fff; padding:4px; box-shadow:0 4px 16px rgba(0,0,0,0.3); margin-bottom:12px; display:block; }
.footer-org-name { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:900; color:#fff; margin-bottom:10px; }
.footer-col-brand p { font-size:0.85rem; line-height:1.8; margin-bottom:8px; }
.footer-reg { font-size:0.78rem; color:rgba(255,255,255,0.45); margin-top:4px; }
.social-links { display:flex; gap:10px; margin-top:16px; }
.social-links a { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,0.08); color:rgba(255,255,255,0.7); display:flex; align-items:center; justify-content:center; font-size:0.88rem; transition:all 0.25s; }
.social-links a:hover { background:var(--blue); color:#fff; transform:translateY(-3px); }

/* Other cols */
.footer-col h4 { font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:800; color:#fff; letter-spacing:0.06em; text-transform:uppercase; margin-bottom:18px; padding-bottom:10px; border-bottom:2px solid rgba(255,255,255,0.08); display:flex; align-items:center; gap:8px; }
.footer-col h4 i { color:var(--blue); }
.footer-col a { display:flex; align-items:center; gap:8px; font-size:0.85rem; color:rgba(255,255,255,0.65); padding:5px 0; transition:all 0.2s; }
.footer-col a:hover { color:#fff; padding-left:4px; }
.footer-col a i { font-size:0.65rem; color:var(--blue); }

/* Contact items */
.footer-contact-item { display:flex; align-items:flex-start; gap:10px; font-size:0.85rem; color:rgba(255,255,255,0.65); margin-bottom:12px; line-height:1.6; }
.footer-contact-item i { color:var(--blue); margin-top:2px; flex-shrink:0; }
.footer-donate-btn { display:inline-flex; align-items:center; gap:8px; margin-top:16px; padding:10px 22px; background:linear-gradient(135deg,var(--blue),var(--dark-blue)); color:#fff !important; border-radius:50px; font-size:0.88rem; font-weight:700; transition:all 0.3s; box-shadow:0 4px 14px rgba(26,111,212,0.35); }
.footer-donate-btn:hover { transform:translateY(-2px); box-shadow:0 8px 20px rgba(26,111,212,0.45); padding-left:22px !important; }

/* Divider */
.footer-divider { height:1px; background:rgba(255,255,255,0.07); margin:0 24px; }

/* Bottom bar */
.footer-bottom { padding:20px 0; }
.footer-bottom-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.footer-bottom p { font-size:0.8rem; color:rgba(255,255,255,0.4); }
.footer-bottom-links { display:flex; gap:20px; }
.footer-bottom-links a { font-size:0.8rem; color:rgba(255,255,255,0.4); transition:color 0.2s; }
.footer-bottom-links a:hover { color:#fff; }

/* Volunteer submit btn */
.volunteer-submit-btn { width:100%; padding:14px; background:linear-gradient(135deg,#25d366,#128c7e); color:#fff; border:none; border-radius:50px; font-family:'DM Sans',sans-serif; font-size:1rem; font-weight:700; cursor:pointer; transition:all 0.3s; display:flex; align-items:center; justify-content:center; gap:8px; }
.volunteer-submit-btn:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(37,211,102,0.4); }

/* Responsive footer */
@media (max-width:1024px) { .footer-grid { grid-template-columns:1fr 1fr; } }
@media (max-width:600px) { .footer-grid { grid-template-columns:1fr; } .footer-topbar-inner { flex-direction:column; gap:8px; } .footer-bottom-inner { flex-direction:column; text-align:center; } }

/* =============================================
   OVERRIDES — Compact Mega Menu + Fix Testimonials
   ============================================= */

/* Compact mega menu */
.mega-menu { width:680px !important; }
.mega-col { padding:16px 16px !important; }
.mega-heading { font-size:0.67rem !important; margin-bottom:8px !important; padding-bottom:6px !important; }
.mega-col ul { gap:2px !important; }
.mega-col ul li a { padding:5px 8px !important; font-size:0.81rem !important; }
.mega-cta-card img { height:80px !important; margin-bottom:8px !important; }
.mega-cta-card h4 { font-size:0.9rem !important; margin-bottom:4px !important; }
.mega-cta-card p { font-size:0.75rem !important; margin-bottom:10px !important; }
.mega-stats-card .mega-stat { margin-bottom:10px !important; }
.mega-stats-card .mega-stat span { font-size:1.5rem !important; }

/* Fix testimonials — show exactly 2 cards, no overflow */
.testimonials-section { min-height:auto !important; }
.testi-left { width:38% !important; padding:48px 36px !important; flex-shrink:0 !important; }
.testi-left-inner h2 { font-size:1.9rem !important; }
.testi-right { width:62% !important; padding:48px 32px !important; min-width:0 !important; }
.testi-card { min-width:calc(50% - 10px) !important; max-width:calc(50% - 10px) !important; }
.testi-track { gap:16px !important; }

/* =============================================
   LOGO — Perfect Circle
   ============================================= */
.logo-img {
  height: 64px !important;
  width: 64px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  border: 3px solid var(--blue) !important;
  box-shadow: 0 0 0 4px rgba(26,111,212,0.12) !important;
  background: #fff !important;
  padding: 2px !important;
}

/* =============================================
   COMPACT DROPDOWN — Override all sizes
   ============================================= */
.mega-menu { width:600px !important; }
.mega-menu-inner { grid-template-columns: 1fr 1fr 1fr !important; }
.mega-col { padding:14px 14px !important; }
.mega-heading { font-size:0.65rem !important; margin-bottom:8px !important; padding-bottom:5px !important; letter-spacing:0.1em !important; }
.mega-col ul { gap:1px !important; }
.mega-col ul li a { padding:4px 8px !important; font-size:0.8rem !important; gap:7px !important; }
.mega-col ul li a i { font-size:0.75rem !important; }
.mega-highlight-col { display:none !important; }
.dropdown-menu { min-width:190px !important; padding:6px !important; }
.dropdown-menu a { padding:7px 12px !important; font-size:0.82rem !important; }

/* =============================================
   PAGE HERO — Creative Variants per page
   ============================================= */
.page-hero { position:relative; overflow:hidden; padding:90px 0 50px; text-align:center; margin-top:calc(var(--header-h) + 36px); }
.page-hero::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 60%,#1a9fd4 100%); z-index:0; }
.page-hero::after { content:''; position:absolute; bottom:-2px; left:0; right:0; height:60px; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23ffffff' d='M0,60 C360,0 1080,0 1440,60 L1440,60 L0,60 Z'/%3E%3C/svg%3E") no-repeat bottom center; background-size:cover; z-index:1; }
.page-hero .container { position:relative; z-index:2; }
.page-hero h1 { font-family:'Playfair Display',serif; font-size:2.8rem; font-weight:900; color:#fff; margin-bottom:10px; text-shadow:0 2px 12px rgba(0,0,0,0.2); }
.page-hero p { font-family:'DM Sans',sans-serif; font-size:0.95rem; color:rgba(255,255,255,0.88); max-width:520px; margin:0 auto 16px; line-height:1.7; }
.page-hero .page-hero-icon { font-size:3rem; color:rgba(255,255,255,0.15); position:absolute; right:10%; top:50%; transform:translateY(-50%); }
.page-hero-about::before { background:linear-gradient(135deg,#0d2b5e 0%,#1a6fd4 60%,#25a0d4 100%); }
.page-hero-campaigns::before { background:linear-gradient(135deg,#1a3a6b 0%,#e74c3c 60%,#f39c12 100%); }
.page-hero-work::before { background:linear-gradient(135deg,#1a3a6b 0%,#27ae60 60%,#2ecc71 100%); }
.page-hero-gallery::before { background:linear-gradient(135deg,#2c1654 0%,#8e44ad 60%,#1a6fd4 100%); }
.page-hero-contact::before { background:linear-gradient(135deg,#0d2b5e 0%,#1a6fd4 60%,#16a085 100%); }
.page-hero-news::before { background:linear-gradient(135deg,#1a3a6b 0%,#2980b9 60%,#1abc9c 100%); }
.page-hero-donate::before { background:linear-gradient(135deg,#7b0000 0%,#c0392b 50%,#e74c3c 100%); }
.page-hero-involved::before { background:linear-gradient(135deg,#1a3a6b 0%,#8e44ad 50%,#1a6fd4 100%); }

/* Breadcrumb */
.breadcrumb { display:flex; align-items:center; justify-content:center; gap:8px; font-family:'DM Sans',sans-serif; font-size:0.82rem; color:rgba(255,255,255,0.65); position:relative; z-index:2; }
.breadcrumb a { color:rgba(255,255,255,0.65); transition:color 0.2s; }
.breadcrumb a:hover { color:#fff; }
.breadcrumb i { font-size:0.55rem; }

/* =============================================
   SECTION HEADERS — Consistent style
   ============================================= */
.section-eyebrow { font-family:'DM Sans',sans-serif; font-size:0.72rem; font-weight:800; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue); margin-bottom:8px; display:block; }
.section-title { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:900; color:#111; margin-bottom:10px; line-height:1.2; }
.section-title span { color:var(--blue); font-style:italic; }
.section-sub { font-family:'DM Sans',sans-serif; font-size:0.92rem; color:#777; max-width:520px; margin:0 auto; line-height:1.7; }
.section-header { text-align:center; margin-bottom:48px; }
.section-header.left { text-align:left; }
.section-header.left .section-sub { margin:0; }

/* =============================================
   ABOUT PAGE
   ============================================= */
.about-page-section { padding:80px 0; }
.about-story-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-story-img { position:relative; }
.about-story-img img { width:100%; border-radius:20px; box-shadow:0 16px 48px rgba(26,111,212,0.18); }
.about-story-img::before { content:''; position:absolute; top:-12px; left:-12px; right:12px; bottom:12px; border:3px solid var(--blue); border-radius:20px; z-index:-1; opacity:0.3; }
.about-vm-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.about-vm-card { border-radius:20px; padding:36px; position:relative; overflow:hidden; }
.about-vm-card.vision { background:linear-gradient(135deg,var(--navy),var(--blue)); color:#fff; }
.about-vm-card.mission { background:#fff; border:2px solid #e8f0fe; }
.about-vm-card .vm-icon { font-size:2.5rem; margin-bottom:16px; display:block; }
.about-vm-card h3 { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:900; margin-bottom:12px; }
.about-vm-card p { font-family:'DM Sans',sans-serif; font-size:0.92rem; line-height:1.8; }
.about-vm-card.vision p { color:rgba(255,255,255,0.85); }
.about-vm-card.mission p { color:#555; }
.about-vm-card.mission h3 { color:var(--navy); }
.about-vm-card.mission .vm-icon { color:var(--blue); }
.about-stats-strip { background:linear-gradient(135deg,var(--navy),var(--blue)); padding:48px 0; }
.about-stats-inner { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.about-stat-item span { font-family:'Playfair Display',serif; font-size:2.8rem; font-weight:900; color:var(--yellow); display:block; line-height:1; }
.about-stat-item p { font-family:'DM Sans',sans-serif; font-size:0.85rem; color:rgba(255,255,255,0.8); margin-top:6px; }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.team-card { background:#fff; border-radius:16px; overflow:hidden; box-shadow:var(--shadow); text-align:center; transition:transform 0.3s,box-shadow 0.3s; }
.team-card:hover { transform:translateY(-6px); box-shadow:0 12px 32px rgba(26,111,212,0.15); }
.team-card-img { height:180px; overflow:hidden; position:relative; }
.team-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.team-card:hover .team-card-img img { transform:scale(1.06); }
.team-card-img-placeholder { width:100%; height:100%; background:linear-gradient(135deg,var(--navy),var(--blue)); display:flex; align-items:center; justify-content:center; }
.team-card-img-placeholder i { font-size:3rem; color:rgba(255,255,255,0.4); }
.team-card-body { padding:20px 16px; }
.team-card-body h4 { font-family:'DM Sans',sans-serif; font-size:0.95rem; font-weight:700; color:var(--navy); margin-bottom:4px; }
.team-card-body p { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:var(--blue); font-weight:600; }

/* =============================================
   CAMPAIGNS PAGE
   ============================================= */
.campaigns-page { padding:60px 0 80px; background:var(--light-bg); }
.campaign-filter { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; margin-bottom:40px; }
.campaign-filter a { padding:8px 20px; border-radius:30px; border:2px solid var(--blue); background:transparent; color:var(--blue); font-family:'DM Sans',sans-serif; font-weight:700; font-size:0.82rem; transition:all 0.25s; }
.campaign-filter a.active, .campaign-filter a:hover { background:var(--blue); color:#fff; }
.campaigns-grid-page { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }

/* =============================================
   OUR WORK PAGE
   ============================================= */
.work-page { padding:60px 0 80px; background:#fff; }
.work-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.work-card { background:#fff; border-radius:16px; overflow:hidden; box-shadow:var(--shadow); transition:transform 0.3s,box-shadow 0.3s; border:1px solid #f0f4f8; }
.work-card:hover { transform:translateY(-6px); box-shadow:0 12px 32px rgba(26,111,212,0.15); }
.work-card-img { height:200px; overflow:hidden; position:relative; }
.work-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.work-card:hover .work-card-img img { transform:scale(1.06); }
.work-card-icon { position:absolute; bottom:-20px; right:20px; width:44px; height:44px; background:var(--blue); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:1rem; box-shadow:0 4px 12px rgba(26,111,212,0.4); }
.work-card-body { padding:28px 20px 20px; }
.work-card-body .prog-tag { margin-bottom:10px; }
.work-card-body h4 { font-family:'DM Sans',sans-serif; font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:8px; line-height:1.4; }
.work-card-body p { font-family:'DM Sans',sans-serif; font-size:0.85rem; color:#777; line-height:1.65; margin-bottom:16px; }
.work-card-footer { display:flex; align-items:center; justify-content:space-between; padding:14px 20px; border-top:1px solid #f0f4f8; }
.work-card-beneficiaries { font-family:'DM Sans',sans-serif; font-size:0.78rem; color:var(--blue); font-weight:700; display:flex; align-items:center; gap:5px; }

/* =============================================
   GALLERY PAGE
   ============================================= */
.gallery-page { padding:60px 0 80px; background:var(--light-bg); }
.gallery-page-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:220px; gap:10px; padding:0; }

/* =============================================
   NEWS PAGE
   ============================================= */
.news-page { padding:60px 0 80px; background:var(--light-bg); }
.news-layout { display:grid; grid-template-columns:1fr 300px; gap:40px; align-items:start; }
.news-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.news-sidebar-card { background:#fff; border-radius:16px; padding:24px; box-shadow:var(--shadow); margin-bottom:24px; }
.news-sidebar-card h4 { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:16px; padding-bottom:10px; border-bottom:2px solid #f0f4f8; }

/* =============================================
   CONTACT PAGE
   ============================================= */
.contact-page { padding:60px 0 80px; background:var(--light-bg); }
.contact-layout { display:grid; grid-template-columns:1fr 1.3fr; gap:40px; align-items:start; }

/* =============================================
   DONATE PAGE
   ============================================= */
.donate-page-wrap { padding:60px 0 80px; background:var(--light-bg); }
.donate-layout { display:grid; grid-template-columns:1.3fr 1fr; gap:40px; align-items:start; }

/* =============================================
   GET INVOLVED PAGE
   ============================================= */
.involved-page { padding:60px 0 80px; background:#fff; }
.involved-ways { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:60px; }
.involved-way-card { background:var(--light-bg); border-radius:16px; padding:28px 20px; text-align:center; border:2px solid transparent; transition:all 0.3s; }
.involved-way-card:hover { border-color:var(--blue); background:#fff; transform:translateY(-4px); box-shadow:var(--shadow); }
.involved-way-icon { width:60px; height:60px; background:linear-gradient(135deg,var(--blue),var(--dark-blue)); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.involved-way-icon i { font-size:1.4rem; color:#fff; }
.involved-way-card h4 { font-family:'DM Sans',sans-serif; font-weight:700; color:var(--navy); margin-bottom:8px; }
.involved-way-card p { font-family:'DM Sans',sans-serif; font-size:0.83rem; color:#666; line-height:1.65; }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width:1024px) {
  .about-story-grid, .about-vm-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .campaigns-grid-page, .work-grid { grid-template-columns:repeat(2,1fr); }
  .news-layout { grid-template-columns:1fr; }
  .contact-layout, .donate-layout { grid-template-columns:1fr; }
  .involved-ways { grid-template-columns:repeat(2,1fr); }
  .about-stats-inner { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px) {
  .page-hero h1 { font-size:2rem; }
  .campaigns-grid-page, .work-grid, .news-grid { grid-template-columns:1fr; }
  .gallery-page-grid { grid-template-columns:repeat(2,1fr); }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .involved-ways { grid-template-columns:1fr 1fr; }
  .about-stats-inner { grid-template-columns:repeat(2,1fr); }
}

/* ---- MEGA MENU CTA CARD — Compact ---- */
.mega-highlight-col { display:flex !important; padding:12px !important; background:var(--light-bg) !important; }
.mega-cta-card { padding:4px !important; width:100%; }
.mega-cta-card img { height:70px !important; width:100% !important; object-fit:cover !important; border-radius:8px !important; margin-bottom:8px !important; }
.mega-cta-card h4 { font-size:0.82rem !important; margin-bottom:4px !important; line-height:1.3 !important; }
.mega-cta-card p { font-size:0.72rem !important; margin-bottom:10px !important; line-height:1.5 !important; color:#666 !important; }
.mega-cta-btn { padding:6px 14px !important; font-size:0.75rem !important; }
.mega-stats-card { padding:4px !important; }
.mega-stats-card .mega-stat { margin-bottom:8px !important; }
.mega-stats-card .mega-stat span { font-size:1.3rem !important; }
.mega-stats-card .mega-stat p { font-size:0.72rem !important; }
.mega-stats-card .mega-cta-btn { width:100%; text-align:center; display:block; }

/* Shrink the whole mega menu width further */
.mega-menu { width:580px !important; }
.mega-menu-inner { grid-template-columns:1fr 1fr 0.85fr !important; }

/* =============================================
   PAGE HERO — Background Image Support
   ============================================= */
.page-hero { position:relative; overflow:hidden; padding:90px 0 70px; text-align:center; margin-top:calc(var(--header-h) + 36px); }
.page-hero-bg { position:absolute; inset:0; background-size:cover !important; background-position:center !important; background-repeat:no-repeat !important; z-index:0; }
.page-hero-overlay { position:absolute; inset:0; z-index:1; }
.page-hero .container { position:relative; z-index:2; }
.page-hero::after { content:''; position:absolute; bottom:-1px; left:0; right:0; height:60px; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23ffffff' d='M0,60 C360,0 1080,0 1440,60 L1440,60 L0,60 Z'/%3E%3C/svg%3E") no-repeat bottom center; background-size:cover; z-index:3; }
.page-hero-about::after, .page-hero-campaigns::after, .page-hero-work::after,
.page-hero-gallery::after, .page-hero-contact::after, .page-hero-news::after,
.page-hero-donate::after, .page-hero-involved::after { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23f7f9ff' d='M0,60 C360,0 1080,0 1440,60 L1440,60 L0,60 Z'/%3E%3C/svg%3E"); }
.page-hero h1 { font-family:'Playfair Display',serif; font-size:2.8rem; font-weight:900; color:#fff; margin-bottom:10px; text-shadow:0 2px 16px rgba(0,0,0,0.4); position:relative; z-index:2; }
.page-hero p { font-family:'DM Sans',sans-serif; font-size:0.95rem; color:rgba(255,255,255,0.92); max-width:520px; margin:0 auto 16px; line-height:1.7; position:relative; z-index:2; text-shadow:0 1px 8px rgba(0,0,0,0.3); }
.page-hero .page-hero-icon { font-size:3rem; color:rgba(255,255,255,0.1); position:absolute; right:10%; top:50%; transform:translateY(-50%); z-index:2; }
.page-hero .breadcrumb { position:relative; z-index:2; }
@media (max-width:768px) { .page-hero { padding:70px 0 50px; } .page-hero h1 { font-size:2rem; } }

/* =============================================
   SECTION CARD BACKGROUNDS
   ============================================= */

/* Mission Section — cards with icon bg */
.mission-card {
  text-align:center;
  padding:32px 20px;
  position:relative;
  background:#fff;
  border-radius:16px;
  box-shadow:0 4px 20px rgba(26,111,212,0.08);
  transition:transform 0.3s, box-shadow 0.3s;
  overflow:hidden;
}
.mission-card::before {
  content:'';
  position:absolute;
  top:-30px; right:-30px;
  width:120px; height:120px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(26,111,212,0.08) 0%, transparent 70%);
  z-index:0;
}
.mission-card:hover {
  transform:translateY(-6px);
  box-shadow:0 12px 32px rgba(26,111,212,0.14);
}
.mission-card .mission-icon-wrap,
.mission-card h4,
.mission-card p { position:relative; z-index:1; }

/* Testimonials cards — subtle bg */
.testi-card {
  background:linear-gradient(145deg, #fff 0%, #f7f9ff 100%) !important;
  border:1px solid #e8f0fe;
}

/* Event cards — image overlay effect */
.event-card { position:relative; }

/* Program cards — bottom gradient removed */

/* hslide cards — image always fills */
.hslide-img-wrap {
  background:linear-gradient(135deg, var(--navy), var(--blue));
}
.hslide-img-wrap img {
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Campaign cards — image overlay */
.campaign-img::after {
  content:'';
  position:absolute;
  bottom:0; left:0; right:0;
  height:80px;
  background:linear-gradient(to top, rgba(0,0,0,0.5), transparent);
  z-index:1;
  pointer-events:none;
}

/* Work cards image overlay */
.work-card-img::after {
  content:'';
  position:absolute;
  bottom:0; left:0; right:0;
  height:80px;
  background:linear-gradient(to top, rgba(26,58,107,0.6), transparent);
  z-index:1;
  pointer-events:none;
}

/* Blog cards image overlay */
.blog-img::after {
  content:'';
  position:absolute;
  bottom:0; left:0; right:0;
  height:60px;
  background:linear-gradient(to top, rgba(0,0,0,0.4), transparent);
  z-index:1;
  pointer-events:none;
}

/* Team cards image overlay */
.team-card-img::after {
  content:'';
  position:absolute;
  bottom:0; left:0; right:0;
  height:60px;
  background:linear-gradient(to top, rgba(26,58,107,0.5), transparent);
  z-index:1;
  pointer-events:none;
}

/* Impact section items */
.impact-item {
  position:relative;
  overflow:hidden;
}
.impact-item::before {
  content:'';
  position:absolute;
  top:-20px; right:-20px;
  width:100px; height:100px;
  border-radius:50%;
  background:rgba(255,255,255,0.05);
  z-index:0;
}
.impact-item .impact-icon,
.impact-item .impact-num,
.impact-item p { position:relative; z-index:1; }

/* Volunteer section cards */
.volunteer-perks li {
  background:#fff;
  padding:10px 14px;
  border-radius:10px;
  box-shadow:0 2px 8px rgba(26,111,212,0.08);
}

/* About VM cards */
.about-vm-card.vision::before {
  content:'';
  position:absolute;
  top:-40px; right:-40px;
  width:160px; height:160px;
  border-radius:50%;
  background:rgba(255,255,255,0.06);
  z-index:0;
}
.about-vm-card.vision > * { position:relative; z-index:1; }

/* Involved way cards */
.involved-way-card {
  position:relative;
  overflow:hidden;
}
.involved-way-card::before {
  content:'';
  position:absolute;
  bottom:-20px; right:-20px;
  width:80px; height:80px;
  border-radius:50%;
  background:rgba(26,111,212,0.06);
  z-index:0;
}
.involved-way-card > * { position:relative; z-index:1; }

/* News sidebar donate card */
.news-sidebar-card {
  position:relative;
  overflow:hidden;
}

/* Footer stats bar items */
.footer-stat {
  position:relative;
}
.footer-stat::after {
  content:'';
  position:absolute;
  right:0; top:50%;
  transform:translateY(-50%);
  width:1px; height:40px;
  background:rgba(255,255,255,0.1);
}
.footer-stat:last-child::after { display:none; }

/* =============================================
   MISSION CARDS — Background Image Style
   ============================================= */
.mission-card {
  position:relative;
  overflow:hidden;
  border-radius:16px;
  min-height:220px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:32px 20px;
  text-align:center;
  transition:transform 0.35s, box-shadow 0.35s;
  cursor:default;
}
.mission-card-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(160deg, rgba(13,43,94,0.82) 0%, rgba(26,111,212,0.75) 100%);
  z-index:0;
  transition:background 0.35s;
}
.mission-card:hover .mission-card-overlay {
  background:linear-gradient(160deg, rgba(13,43,94,0.92) 0%, rgba(26,111,212,0.88) 100%);
}
.mission-card:hover {
  transform:translateY(-8px) scale(1.02);
  box-shadow:0 16px 40px rgba(26,111,212,0.3);
}
.mission-card .mission-icon-wrap,
.mission-card h4,
.mission-card p {
  position:relative;
  z-index:1;
}
.mission-card .mission-icon-wrap {
  width:72px;
  height:72px;
  margin:0 auto 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.15);
  border-radius:50%;
  border:2px solid rgba(255,255,255,0.3);
  backdrop-filter:blur(4px);
  transition:background 0.3s, transform 0.3s;
}
.mission-card:hover .mission-icon-wrap {
  background:rgba(245,200,0,0.25);
  border-color:var(--yellow);
  transform:scale(1.1);
}
.mission-card .mission-icon-wrap i {
  font-size:2rem;
  color:#fff;
}
.mission-card:hover .mission-icon-wrap i {
  color:var(--yellow);
}
.mission-card h4 {
  font-family:'DM Sans',sans-serif;
  font-size:1.05rem;
  font-weight:800;
  color:#fff;
  margin-bottom:10px;
}
.mission-card p {
  font-family:'DM Sans',sans-serif;
  font-size:0.83rem;
  color:rgba(255,255,255,0.85);
  line-height:1.7;
}

/* Mission section background */
.mission-section {
  padding:80px 60px;
  background:#f7f9ff;
}
.mission-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  max-width:1100px;
  margin:0 auto;
}
@media (max-width:768px) {
  .mission-section { padding:50px 20px; }
  .mission-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
}
@media (max-width:480px) {
  .mission-grid { grid-template-columns:1fr; }
}

/* =============================================
   SECTION HEADER — Heading BG Image
   ============================================= */
.section-header-bg {
  position: relative;
  padding: 48px 24px 40px;
  background: url('../asset/heading bg.png') no-repeat center center;
  background-size: cover;
  border-radius: 16px;
  margin-bottom: 40px;
  text-align: center;
}
