/* ============================================================
   CDF Website - Page Specific Styles
   Consolidated from embedded PHP page style blocks.
   Keep reusable design-system styles in cdf.css.
   ============================================================ */

/* ============================================================
   Source: .\contact.php style block 1
   ============================================================ */
@media (max-width:768px){
  .contact-layout { grid-template-columns: 1fr !important; }
}

/* ============================================================
   Source: .\index.php style block 1
   ============================================================ */
/* ── Home-specific styles ─────────────────────────────────────── */

/* 1. HERO — dark charcoal, large editorial type, orange accents */
.h-hero {
  background: #1A1F2E;
  position: relative;
  overflow: hidden;
  padding: 100px 0 80px;
}
.h-hero::before {
  content:'';
  position:absolute;
  top:-120px; right:-120px;
  width:440px; height:440px;
  border-radius:50%;
  background: radial-gradient(circle, rgba(249,115,22,0.18) 0%, transparent 70%);
  pointer-events:none;
}
.h-hero::after {
  content:'';
  position:absolute;
  bottom:-80px; left:20%;
  width:260px; height:260px;
  border-radius:50%;
  background: radial-gradient(circle, rgba(245,180,0,0.10) 0%, transparent 70%);
  pointer-events:none;
}
.h-hero-inner {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 64px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.h-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(249,115,22,0.12);
  border: 1px solid rgba(249,115,22,0.3);
  border-radius: 99px;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 800;
  color: #F97316;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.h-hero-eyebrow span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #F97316;
  display: inline-block;
}
.h-hero-title {
  font-family: var(--font-heading);
  font-size: clamp(44px, 6vw, 72px);
  font-weight: 900;
  line-height: 1.04;
  letter-spacing: -0.03em;
  color: #FFFFFF;
  margin-bottom: 24px;
}
.h-hero-title .accent { color: #F97316; }
.h-hero-title .accent-gold { color: #F5B400; }
.h-hero-desc {
  font-size: 17px;
  line-height: 1.72;
  color: rgba(255,255,255,0.65);
  margin-bottom: 36px;
  max-width: 520px;
}
.h-hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 52px;
}
.h-hero-stats {
  display: flex;
  gap: 36px;
  padding-top: 36px;
  border-top: 1px solid rgba(255,255,255,0.1);
  flex-wrap: wrap;
}
.h-hero-stat-num {
  font-family: var(--font-number);
  font-size: 30px;
  font-weight: 900;
  color: #F97316;
  line-height: 1;
  display: block;
}
.h-hero-stat-num.h-gold { color: #F5B400; }
.h-hero-stat-lbl {
  font-size: 12px;
  font-weight: 700;
  color: rgba(255,255,255,0.5);
  display: block;
  margin-top: 5px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
/* Hero Visual */
.h-hero-visual {
  position: relative;
}
.h-hero-img-wrap {
  width: 100%;
  aspect-ratio: 3/4;
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
}
.h-hero-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 24px;
}
.h-hero-img-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  color: rgba(255,255,255,0.25);
  font-size: 13px;
  font-weight: 600;
  text-align: center;
  padding: 32px;
}
.h-hero-img-placeholder svg { opacity: 0.35; }
/* floating card on hero image */
.h-hero-badge-card {
  position: absolute;
  bottom: 24px;
  left: -32px;
  background: #FFFFFF;
  border-radius: 16px;
  padding: 14px 18px;
  box-shadow: 0 20px 48px rgba(0,0,0,0.28);
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 190px;
}
.h-hero-badge-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: var(--cdf-primary-soft);
  color: var(--cdf-primary);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.h-hero-badge-icon svg { width: 20px; height: 20px; }
.h-hero-badge-num {
  font-family: var(--font-number);
  font-size: 22px; font-weight: 900;
  color: var(--cdf-charcoal);
  line-height: 1;
}
.h-hero-badge-lbl { font-size: 11px; color: var(--cdf-muted); font-weight: 600; }

/* ── SECTION: "We raise hope" — split with image + text + mini activity ── */
.h-raise {
  background: #FFFFFF;
  padding: 88px 0;
}
.h-raise-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.h-raise-img {
  border-radius: 20px;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--cdf-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.h-raise-img img { width:100%; height:100%; object-fit:cover; }
.h-raise-quote {
  font-family: var(--font-heading);
  font-size: clamp(22px, 3.5vw, 34px);
  font-weight: 800;
  color: var(--cdf-charcoal);
  line-height: 1.2;
  margin-bottom: 20px;
}
.h-raise-quote .accent { color: var(--cdf-primary); }
/* mini latest activity sidebar card */
.h-activity-card {
  border: 1px solid var(--cdf-border);
  border-radius: 16px;
  padding: 20px;
  background: #FFFFFF;
  box-shadow: var(--shadow-sm);
}
.h-activity-title {
  font-size: 11px;
  font-weight: 800;
  color: var(--cdf-muted);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 14px;
}
.h-activity-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid var(--cdf-border);
}
.h-activity-item:last-child { border-bottom: none; padding-bottom: 0; }
.h-activity-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--cdf-primary);
  flex-shrink: 0;
  margin-top: 5px;
}
.h-activity-text { font-size: 13px; color: var(--cdf-charcoal); font-weight: 600; line-height: 1.4; }
.h-activity-sub  { font-size: 12px; color: var(--cdf-muted); margin-top: 2px; }

/* ── SECTION: "You can help" — orange headline, 4 program icons ── */
.h-help {
  background: var(--cdf-bg);
  padding: 88px 0;
  text-align: center;
}
.h-help-title {
  font-family: var(--font-heading);
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 800;
  color: var(--cdf-charcoal);
  line-height: 1.15;
  margin-bottom: 12px;
}
.h-help-title .accent { color: var(--cdf-primary); }
.h-help-sub {
  font-size: 16px;
  color: var(--cdf-muted);
  margin-bottom: 52px;
  max-width: 560px;
  margin-inline: auto;
}
.h-prog-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-bottom: 36px;
}
.h-prog-card {
  background: #FFFFFF;
  border: 1px solid var(--cdf-border);
  border-radius: 18px;
  padding: 28px 20px 24px;
  text-align: center;
  transition: all 200ms ease;
  cursor: default;
}
.h-prog-card:hover {
  border-color: rgba(249,115,22,0.35);
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}
.h-prog-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  background: var(--cdf-primary-soft);
  color: var(--cdf-primary);
  display: grid; place-items: center;
  margin: 0 auto 14px;
  transition: background 200ms, color 200ms;
}
.h-prog-card:hover .h-prog-icon { background: var(--cdf-primary); color: #FFF; }
.h-prog-icon svg { width: 24px; height: 24px; }
.h-prog-name {
  font-family: var(--font-heading);
  font-size: 14px; font-weight: 700;
  color: var(--cdf-charcoal);
  line-height: 1.3;
}

/* ── SECTION: "See how CDF is responding" — 2-col project cards ── */
.h-respond {
  background: #FFFFFF;
  padding: 88px 0;
}
.h-respond-title {
  font-family: var(--font-heading);
  font-size: clamp(26px, 3.5vw, 42px);
  font-weight: 800;
  color: var(--cdf-charcoal);
  margin-bottom: 40px;
  text-align: center;
}
.h-respond-title .accent { color: var(--cdf-primary); }
.h-project-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.h-project-card {
  border: 1px solid var(--cdf-border);
  border-radius: 18px;
  overflow: hidden;
  background: #FFFFFF;
  transition: all 200ms ease;
}
.h-project-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.h-project-img {
  height: 170px;
  background: linear-gradient(135deg, var(--cdf-primary-soft), var(--cdf-bg));
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.h-project-img img { width:100%; height:100%; object-fit:cover; }
.h-project-img svg { opacity: 0.25; }
.h-project-body { padding: 20px; }
.h-project-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--cdf-primary-soft);
  color: var(--cdf-primary);
  border-radius: 99px;
  padding: 4px 10px;
  font-size: 11px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.05em;
  margin-bottom: 8px;
}
.h-project-name {
  font-family: var(--font-heading);
  font-size: 16px; font-weight: 700;
  color: var(--cdf-charcoal);
  margin-bottom: 8px; line-height: 1.35;
}
.h-project-meta {
  display: flex; gap: 16px; flex-wrap: wrap;
  font-size: 12px; color: var(--cdf-muted);
  margin-bottom: 10px;
}
.h-project-meta span { display: flex; align-items: center; gap: 4px; }
.h-project-meta svg { width:12px; height:12px; flex-shrink:0; }
.h-project-excerpt {
  font-size: 13px; color: var(--cdf-muted);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── SECTION: dark banner quote ── */
.h-banner {
  background: #1A1F2E;
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}
.h-banner::before {
  content:'';
  position:absolute; top:-80px; right:-80px;
  width:300px; height:300px; border-radius:50%;
  background: radial-gradient(circle, rgba(249,115,22,0.12) 0%, transparent 70%);
}
.h-banner-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  position: relative; z-index:1;
}
.h-banner-title {
  font-family: var(--font-heading);
  font-size: clamp(28px, 4vw, 50px);
  font-weight: 900;
  color: #FFFFFF;
  line-height: 1.1;
  margin-bottom: 20px;
  letter-spacing: -0.02em;
}
.h-banner-title .accent { color: #F97316; }
.h-banner-title .accent-gold { color: #F5B400; }
.h-banner-desc {
  font-size: 16px;
  color: rgba(255,255,255,0.6);
  line-height: 1.7;
  margin-bottom: 28px;
  max-width: 440px;
}
/* progress bars */
.h-progress-list { display: flex; flex-direction: column; gap: 18px; }
.h-progress-item {}
.h-progress-label {
  display: flex; justify-content: space-between;
  font-size: 13px; font-weight: 700;
  color: rgba(255,255,255,0.85);
  margin-bottom: 6px;
}
.h-progress-track {
  height: 6px; border-radius: 99px;
  background: rgba(255,255,255,0.1);
  overflow: hidden;
}
.h-progress-fill {
  height: 100%; border-radius: 99px;
  background: var(--cdf-primary);
  transition: width 1.2s ease;
}
.h-progress-fill.h-gold { background: var(--cdf-gold); }

/* ── SECTION: Trust / Values 4-up ── */
.h-values {
  background: var(--cdf-bg);
  padding: 88px 0;
}
.h-values-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
  margin-bottom: 52px;
}
.h-values-right { font-size: 15px; color: var(--cdf-muted); line-height: 1.7; }
.h-val-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.h-val-card {
  background: #FFFFFF;
  border: 1px solid var(--cdf-border);
  border-radius: 18px;
  padding: 24px 20px;
  transition: all 200ms ease;
}
.h-val-card:hover { border-color: rgba(249,115,22,0.3); transform:translateY(-3px); box-shadow:var(--shadow-sm); }
.h-val-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--cdf-primary-soft);
  color: var(--cdf-primary);
  display: grid; place-items: center;
  margin-bottom: 14px;
}
.h-val-icon svg { width: 22px; height: 22px; }
.h-val-name {
  font-family: var(--font-heading);
  font-size: 15px; font-weight: 700;
  color: var(--cdf-charcoal);
  margin-bottom: 6px;
}
.h-val-desc { font-size: 13px; color: var(--cdf-muted); line-height: 1.55; }

/* ── SECTION: Community action — 3 story cards ── */
.h-stories {
  background: #FFFFFF;
  padding: 88px 0;
}
.h-story-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 44px;
}
.h-story-card {
  border: 1px solid var(--cdf-border);
  border-radius: 20px;
  overflow: hidden;
  background: #FFFFFF;
  transition: all 200ms;
}
.h-story-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.h-story-img {
  height: 180px;
  background: linear-gradient(135deg, var(--cdf-bg), var(--cdf-primary-soft));
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.h-story-img img { width:100%; height:100%; object-fit:cover; }
.h-story-body { padding: 20px; }
.h-story-cat {
  font-size: 11px; font-weight: 800;
  color: var(--cdf-primary);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 8px;
  display: block;
}
.h-story-title {
  font-family: var(--font-heading);
  font-size: 15px; font-weight: 700;
  color: var(--cdf-charcoal);
  line-height: 1.35; margin-bottom: 8px;
}
.h-story-excerpt { font-size: 13px; color: var(--cdf-muted); line-height: 1.55; }

/* ── SECTION: Programs — 6-up grid ── */
.h-programs {
  background: var(--cdf-bg);
  padding: 88px 0;
}
.h-prog6-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 44px;
}
.h-prog6-card {
  background: #FFFFFF;
  border: 1px solid var(--cdf-border);
  border-radius: 18px;
  padding: 24px;
  transition: all 200ms;
}
.h-prog6-card:hover { border-color:rgba(249,115,22,0.3); transform:translateY(-3px); box-shadow:var(--shadow-sm); }
.h-prog6-img {
  height: 130px;
  background: linear-gradient(135deg, var(--cdf-primary-soft), var(--cdf-bg));
  border-radius: 12px;
  display: flex; align-items:center; justify-content:center;
  margin-bottom: 16px;
  overflow: hidden;
}
.h-prog6-img img { width:100%; height:100%; object-fit:cover; border-radius:12px; }
.h-prog6-img svg { opacity: 0.2; }
.h-prog6-name {
  font-family: var(--font-heading);
  font-size: 15px; font-weight: 700;
  color: var(--cdf-charcoal);
  margin-bottom: 6px;
}
.h-prog6-desc { font-size: 13px; color: var(--cdf-muted); line-height: 1.55; }
.h-prog6-tag {
  display: inline-block;
  margin-top: 10px;
  padding: 3px 10px;
  border-radius: 99px;
  background: var(--cdf-bg);
  color: var(--cdf-muted);
  font-size: 11px; font-weight: 700;
  border: 1px solid var(--cdf-border);
}

/* ── SECTION: Partner Connect ── */
.h-partner-connect {
  background: #FFFFFF;
  padding: 88px 0;
}
.h-partner-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.h-partner-tags {
  display: flex; flex-wrap: wrap; gap: 8px; margin: 20px 0 28px;
}
.h-partner-tag {
  padding: 6px 14px; border-radius: 99px;
  border: 1px solid var(--cdf-border);
  font-size: 12px; font-weight: 700;
  color: var(--cdf-charcoal);
  background: var(--cdf-bg);
  transition: all 180ms;
}
.h-partner-tag:hover { border-color:var(--cdf-primary); color:var(--cdf-primary); background:var(--cdf-primary-soft); }
.h-partner-img {
  border-radius: 20px;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--cdf-bg);
  display:flex; align-items:center; justify-content:center;
  box-shadow: var(--shadow-md);
}
.h-partner-img img { width:100%; height:100%; object-fit:cover; }
.h-partner-contact { margin-top: 24px; }
.h-partner-contact a {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 700; color: var(--cdf-charcoal);
  margin-bottom: 8px;
}
.h-partner-contact a svg { width:15px; height:15px; color:var(--cdf-primary); flex-shrink:0; }

/* ── SECTION: "Your contribution" — 6 donor icons ── */
.h-contrib {
  background: var(--cdf-bg);
  padding: 88px 0;
  text-align: center;
}
.h-donor-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 20px;
  margin-top: 48px;
}
.h-donor-card {
  background: var(--logo-bg, #FFFFFF);
  border: 1px solid var(--cdf-border);
  border-radius: 18px;
  padding: 24px 16px;
  width: var(--logo-card-width, auto);
  min-height: var(--logo-card-height, auto);
  display: flex;
  flex-direction: var(--logo-direction, column);
  align-items: var(--logo-align, center);
  justify-content: var(--logo-justify, center);
  gap: var(--logo-gap, 10px);
  text-align: var(--logo-text-align, center);
  transition: all 200ms;
}
.h-donor-card:hover { border-color:rgba(249,115,22,0.3); transform:translateY(-3px); box-shadow:var(--shadow-sm); }
.h-donor-card img {
  width: var(--logo-size, 72px) !important;
  height: var(--logo-size, 72px) !important;
  object-fit: var(--logo-fit, contain) !important;
  display: block;
  margin: var(--logo-img-margin, 0 auto) !important;
  padding: var(--logo-padding, 0);
  border-radius: var(--logo-radius, 0);
  flex-shrink: 0;
}
.h-donor-orb {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--cdf-primary);
  display: grid; place-items: center;
}
.h-donor-orb svg { width: 26px; height: 26px; color: #fff; }
.h-donor-name { font-size: 12px; font-weight: 700; color: var(--cdf-charcoal); text-align:var(--logo-text-align, center); line-height:1.3; }

.cdf-partner-card[data-logo-card] {
  background: var(--logo-bg, #fff);
  width: var(--logo-card-width, auto);
  min-height: var(--logo-card-height, 80px);
  display: flex;
  flex-direction: var(--logo-direction, column);
  align-items: var(--logo-align, center);
  justify-content: var(--logo-justify, center);
  gap: var(--logo-gap, 10px);
  text-align: var(--logo-text-align, center);
  border-radius: var(--logo-card-radius, var(--radius-md));
  box-sizing: border-box;
  overflow: hidden;
}
.cdf-partner-card[data-logo-card] img {
  width: var(--logo-size, 72px) !important;
  height: var(--logo-size, 72px) !important;
  object-fit: var(--logo-fit, contain) !important;
  display: block;
  flex-shrink: 0;
  margin: var(--logo-img-margin, 0 auto) !important;
  padding: var(--logo-padding, 0);
  border-radius: var(--logo-radius, 0);
}
.cdf-partner-card[data-logo-card] .cdf-logo-label-group {
  width: 100%;
  min-width: 0;
  text-align: var(--logo-text-align, center);
}
.cdf-partner-card[data-logo-card] .cdf-partner-logo-label,
.cdf-partner-card[data-logo-card] .cdf-partner-logo-full {
  text-align: var(--logo-text-align, center);
}
.cdf-network-logo-card[data-logo-card] {
  background: var(--logo-bg, transparent);
  display: flex;
  flex-direction: var(--logo-direction, row);
  align-items: var(--logo-align, center);
  justify-content: var(--logo-justify, flex-start);
  gap: var(--logo-gap, 14px);
  text-align: var(--logo-text-align, left);
  border-radius: var(--logo-card-radius, 0);
  width: var(--logo-card-width, auto);
  min-height: var(--logo-card-height, auto);
  box-sizing: border-box;
}
.cdf-network-logo-card[data-logo-card] img {
  width: var(--logo-size, 56px) !important;
  height: var(--logo-size, 56px) !important;
  object-fit: var(--logo-fit, contain) !important;
  margin: var(--logo-img-margin, 0) !important;
  padding: var(--logo-padding, 0);
  border-radius: var(--logo-radius, 10px);
  flex-shrink: 0;
}
.cdf-network-logo-card[data-logo-card] .cdf-logo-label-group {
  text-align: var(--logo-text-align, left);
}

/* ── PARTNER LOGO CAROUSEL ────────────────────────────────── */
/* ITEM SIZE: fixed 90px wide, 10px gap, 5 visible = 90*5 + 10*4 = 490px min */
:root { --pc-item: 90px; --pc-gap: 10px; }
.cdf-partner-carousel-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
}
.cdf-pc-viewport {
  flex: 1;
  min-width: 0;
  max-width: 490px;    /* 5 × 90px + 4 × 10px gap = 490px — hard CSS clip */
  overflow: hidden;
}
@media (max-width: 600px) {
  .cdf-pc-viewport { max-width: 290px; }  /* 3 × 90px + 2 × 10px = 290px */
}
.cdf-pc-track {
  display: flex;
  flex-wrap: nowrap;  /* NEVER wrap onto a second row */
  gap: var(--pc-gap);
  transform: translateX(0);
  transition: transform 360ms cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.cdf-pc-item {
  flex: 0 0 var(--pc-item);
  width: var(--logo-card-width, var(--pc-item));
  min-width: var(--logo-card-width, var(--pc-item));
  max-width: var(--logo-card-width, var(--pc-item));
  display: flex;
  flex-direction: var(--logo-direction, column);
  align-items: var(--logo-align, center);
  justify-content: var(--logo-justify, center);
  gap: var(--logo-gap, 6px);
  padding: 8px 4px 10px;
  border: 1px solid var(--cdf-border);
  border-radius: var(--logo-card-radius, 12px);
  background: var(--logo-bg, #fff);
  min-height: var(--logo-card-height, auto);
  text-align: var(--logo-text-align, center);
  transition: box-shadow 200ms, border-color 200ms;
  box-sizing: border-box;
  overflow: hidden;
}
.cdf-pc-item:hover { border-color: rgba(249,115,22,0.3); box-shadow: 0 4px 16px rgba(0,0,0,0.07); }
.cdf-pc-item img {
  width: var(--logo-size, 64px) !important;
  height: var(--logo-size, 64px) !important;
  object-fit: var(--logo-fit, contain) !important;
  display: block;
  flex-shrink: 0;
  pointer-events: none;
  margin: var(--logo-img-margin, 0 auto) !important;
  padding: var(--logo-padding, 0);
  border-radius: var(--logo-radius, 0);
}
.cdf-pc-item.ac-anim-pulse img,
.h-donor-card.ac-anim-pulse img,
.cdf-partner-card.ac-anim-pulse img,
.cdf-network-logo-card.ac-anim-pulse img { animation: ac-logo-pulse 1.4s ease-in-out infinite; }
.cdf-pc-item.ac-anim-spin img,
.h-donor-card.ac-anim-spin img,
.cdf-partner-card.ac-anim-spin img,
.cdf-network-logo-card.ac-anim-spin img { animation: ac-logo-spin 2s linear infinite; }
.cdf-pc-item.ac-anim-bounce img,
.h-donor-card.ac-anim-bounce img,
.cdf-partner-card.ac-anim-bounce img,
.cdf-network-logo-card.ac-anim-bounce img { animation: ac-logo-bounce 1s ease-in-out infinite; }
.cdf-pc-item.ac-anim-shake img,
.h-donor-card.ac-anim-shake img,
.cdf-partner-card.ac-anim-shake img,
.cdf-network-logo-card.ac-anim-shake img { animation: ac-logo-shake .5s ease-in-out infinite; }
@keyframes ac-logo-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.12)} }
@keyframes ac-logo-spin { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes ac-logo-bounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes ac-logo-shake { 0%,100%{transform:rotate(0)} 25%{transform:rotate(-7deg)} 75%{transform:rotate(7deg)} }
.cdf-pc-label {
  font-size: 9px;
  font-weight: 700;
  color: var(--cdf-muted);
  text-align: var(--logo-text-align, center);
  line-height: 1.3;
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 0 2px;
}
.cdf-pc-arrow {
  flex-shrink: 0;
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 1.5px solid var(--cdf-border);
  background: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: var(--cdf-charcoal);
  transition: background 180ms, border-color 180ms, color 180ms;
  padding: 0;
  line-height: 1;
}
.cdf-pc-arrow:hover  { background: var(--cdf-primary); border-color: var(--cdf-primary); color: #fff; }
.cdf-pc-arrow:disabled { opacity: 0.32; cursor: default; pointer-events: none; }

/* ── SECTION: dark bottom stats ── */
.h-stats-dark {
  background: #1A1F2E;
  padding: 72px 0;
  position: relative;
  overflow: hidden;
}
.h-stats-dark::before {
  content:'';
  position:absolute; bottom:-60px; left:-60px;
  width:240px; height:240px; border-radius:50%;
  background: radial-gradient(circle, rgba(249,115,22,0.10) 0%, transparent 70%);
}
.h-stats-dark-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  position: relative; z-index:1;
}
.h-stats-dark-title {
  font-family: var(--font-heading);
  font-size: clamp(26px, 3.5vw, 44px);
  font-weight: 900;
  color: #FFFFFF;
  line-height: 1.15;
  letter-spacing: -0.02em;
}
.h-stats-dark-title .accent { color: #F97316; }
.h-stats-dark-title .accent-gold { color: #F5B400; }
.h-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.h-stat-item {
  text-align: center;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 24px 12px;
}
.h-stat-num {
  font-family: var(--font-number);
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 900;
  color: #F97316;
  line-height: 1;
  display: block;
}
.h-stat-num.h-gold { color: #F5B400; }
.h-stat-lbl {
  font-size: 12px; font-weight: 700;
  color: rgba(255,255,255,0.5);
  display: block; margin-top: 8px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

/* ── SECTION: CTA / Let's work together ── */
.h-final-cta {
  background: #FFFFFF;
  padding: 80px 0;
}
.h-cta-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.h-cta-left-title {
  font-family: var(--font-heading);
  font-size: clamp(26px, 3.5vw, 42px);
  font-weight: 900;
  color: var(--cdf-charcoal);
  line-height: 1.15;
  margin-bottom: 12px;
  letter-spacing: -0.02em;
}
.h-cta-left-title .accent { color: var(--cdf-primary); }
.h-cta-form { display: flex; flex-direction: column; gap: 16px; }
.h-cta-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.h-newsletter-wrap {
  background: var(--cdf-charcoal);
  border-radius: 14px;
  padding: 20px;
  display: flex;
  gap: 10px;
  margin-top: 4px;
}
.h-newsletter-wrap input {
  flex: 1;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 10px;
  padding: 10px 14px;
  color: #FFF;
  font-size: 14px;
  outline: none;
}
.h-newsletter-wrap input::placeholder { color: rgba(255,255,255,0.4); }
.h-newsletter-wrap input:focus { border-color: var(--cdf-primary); }

/* ─ Responsive ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .h-hero-inner  { grid-template-columns: 1fr; }
  .h-hero-visual { display: none; }
  .h-prog-grid   { grid-template-columns: repeat(2,1fr); }
  .h-val-grid    { grid-template-columns: repeat(2,1fr); }
  .h-donor-grid  { grid-template-columns: repeat(3,1fr); }
  .h-stats-dark-inner { grid-template-columns: 1fr; }
  .h-stats-grid  { grid-template-columns: repeat(2,1fr); }
  .h-raise-grid  { grid-template-columns: 1fr; }
  .h-banner-inner{ grid-template-columns: 1fr; }
  .h-values-header{ grid-template-columns: 1fr; }
  .h-partner-inner{ grid-template-columns: 1fr; }
  .h-cta-inner   { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .h-hero        { padding: 64px 0 56px; }
  .h-prog6-grid  { grid-template-columns: repeat(2,1fr); }
  .h-project-grid{ grid-template-columns: 1fr; }
  .h-story-grid  { grid-template-columns: 1fr; }
  .h-cta-row     { grid-template-columns: 1fr; }
  .h-hero-stats  { gap: 24px; }
}
@media (max-width: 540px) {
  .h-prog-grid   { grid-template-columns: repeat(2,1fr); }
  .h-val-grid    { grid-template-columns: 1fr 1fr; }
  .h-donor-grid  { grid-template-columns: repeat(2,1fr); }
  .h-prog6-grid  { grid-template-columns: 1fr; }
  .h-stats-grid  { grid-template-columns: repeat(2,1fr); }
}


/* AsliCreate CDF: publication thumbnail images */
.cdf-pub-thumb{
  width:76px;
  height:76px;
  border-radius:14px;
  overflow:hidden;
  flex-shrink:0;
  background:var(--cdf-bg);
  border:1px solid var(--cdf-border);
}
.cdf-pub-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
