/* ===================================================================
   PLRDO — Global Stylesheet  |  assets/css/style.css
   Theme: Emerald Green  |  Fonts: Playfair Display + DM Sans
   =================================================================== */

/* ── 0. CSS Custom Properties ─────────────────────────────────── */
:root {
  /* Brand palette */
  --primary:     #10b981;
  --primary-d:   #059669;
  --primary-dd:  #047857;
  --primary-lt:  #d1fae5;
  --primary-bg:  #f0fdf4;
  --secondary:   #0f172a;
  --accent:      #f59e0b;
  --danger:      #ef4444;
  --info:        #0891b2;

  /* Neutrals */
  --white:       #ffffff;
  --off-white:   #f8fafc;
  --border:      #e2e8f0;
  --mid:         #64748b;
  --dark:        #1e293b;
  --text:        #334155;

  /* Shadows */
  --shadow-sm:   0 1px 4px rgba(0,0,0,.06);
  --shadow-md:   0 4px 16px rgba(0,0,0,.09);
  --shadow-lg:   0 12px 40px rgba(0,0,0,.13);
  --shadow-green:0 8px 32px rgba(16,185,129,.22);

  /* Radii */
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 24px;
  --r-full: 9999px;

  /* Transitions */
  --t-fast: 0.15s ease;
  --t-norm: 0.25s ease;
  --t-slow: 0.4s ease;
}

/* ── Dark-mode overrides ──────────────────────────────────────── */
body.dark-mode {
  --white:    #1e293b;
  --off-white:#0f172a;
  --border:   #334155;
  --mid:      #94a3b8;
  --dark:     #f1f5f9;
  --text:     #cbd5e1;
  background: #0f172a;
  color: #cbd5e1;
}
body.dark-mode .card,
body.dark-mode .blog-card,
body.dark-mode .prog-card { background:#1e293b; border-color:#334155; color:#cbd5e1; }
body.dark-mode #plrdNav  { background:#1e293b; box-shadow:0 2px 16px rgba(0,0,0,.4); }
body.dark-mode .plrd-desk-links a { color:#94a3b8; }
body.dark-mode .footer  { background:#020617; }

/* ── 1. Reset & Base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: 'DM Sans', 'Poppins', sans-serif;
  color: var(--text);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; }
a   { color: var(--primary); text-decoration: none; transition: color var(--t-norm); }
a:hover { color: var(--primary-d); }

/* Skip-to-content for accessibility */
.skip-link {
  position: absolute; top: -100%; left: 16px;
  background: var(--primary); color: #fff;
  padding: 8px 16px; border-radius: 0 0 var(--r-sm) var(--r-sm);
  z-index: 10000; font-weight: 600; font-size: 14px;
  transition: top var(--t-fast);
}
.skip-link:focus { top: 0; }

/* ── 2. Typography ────────────────────────────────────────────── */
h1, h2, h3 { font-family: 'Playfair Display', Georgia, serif; font-weight: 700; line-height: 1.2; }
h4, h5, h6 { font-family: 'DM Sans', sans-serif; font-weight: 600; }
.section-title {
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  color: var(--dark);
  margin-bottom: 6px;
}
.section-sub {
  font-size: 0.95rem;
  color: var(--mid);
  margin-bottom: 32px;
  max-width: 540px;
}
.tag, .badge-tag {
  display: inline-block;
  background: rgba(16,185,129,.12);
  color: var(--primary);
  border: 1px solid rgba(16,185,129,.25);
  border-radius: var(--r-full);
  padding: 4px 14px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.badge-tag-white {
  background: rgba(255,255,255,.15);
  color: #fff;
  border-color: rgba(255,255,255,.3);
}

/* ── 3. Navigation ────────────────────────────────────────────── */
#plrdNav {
  background: var(--white);
  box-shadow: 0 2px 16px rgba(0,0,0,.07);
  position: sticky;
  top: 0;
  z-index: 1000;
  font-family: 'DM Sans','Poppins',sans-serif;
}
.plrd-nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  height: 64px;
  max-width: 1400px;
  margin: 0 auto;
}
.plrd-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}
.plrd-logo img { max-height: 50px; width: auto; object-fit: contain; border-radius: var(--r-sm); }
.plrd-brand-text .plrd-n { font-size: 14px; font-weight: 700; color: var(--dark); line-height: 1.1; }
.plrd-brand-text .plrd-t { font-size: 10px; color: var(--mid); }
.plrd-desk-links { display: flex; align-items: center; gap: 2px; }
.plrd-desk-links a {
  color: var(--text);
  font-size: 13px;
  font-weight: 500;
  padding: 7px 12px;
  border-radius: var(--r-sm);
  transition: color var(--t-fast), background var(--t-fast);
  white-space: nowrap;
}
.plrd-desk-links a:hover,
.plrd-desk-links a.plrd-active { color: var(--primary); background: var(--primary-bg); }
.plrd-donate-pill {
  background: linear-gradient(135deg, var(--primary), var(--primary-d)) !important;
  color: #fff !important;
  padding: 7px 18px !important;
  border-radius: var(--r-full) !important;
  font-weight: 600 !important;
  margin-left: 6px !important;
}
.plrd-donate-pill:hover { opacity: .9 !important; }

/* Nav utility icons (search, dark-mode) */
.nav-icon-btn {
  background: none;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: var(--mid);
  font-size: 15px;
  transition: border-color var(--t-fast), color var(--t-fast);
  margin-left: 4px;
}
.nav-icon-btn:hover { border-color: var(--primary); color: var(--primary); }

/* Hamburger */
.plrd-ham {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px; height: 40px;
  background: none;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  cursor: pointer;
  padding: 8px;
  flex-shrink: 0;
  transition: border-color var(--t-fast);
}
.plrd-ham:hover { border-color: var(--primary); }
.plrd-ham span { display: block; height: 2px; background: var(--text); border-radius: 2px; transition: all .3s; }
.plrd-ham.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.plrd-ham.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.plrd-ham.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.plrd-mob-menu {
  display: none;
  background: var(--white);
  border-top: 2px solid #f1f5f9;
  padding: 6px 0 14px;
}
.plrd-mob-menu.is-open { display: block; }
.plrd-mob-menu a {
  display: flex;
  align-items: center;
  padding: 11px 28px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  border-left: 3px solid transparent;
  transition: all var(--t-fast);
}
.plrd-mob-menu a:hover,
.plrd-mob-menu a.plrd-active { color: var(--primary); border-left-color: var(--primary); background: var(--primary-bg); }
.plrd-mob-donate-link { color: var(--primary) !important; font-weight: 700 !important; background: var(--primary-bg) !important; margin-top: 6px; }

@media (max-width: 991px) {
  .plrd-desk-links { display: none !important; }
  .plrd-ham { display: flex !important; }
}

/* ── 4. Global Search Modal ───────────────────────────────────── */
.search-modal-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.6);
  z-index: 9000;
  align-items: flex-start;
  justify-content: center;
  padding-top: 80px;
  backdrop-filter: blur(4px);
}
.search-modal-overlay.open { display: flex; }
.search-modal {
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 24px;
  width: 90%;
  max-width: 640px;
  box-shadow: var(--shadow-lg);
  animation: slideDown .25s ease;
}
@keyframes slideDown { from { transform: translateY(-20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.search-modal input {
  width: 100%; padding: 14px 16px;
  border: 2px solid var(--border);
  border-radius: var(--r-md);
  font-size: 16px;
  font-family: 'DM Sans', sans-serif;
  outline: none;
  transition: border-color var(--t-fast);
}
.search-modal input:focus { border-color: var(--primary); }
.search-results-list { margin-top: 16px; max-height: 360px; overflow-y: auto; }
.search-result-item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px; border-radius: var(--r-sm);
  cursor: pointer; transition: background var(--t-fast);
  text-decoration: none; color: var(--text);
}
.search-result-item:hover { background: var(--primary-bg); }
.search-result-item .sri-icon {
  width: 36px; height: 36px;
  border-radius: var(--r-sm);
  background: var(--primary-bg);
  color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.search-result-item .sri-title { font-weight: 600; font-size: 14px; }
.search-result-item .sri-snippet { font-size: 12px; color: var(--mid); }
.search-result-item .sri-type {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--primary);
}

/* ── 5. Page Hero (inner pages) ───────────────────────────────── */
.page-hero {
  background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 45%, #064e3b 100%);
  padding: 80px 0 55px;
  text-align: center;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at bottom left, rgba(16,185,129,.2) 0%, transparent 60%);
}
.page-hero .container { position: relative; }
.page-hero h1 { font-size: clamp(1.8rem, 5vw, 2.8rem); margin-bottom: 12px; }
.page-hero p  { font-size: 1rem; color: rgba(255,255,255,.75); max-width: 540px; margin: 0 auto; }

/* Breadcrumb */
.breadcrumb-wrap {
  background: var(--off-white);
  border-bottom: 1px solid var(--border);
  padding: 10px 0;
}
.breadcrumb-wrap ol { margin: 0; padding: 0; list-style: none; display: flex; flex-wrap: wrap; gap: 6px; font-size: 13px; }
.breadcrumb-wrap li { display: flex; align-items: center; gap: 6px; }
.breadcrumb-wrap li + li::before { content: '/'; color: var(--mid); }
.breadcrumb-wrap a { color: var(--primary); }
.breadcrumb-wrap .current { color: var(--mid); }

/* ── 6. Hero Slider (index) ───────────────────────────────────── */
.hero-slider {
  position: relative;
  width: 100%;
  height: clamp(480px, 70vh, 780px);
  overflow: hidden;
  background: #0f172a;
}
.hero-slide {
  position: absolute; inset: 0;
  opacity: 0;
  transition: opacity .7s ease;
  background-size: cover;
  background-position: center;
}
.hero-slide.active { opacity: 1; }
.hero-slide-video { position: absolute; inset: 0; }
.hero-slide-video iframe,
.hero-slide-video video { width: 100%; height: 100%; object-fit: cover; border: none; pointer-events: none; }
.hero-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 1;
}
.hero-content {
  position: absolute;
  bottom: 80px; left: 0; right: 0;
  padding: 0 24px;
  text-align: center;
  color: #fff;
  z-index: 3;
  pointer-events: none;
}
.hero-content > * { pointer-events: auto; }
.hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(16,185,129,.25);
  border: 1px solid rgba(16,185,129,.5);
  color: #a7f3d0; border-radius: var(--r-full);
  padding: 5px 16px; font-size: 11px; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  margin-bottom: 16px; backdrop-filter: blur(6px);
}
.hero-content h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 5.5vw, 3.4rem);
  font-weight: 700; margin-bottom: 16px;
  text-shadow: 0 2px 20px rgba(0,0,0,.6);
  line-height: 1.2;
}
.hero-content p {
  font-size: clamp(.95rem, 2vw, 1.1rem);
  color: rgba(255,255,255,.88);
  margin-bottom: 28px; max-width: 640px;
  margin-left: auto; margin-right: auto;
  line-height: 1.7;
  text-shadow: 0 1px 8px rgba(0,0,0,.4);
}
.hero-btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* Animated slide-in for hero content */
.hero-slide.active .hero-content { animation: heroIn .6s ease both; }
@keyframes heroIn {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}
.btn-hero-primary {
  background: linear-gradient(135deg, var(--primary), var(--primary-d));
  color: #fff; padding: 12px 28px; border-radius: var(--r-full);
  font-weight: 600; font-size: 14px; display: inline-flex; align-items: center; gap: 8px;
  transition: transform var(--t-fast), box-shadow var(--t-fast);
}
.btn-hero-primary:hover { transform: translateY(-2px); box-shadow: var(--shadow-green); color: #fff; }
.btn-hero-secondary {
  background: rgba(255,255,255,.15);
  backdrop-filter: blur(8px);
  color: #fff; border: 1.5px solid rgba(255,255,255,.4);
  padding: 12px 28px; border-radius: var(--r-full);
  font-weight: 500; font-size: 14px; display: inline-flex; align-items: center; gap: 8px;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.btn-hero-secondary:hover { background: rgba(255,255,255,.25); color: #fff; }

/* Slider controls */
.hero-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 46px; height: 46px;
  background: rgba(255,255,255,.12);
  border: 1.5px solid rgba(255,255,255,.35);
  border-radius: var(--r-full);
  color: #fff; font-size: 16px;
  cursor: pointer; z-index: 4;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--t-fast), border-color var(--t-fast);
  backdrop-filter: blur(8px);
}
.hero-arrow:hover   { background: var(--primary); border-color: var(--primary); }
.hero-arrow-left    { left: 20px; }
.hero-arrow-right   { right: 20px; }
.hero-dots          { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 4; }
.hero-dot           { width: 8px; height: 8px; border-radius: var(--r-full); background: rgba(255,255,255,.4); cursor: pointer; border: none; padding: 0; transition: all var(--t-fast); }
.hero-dot.active    { background: var(--primary); width: 28px; }
.hero-progress-ring { position: absolute; bottom: 20px; right: 24px; z-index: 4; }

/* Slider pause indicator */
.hero-slider.paused .hero-arrow-right::after {
  content: '⏸';
  font-size: 10px;
  position: absolute;
  bottom: -18px;
  color: rgba(255,255,255,.6);
}

/* ── 7. Stats Section ─────────────────────────────────────────── */
.stats-section { padding: 60px 0; background: var(--white); }
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 24px;
}
.stat-card {
  text-align: center; padding: 32px 20px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-norm), box-shadow var(--t-norm);
  position: relative;
}
.stat-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-green); }
.stat-icon { font-size: 28px; color: var(--primary); margin-bottom: 12px; }
.stat-num  { font-size: clamp(2rem, 5vw, 2.8rem); font-weight: 800; color: var(--primary); font-family: 'DM Sans', sans-serif; line-height: 1; }
.stat-label { font-size: 13px; color: var(--mid); margin-top: 6px; font-weight: 500; }
.stat-tooltip {
  position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%);
  background: var(--dark); color: #fff;
  padding: 8px 12px; border-radius: var(--r-sm); font-size: 12px;
  white-space: nowrap; pointer-events: none;
  opacity: 0; transition: opacity var(--t-fast);
  z-index: 100;
}
.stat-tooltip::after {
  content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  border: 6px solid transparent; border-top-color: var(--dark);
}
.stat-card:hover .stat-tooltip { opacity: 1; }

/* ── 8. Category Filter Chips ─────────────────────────────────── */
.filter-chips   { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.filter-btn {
  background: var(--white);
  border: 1.5px solid var(--border);
  color: var(--text);
  padding: 6px 16px;
  border-radius: var(--r-full);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--t-fast);
}
.filter-btn:hover,
.filter-btn.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

/* ── 9. Cards ─────────────────────────────────────────────────── */
.blog-card, .card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform var(--t-norm), box-shadow var(--t-norm), border-color var(--t-norm);
}
.blog-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--primary-lt); }
.blog-card .blog-img { height: 200px; overflow: hidden; }
.blog-card .blog-img img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow); }
.blog-card:hover .blog-img img { transform: scale(1.06); }
.blog-card .blog-body { padding: 20px; }
.blog-card .blog-title { font-size: 16px; font-weight: 700; color: var(--dark); margin-bottom: 8px; font-family: 'Playfair Display', serif; }
.blog-card .blog-meta  { display: flex; gap: 12px; font-size: 12px; color: var(--mid); margin-bottom: 10px; }
.blog-card .blog-excerpt { font-size: 14px; color: var(--mid); line-height: 1.6; margin-bottom: 16px; }
.read-more {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--primary); font-size: 14px; font-weight: 600;
  transition: gap var(--t-fast);
}
.read-more:hover { gap: 10px; color: var(--primary-d); }

/* Social share on card hover */
.card-share-wrap { position: relative; }
.card-share-btns {
  display: flex; gap: 6px;
  position: absolute; top: 12px; right: 12px;
  opacity: 0; transform: translateY(-4px);
  transition: opacity var(--t-norm), transform var(--t-norm);
  z-index: 5;
}
.card-share-wrap:hover .card-share-btns { opacity: 1; transform: translateY(0); }
.share-btn {
  width: 30px; height: 30px;
  border-radius: var(--r-full);
  border: none;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
  color: #fff;
  cursor: pointer;
  transition: transform var(--t-fast);
}
.share-btn:hover { transform: scale(1.15); }
.share-fb { background: #1877f2; }
.share-tw { background: #000; }
.share-wa { background: #25d366; }
.share-li { background: #0a66c2; }

/* ── 10. Load More Button ─────────────────────────────────────── */
.load-more-wrap { text-align: center; margin-top: 32px; }
.btn-load-more {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--white);
  border: 2px solid var(--primary);
  color: var(--primary);
  padding: 11px 28px;
  border-radius: var(--r-full);
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: all var(--t-fast);
}
.btn-load-more:hover { background: var(--primary); color: #fff; }
.btn-load-more.loading { opacity: .6; pointer-events: none; }

/* ── 11. Programs / Sector Cards ──────────────────────────────── */
.prog-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px;
  text-align: center;
  cursor: pointer;
  text-decoration: none;
  display: block;
  transition: all var(--t-norm);
  color: var(--text);
}
.prog-card:hover { border-color: var(--primary); box-shadow: var(--shadow-green); transform: translateY(-4px); color: var(--dark); }
.prog-icon {
  width: 60px; height: 60px;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--primary), var(--primary-d));
  color: #fff;
  font-size: 26px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px;
}
.prog-card h5 { font-size: 15px; font-weight: 700; margin-bottom: 8px; color: var(--dark); }
.prog-card p  { font-size: 13px; color: var(--mid); line-height: 1.6; }

/* ── 12. Newsletter Section ───────────────────────────────────── */
.newsletter-section {
  background: linear-gradient(135deg, #0f172a 0%, #064e3b 100%);
  padding: 64px 0;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.newsletter-section::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top right, rgba(16,185,129,.2) 0%, transparent 55%);
}
.newsletter-section .container { position: relative; }
.newsletter-title { font-size: clamp(1.3rem, 3vw, 1.8rem); margin-bottom: 8px; }
.newsletter-sub   { color: rgba(255,255,255,.7); margin-bottom: 28px; font-size: 15px; }
.newsletter-form  { display: flex; gap: 10px; flex-wrap: wrap; }
.newsletter-form input[type="email"] {
  flex: 1; min-width: 240px;
  padding: 13px 18px;
  border: 1.5px solid rgba(255,255,255,.25);
  border-radius: var(--r-full);
  background: rgba(255,255,255,.1);
  color: #fff;
  font-size: 14px;
  outline: none;
  transition: border-color var(--t-fast);
}
.newsletter-form input::placeholder { color: rgba(255,255,255,.5); }
.newsletter-form input:focus { border-color: var(--primary); }
.newsletter-form button {
  background: linear-gradient(135deg, var(--primary), var(--primary-d));
  color: #fff;
  border: none;
  padding: 13px 28px;
  border-radius: var(--r-full);
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: opacity var(--t-fast), transform var(--t-fast);
}
.newsletter-form button:hover { opacity: .9; transform: translateY(-1px); }
.newsletter-cats { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }
.newsletter-cats label {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; color: rgba(255,255,255,.8);
  cursor: pointer;
}
.newsletter-cats input[type="checkbox"] { accent-color: var(--primary); }
.newsletter-alert {
  padding: 10px 16px;
  border-radius: var(--r-sm);
  margin-top: 14px;
  font-size: 14px;
  display: none;
}
.newsletter-alert.success { background: rgba(16,185,129,.15); color: #a7f3d0; border: 1px solid rgba(16,185,129,.3); }
.newsletter-alert.error   { background: rgba(239,68,68,.15); color: #fca5a5; border: 1px solid rgba(239,68,68,.3); }

/* ── 13. Testimonials Carousel ────────────────────────────────── */
.testimonials-section { padding: 64px 0; background: var(--off-white); }
.testimonial-carousel { position: relative; overflow: hidden; }
.testimonial-track { display: flex; transition: transform .5s cubic-bezier(.25,.46,.45,.94); will-change: transform; }
.testimonial {
  min-width: min(300px, calc(100vw - 48px));
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 28px;
  border: 1px solid var(--border);
  flex-shrink: 0;
  margin-right: 20px;
}
.testimonial .stars { color: var(--accent); font-size: 16px; margin-bottom: 14px; }
.testimonial p      { font-size: 14px; line-height: 1.7; color: var(--text); font-style: italic; margin-bottom: 16px; }
.testimonial-author { display: flex; align-items: center; gap: 12px; }
.t-avatar           { width: 44px; height: 44px; border-radius: var(--r-full); background: var(--primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 18px; flex-shrink: 0; }
.t-name             { font-weight: 700; font-size: 14px; color: var(--dark); }
.t-role             { font-size: 12px; color: var(--mid); }

/* Desktop: 3-column static grid — disable carousel transform */
@media (min-width: 992px) {
  .testimonial-carousel                    { overflow: visible; }
  .testimonial-carousel .testimonial-track { flex-wrap: wrap; gap: 20px; transform: none !important; transition: none; }
  .testimonial                              { min-width: 0; flex: 0 0 calc(33.33% - 14px); margin-right: 0; }
  .testimonial-carousel-controls           { display: none; }
}
.testimonial-carousel-controls { display: flex; justify-content: center; gap: 10px; margin-top: 20px; }
.tc-btn { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--r-full); width: 36px; height: 36px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all var(--t-fast); }
.tc-btn:hover { border-color: var(--primary); color: var(--primary); }

/* ── 14. Partners Section ─────────────────────────────────────── */
.partners-section { padding: 56px 0; }
.partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 16px;
  justify-items: center;
  align-items: stretch;
}
.partner-item {
  width: 100%;
  height: 100px;
  padding: 16px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 8px;
  transition: all var(--t-norm);
  cursor: pointer;
  text-align: center;
  overflow: hidden;
}
.partner-item:hover {
  border-color: var(--primary-lt);
  box-shadow: var(--shadow-green);
  transform: translateY(-3px);
}
.partner-item img {
  max-height: 50px;
  max-width: 120px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(1) opacity(.7);
  transition: filter var(--t-norm);
}
.partner-item:hover img { filter: grayscale(0) opacity(1); }
.partner-item .partner-name {
  font-size: 11px;
  font-weight: 700;
  color: var(--mid);
  text-transform: uppercase;
  letter-spacing: .05em;
  line-height: 1.3;
}
.partner-item:hover .partner-name { color: var(--primary); }

/* Donor logo placeholder when no image */
.partner-logo-placeholder {
  width: 48px; height: 48px;
  border-radius: var(--r-sm);
  background: linear-gradient(135deg, var(--primary), var(--primary-d));
  color: #fff; font-weight: 800; font-size: 18px;
  display: flex; align-items: center; justify-content: center;
}

/* Partner modal */
.partner-modal .modal-header { border-bottom: 2px solid var(--primary-bg); }

/* ── 15. Footer ───────────────────────────────────────────────── */
.footer {
  background: #0f172a;
  color: #94a3b8;
  padding: 64px 0 0;
}
.footer h6     { color: #e2e8f0; font-weight: 700; margin-bottom: 16px; font-size: 13px; text-transform: uppercase; letter-spacing: .07em; }
.footer ul     { list-style: none; padding: 0; margin: 0; }
.footer ul li  { margin-bottom: 8px; }
.footer ul a   { color: #64748b; font-size: 14px; transition: color var(--t-fast); }
.footer ul a:hover { color: var(--primary); }
.footer-support { color: var(--primary) !important; font-weight: 600; }
.footer-support:hover { color: var(--primary-d) !important; }
.footer-bottom {
  border-top: 1px solid #1e293b;
  padding: 18px 0;
  margin-top: 40px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 13px;
  color: #475569;
}
.social-links   { display: flex; gap: 8px; }
.social-links a {
  width: 34px; height: 34px;
  border-radius: var(--r-full);
  border: 1.5px solid #1e293b;
  color: #64748b;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  transition: all var(--t-fast);
}
.social-links a:hover { background: var(--primary); border-color: var(--primary); color: #fff; }
.footer-contact-info { display: flex; flex-direction: column; gap: 6px; font-size: 14px; }
.footer-contact-info a { color: #64748b; }
.footer-contact-info a:hover { color: var(--primary); }

/* Footer mini-form */
.footer-mini-form input {
  width: 100%; padding: 9px 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid #1e293b;
  border-radius: var(--r-sm);
  color: #e2e8f0; font-size: 13px;
  margin-bottom: 8px;
  outline: none;
  transition: border-color var(--t-fast);
}
.footer-mini-form input:focus { border-color: var(--primary); }
.footer-mini-form textarea {
  width: 100%; padding: 9px 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid #1e293b;
  border-radius: var(--r-sm);
  color: #e2e8f0; font-size: 13px;
  resize: vertical; min-height: 80px;
  margin-bottom: 8px;
  outline: none;
  transition: border-color var(--t-fast);
}
.footer-mini-form textarea:focus { border-color: var(--primary); }
.footer-mini-form button {
  background: linear-gradient(135deg, var(--primary), var(--primary-d));
  color: #fff; border: none; padding: 9px 20px;
  border-radius: var(--r-sm); font-weight: 600; font-size: 13px;
  cursor: pointer; width: 100%;
  transition: opacity var(--t-fast);
}
.footer-mini-form button:hover { opacity: .9; }

/* ── 16. Back to Top + Progress Ring ─────────────────────────── */
#back-to-top {
  position: fixed; bottom: 30px; right: 30px;
  width: 48px; height: 48px;
  border-radius: var(--r-full);
  background: var(--primary);
  color: #fff; border: none;
  box-shadow: var(--shadow-md);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  opacity: 0; visibility: hidden;
  transition: all var(--t-norm);
  z-index: 999;
}
#back-to-top.show { opacity: 1; visibility: visible; }
#back-to-top:hover { background: var(--primary-d); transform: translateY(-3px); }

.scroll-progress-ring {
  position: fixed; bottom: 24px; right: 24px;
  width: 56px; height: 56px; z-index: 998;
  pointer-events: none;
}
.scroll-progress-ring svg { transform: rotate(-90deg); }
.scroll-progress-ring circle {
  fill: none;
  stroke: var(--primary);
  stroke-width: 3;
  stroke-dasharray: 145;
  stroke-dashoffset: 145;
  transition: stroke-dashoffset .1s linear;
}

/* ── 17. Cookie Consent Banner ────────────────────────────────── */
#cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: #1e293b;
  color: #e2e8f0;
  padding: 16px 24px;
  z-index: 9999;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
  box-shadow: 0 -4px 16px rgba(0,0,0,.25);
  font-size: 14px;
  transform: translateY(100%);
  transition: transform .4s ease;
}
#cookie-banner.show { transform: translateY(0); }
#cookie-banner a    { color: var(--primary); }
.cookie-btns        { display: flex; gap: 8px; }
.cookie-btn-reject  { background: #475569; color: #fff; border: none; padding: 8px 16px; border-radius: var(--r-sm); cursor: pointer; font-size: 13px; }
.cookie-btn-accept  { background: var(--primary); color: #fff; border: none; padding: 8px 16px; border-radius: var(--r-sm); cursor: pointer; font-size: 13px; font-weight: 600; }

/* ── 18. Dark Mode Toggle ─────────────────────────────────────── */
.dark-mode-toggle {
  background: none; border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  width: 36px; height: 36px;
  cursor: pointer; color: var(--mid); font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--t-fast);
}
.dark-mode-toggle:hover { border-color: var(--primary); color: var(--primary); }

/* ── 19. Leaflet Map Override ─────────────────────────────────── */
#darfurMap { height: 480px; border-radius: var(--r-lg); z-index: 1; }
.leaflet-popup-content { font-family: 'DM Sans', sans-serif; font-size: 14px; }
.leaflet-popup-content b { color: var(--dark); }
.leaflet-popup-content a { color: var(--primary); font-weight: 600; }

/* ── 20. Donate Page ──────────────────────────────────────────── */
.donate-section    { padding: 64px 0; }
.donate-amount-grid { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 20px; }
.amount-chip {
  padding: 10px 20px;
  border: 2px solid var(--border);
  border-radius: var(--r-full);
  background: var(--white);
  font-weight: 700; font-size: 15px;
  cursor: pointer;
  transition: all var(--t-fast);
}
.amount-chip.active { background: var(--primary); border-color: var(--primary); color: #fff; }
.amount-chip:hover  { border-color: var(--primary); color: var(--primary); }
.impact-counter-box {
  background: var(--primary-bg);
  border: 1.5px solid rgba(16,185,129,.3);
  border-radius: var(--r-lg);
  padding: 18px 20px;
  margin-top: 16px;
  font-size: 15px;
  font-weight: 600;
  color: var(--primary-dd);
}
.impact-counter-box i { font-size: 20px; margin-right: 8px; }
.project-donate-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; margin-bottom: 40px; }
.project-donate-card {
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  cursor: pointer;
  transition: all var(--t-norm);
  background: var(--white);
}
.project-donate-card:hover,
.project-donate-card.selected { border-color: var(--primary); background: var(--primary-bg); }
.project-donate-card .pdc-icon { font-size: 28px; margin-bottom: 10px; }
.project-donate-card h5  { font-size: 15px; font-weight: 700; margin-bottom: 6px; color: var(--dark); }
.project-donate-card p   { font-size: 13px; color: var(--mid); }
.donation-form-wrap { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--shadow-sm); }
.donation-form-wrap label { font-size: 14px; font-weight: 600; color: var(--dark); margin-bottom: 6px; display: block; }
.donation-form-wrap input,
.donation-form-wrap select,
.donation-form-wrap textarea {
  width: 100%; padding: 12px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  outline: none;
  transition: border-color var(--t-fast);
  background: var(--white);
  color: var(--text);
  margin-bottom: 16px;
}
.donation-form-wrap input:focus,
.donation-form-wrap select:focus { border-color: var(--primary); }
.btn-donate-submit {
  width: 100%;
  background: linear-gradient(135deg, var(--primary), var(--primary-d));
  color: #fff; border: none; padding: 14px;
  border-radius: var(--r-full); font-weight: 700; font-size: 16px;
  cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 10px;
  transition: opacity var(--t-fast), transform var(--t-fast);
}
.btn-donate-submit:hover { opacity: .9; transform: translateY(-2px); }

/* ── 21. Contact Page ─────────────────────────────────────────── */
.contact-section   { padding: 64px 0; }
.contact-form-wrap {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
}
.contact-form-wrap label { font-size: 14px; font-weight: 600; color: var(--dark); margin-bottom: 6px; display: block; }
.contact-form-wrap input,
.contact-form-wrap textarea,
.contact-form-wrap select {
  width: 100%; padding: 12px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  outline: none;
  transition: border-color var(--t-fast);
  resize: vertical;
  background: var(--white);
  color: var(--text);
  margin-bottom: 16px;
}
.contact-form-wrap input:focus,
.contact-form-wrap textarea:focus { border-color: var(--primary); }
.btn-contact-submit {
  background: linear-gradient(135deg, var(--primary), var(--primary-d));
  color: #fff; border: none; padding: 13px 32px;
  border-radius: var(--r-full); font-weight: 700; font-size: 15px;
  cursor: pointer; display: inline-flex; align-items: center; gap: 8px;
  transition: opacity var(--t-fast), transform var(--t-fast);
}
.btn-contact-submit:hover { opacity: .9; transform: translateY(-2px); }
.contact-info-box {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px;
}
.contact-info-item { display: flex; gap: 14px; margin-bottom: 20px; }
.contact-info-item:last-child { margin-bottom: 0; }
.ci-icon {
  width: 42px; height: 42px; flex-shrink: 0;
  background: var(--primary-bg);
  color: var(--primary);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
}
.ci-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--mid); margin-bottom: 2px; }
.ci-val   { font-size: 14px; color: var(--dark); font-weight: 500; }
.contact-map-embed iframe { width: 100%; height: 320px; border: none; border-radius: var(--r-lg); }

/* ── 22. About Page ───────────────────────────────────────────── */
.about-section   { padding: 64px 0; }
.about-timeline  { position: relative; padding-left: 28px; }
.about-timeline::before { content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px; background: var(--border); }
.timeline-item   { position: relative; margin-bottom: 32px; }
.timeline-dot    { position: absolute; left: -24px; top: 4px; width: 12px; height: 12px; border-radius: var(--r-full); background: var(--primary); border: 2px solid #fff; box-shadow: 0 0 0 2px var(--primary-lt); }
.timeline-year   { font-size: 12px; font-weight: 700; color: var(--primary); text-transform: uppercase; letter-spacing: .07em; }
.team-grid       { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 24px; }
.team-card       {
  text-align: center;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px 16px;
  transition: all var(--t-norm);
}
.team-card:hover { border-color: var(--primary); transform: translateY(-4px); box-shadow: var(--shadow-green); }
.team-avatar     { width: 80px; height: 80px; border-radius: var(--r-full); object-fit: cover; margin: 0 auto 12px; display: block; border: 3px solid var(--primary-bg); }
.team-name       { font-size: 15px; font-weight: 700; color: var(--dark); }
.team-role       { font-size: 13px; color: var(--mid); margin-top: 4px; }
.annual-reports-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }
.report-card {
  display: flex; align-items: center; gap: 16px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  transition: all var(--t-norm);
}
.report-card:hover { border-color: var(--primary); box-shadow: var(--shadow-md); }
.report-icon  { width: 50px; height: 50px; background: var(--primary-bg); border-radius: var(--r-sm); display: flex; align-items: center; justify-content: center; color: var(--primary); font-size: 24px; flex-shrink: 0; }
.report-title { font-weight: 700; font-size: 15px; color: var(--dark); margin-bottom: 4px; }
.report-meta  { font-size: 12px; color: var(--mid); margin-bottom: 8px; }
.btn-download { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--primary); }

/* ── 23. Research Detail ──────────────────────────────────────── */
.post-detail       { padding: 60px 0; }
.post-header       { margin-bottom: 36px; }
.post-image        { width: 100%; max-height: 440px; object-fit: cover; border-radius: var(--r-lg); margin-bottom: 32px; }
.post-meta         { display: flex; flex-wrap: wrap; gap: 16px; color: var(--mid); font-size: 14px; margin-bottom: 20px; }
.post-content      { font-size: 15px; line-height: 1.85; color: var(--text); }
.post-content h2   { font-size: 1.4rem; color: var(--dark); margin: 28px 0 12px; }
.post-content h3   { font-size: 1.2rem; color: var(--dark); margin: 20px 0 10px; }
.post-content p    { margin-bottom: 16px; }
.post-content img  { width: 100%; border-radius: var(--r-md); margin: 16px 0; }
.post-content ul, .post-content ol { padding-left: 24px; margin-bottom: 16px; }
.post-content blockquote {
  border-left: 4px solid var(--primary);
  padding: 14px 20px;
  margin: 20px 0;
  background: var(--primary-bg);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  font-style: italic;
  color: var(--primary-dd);
}
.post-share-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 20px 0; border-top: 1px solid var(--border); margin-top: 32px; }
.share-pill {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px;
  border-radius: var(--r-full);
  border: none;
  font-size: 13px; font-weight: 600;
  cursor: pointer; color: #fff;
  transition: transform var(--t-fast);
}
.share-pill:hover { transform: translateY(-2px); }
.share-pill.fb { background: #1877f2; }
.share-pill.tw { background: #000; }
.share-pill.wa { background: #25d366; }
.share-pill.li { background: #0a66c2; }
.share-pill.cp { background: var(--mid); }

.related-posts-section { padding: 48px 0; background: var(--off-white); }
.related-posts-grid    { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; }

/* ── 24. Loading / Empty States ───────────────────────────────── */
.plrd-loading { text-align: center; padding: 48px 20px; color: var(--mid); grid-column: 1 / -1; }
.plrd-spinner { width: 36px; height: 36px; border: 3px solid var(--border); border-top-color: var(--primary); border-radius: var(--r-full); animation: plrdSpin 1s linear infinite; margin: 0 auto 14px; }
@keyframes plrdSpin { to { transform: rotate(360deg); } }
.plrd-empty   { text-align: center; padding: 48px 20px; color: var(--mid); grid-column: 1 / -1; }
.plrd-empty i { font-size: 2.5rem; margin-bottom: 14px; display: block; opacity: .3; }
.plrd-empty p { font-size: 14px; margin: 0; }

/* Alert / toast */
.plrd-toast {
  position: fixed; top: 80px; right: 20px;
  background: var(--dark); color: #fff;
  padding: 12px 20px; border-radius: var(--r-md);
  font-size: 14px; z-index: 9000;
  box-shadow: var(--shadow-lg);
  transform: translateX(120%);
  transition: transform .35s cubic-bezier(.25,.46,.45,.94);
}
.plrd-toast.show { transform: translateX(0); }
.plrd-toast.success { background: var(--primary-d); }
.plrd-toast.error   { background: var(--danger); }

/* ── 25. Form Helpers ─────────────────────────────────────────── */
.form-alert { padding: 12px 16px; border-radius: var(--r-sm); font-size: 14px; margin-top: 12px; display: none; }
.form-alert.success { background: rgba(16,185,129,.1); color: #065f46; border: 1px solid rgba(16,185,129,.3); }
.form-alert.error   { background: rgba(239,68,68,.1);  color: #991b1b; border: 1px solid rgba(239,68,68,.3); }

/* ── 26. Utility ──────────────────────────────────────────────── */
.text-green  { color: var(--primary) !important; }
.bg-green-lt { background: var(--primary-bg) !important; }
.section-pad { padding: 64px 0; }
.section-pad-sm { padding: 40px 0; }
.divider     { height: 1px; background: var(--border); margin: 40px 0; }
.rounded-img { border-radius: var(--r-lg); overflow: hidden; }

/* ── 27. Print Styles ─────────────────────────────────────────── */
@media print {
  #plrdNav, .footer, #back-to-top, #cookie-banner,
  .search-modal-overlay, .hero-arrow, .hero-dots,
  .btn-load-more, .filter-chips, .post-share-row { display: none !important; }
  body   { font-size: 12pt; color: #000; }
  a      { color: #000; text-decoration: underline; }
  .post-content img { max-width: 80%; }
  .page-hero { background: #f0fdf4 !important; color: #000 !important; padding: 20px 0; }
  .post-detail { padding: 20px 0; }
}

/* ── 28. Responsive ───────────────────────────────────────────── */
@media (max-width: 767px) {
  .stats-grid           { grid-template-columns: repeat(2, 1fr); }
  .hero-content         { bottom: 60px; }
  .hero-content h1      { font-size: 1.6rem; }
  .newsletter-form      { flex-direction: column; }
  .newsletter-form input { min-width: 0; }
  .related-posts-grid   { grid-template-columns: 1fr; }
  .project-donate-cards { grid-template-columns: 1fr 1fr; }
  .post-share-row       { flex-direction: column; align-items: flex-start; }
  #darfurMap            { height: 320px; }
}
@media (max-width: 479px) {
  .stats-grid           { grid-template-columns: 1fr; }
  .project-donate-cards { grid-template-columns: 1fr; }
  .hero-arrow           { display: none; }
}