/* ═══════════════════════════════════════════════════════
   SIVF Theme — Component Styles
   ═══════════════════════════════════════════════════════ */

/* ─── Scroll Animations ─────────────────────────────── */
.fade-in { opacity: 0; transform: translateY(1.5rem); transition: opacity .5s ease, transform .5s ease; }
.fade-in.visible { opacity: 1; transform: translateY(0); }
.fade-left  { opacity: 0; transform: translateX(-2rem); transition: opacity .6s ease, transform .6s ease; }
.fade-left.visible  { opacity: 1; transform: translateX(0); }
.fade-right { opacity: 0; transform: translateX(2rem);  transition: opacity .6s ease, transform .6s ease; }
.fade-right.visible { opacity: 1; transform: translateX(0); }
.stagger-1 { transition-delay: .1s; }
.stagger-2 { transition-delay: .2s; }
.stagger-3 { transition-delay: .3s; }
.stagger-4 { transition-delay: .4s; }

/* ─── Top Info Bar ──────────────────────────────────── */
.topbar {
  background: var(--color-teal);
  color: #fff;
  font-size: .8125rem;
  padding-block: .5rem;
  display: none; /* desktop only */
}
@media (min-width: 1024px) { .topbar { display: block; } }

.topbar-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.topbar-left  { display: flex; gap: 1.5rem; align-items: center; }
.topbar-right { display: flex; align-items: center; }

.topbar-item {
  display: flex;
  align-items: center;
  gap: .4rem;
  color: rgba(255,255,255,.9);
  text-decoration: none;
  transition: color .15s;
}
.topbar-item:hover { color: #fff; }
.topbar-item svg { flex-shrink: 0; opacity: .85; }

/* ─── Header ────────────────────────────────────────── */
.site-header {
  background: #fff;
  box-shadow: var(--shadow-sm);
  position: sticky;
  top: 0;
  z-index: 100;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 5rem;
  gap: 2rem;
}
.site-logo .logo-img { height: 3rem; width: auto; }

/* Primary Nav */
.nav-list { display: flex; align-items: center; gap: 2rem; }
.nav-item > a {
  font-size: .9375rem;
  font-weight: 500;
  color: var(--color-muted);
  transition: color .2s;
  padding-bottom: .25rem;
  border-bottom: 2px solid transparent;
}
.nav-item > a:hover,
.nav-item.active > a {
  color: var(--color-teal);
  border-bottom-color: var(--color-teal);
}
.dropdown-arrow { font-size: .6rem; margin-left: .25rem; }

/* Dropdown */
.nav-item.has-dropdown { position: relative; }
.dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  box-shadow: var(--shadow-lg);
  border-radius: var(--radius);
  border: 1px solid var(--color-border);
  padding: .5rem 0;
  padding-top: 1rem;  /* visual gap without breaking hover */
  margin-top: -.5rem; /* overlap nav item slightly to close the gap */
  min-width: 12rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity .2s, transform .2s;
  transform: translateX(-50%) translateY(.5rem);
}
.nav-item.has-dropdown:hover .dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  transition: opacity .2s, transform .2s;
}

/* Delay hiding so mouse can travel into the dropdown */
.dropdown {
  transition: opacity .2s .1s, transform .2s .1s, visibility 0s .3s;
}
.nav-item.has-dropdown:hover .dropdown {
  transition: opacity .15s, transform .15s, visibility 0s;
}
.dropdown li a {
  display: block;
  padding: .6rem 1.25rem;
  font-size: .875rem;
  color: var(--color-muted);
  transition: background .15s, color .15s;
}
.dropdown li a:hover { background: var(--color-teal-soft); color: var(--color-teal); }

/* Mobile toggle */
.mobile-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: .5rem;
}
.mobile-toggle span { display: block; width: 24px; height: 2px; background: var(--color-ink); border-radius: 2px; transition: all .3s; }
.mobile-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mobile-toggle.open span:nth-child(2) { opacity: 0; }
.mobile-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav */
.mobile-nav {
  background: #fff;
  border-top: 1px solid var(--color-border);
  padding: 1rem 0;
}
.mobile-nav-list { padding-inline: 1.5rem; }
.mobile-nav-list li { border-bottom: 1px solid var(--color-border); }
.mobile-nav-list li a,
.mobile-dropdown-toggle {
  display: block;
  padding: .875rem 0;
  font-size: 1rem;
  color: var(--color-ink);
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  font-family: var(--font-body);
}
.mobile-dropdown { padding: 0 1rem 1rem; }
.mobile-dropdown li a { padding: .5rem 0; font-size: .9rem; color: var(--color-muted); border-bottom: none; }

@media (max-width: 1024px) {
  .primary-nav, .header-cta { display: none; }
  .mobile-toggle { display: flex; }
}

/* ─── Inner Page Hero ───────────────────────────────── */
.page-hero {
  background: linear-gradient(135deg, #f0f9ff 0%, #ffffff 60%, #eff6ff 100%);
  padding-block: 4rem 3rem;
  text-align: center;
  border-bottom: 1px solid var(--color-border);
}
.page-hero .section-label { margin-bottom: .75rem; }
.page-hero h1 {
  font-family: var(--font-heading);
  font-size: clamp(1.875rem, 4vw, 3rem);
  font-weight: 700;
  color: var(--color-ink);
  margin-bottom: 1rem;
  line-height: 1.2;
}
.page-hero p {
  font-size: 1.0625rem;
  color: var(--color-muted);
  max-width: 44rem;
  margin-inline: auto;
  line-height: 1.7;
}

/* ─── Hero ──────────────────────────────────────────── */
.hero {
  position: relative;
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 50%, #eff6ff 100%);
  padding-block: 6rem;
  overflow: hidden;
}
/* Decorative blobs */
.hero-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.hero-bg::before {
  content: '';
  position: absolute;
  top: -5rem;
  right: -5rem;
  width: 28rem;
  height: 28rem;
  background: radial-gradient(circle, rgba(8,145,178,.08) 0%, transparent 70%);
  border-radius: 50%;
}
.hero-bg::after {
  content: '';
  position: absolute;
  bottom: -5rem;
  left: -5rem;
  width: 22rem;
  height: 22rem;
  background: radial-gradient(circle, rgba(249,115,22,.06) 0%, transparent 70%);
  border-radius: 50%;
}
.hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.hero-title {
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  font-weight: 700;
  color: var(--color-ink);
  margin-bottom: 1.25rem;
  line-height: 1.15;
}
.hero-title span { color: var(--color-teal); }
.hero-desc { font-size: 1.125rem; color: var(--color-muted); margin-bottom: 2rem; max-width: 38rem; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-stats { display: grid; grid-template-columns: repeat(2,1fr); gap: 1rem; }
.stat-card {
  background: #fff;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-md);
  border-radius: var(--radius);
  padding: 1.5rem;
  text-align: center;
}
.stat-num { display: block; font-size: 2rem; font-weight: 700; font-family: var(--font-heading); color: var(--color-teal); }
.stat-lbl { font-size: .8125rem; color: var(--color-muted); margin-top: .25rem; display: block; }

@media (max-width: 768px) {
  .hero-inner { grid-template-columns: 1fr; gap: 2rem; }
  .hero-stats { grid-template-columns: repeat(4,1fr); }
}
@media (max-width: 480px) { .hero-stats { grid-template-columns: repeat(2,1fr); } }

/* ─── Background variants ───────────────────────────── */
.bg-teal-soft { background: var(--color-teal-soft); }

/* ─── Service Cards ─────────────────────────────────── */
.card-thumb { overflow: hidden; aspect-ratio: 16/9; }
.card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.card:hover .card-thumb img { transform: scale(1.05); }
.service-card h3 { font-size: 1.125rem; margin-block: .75rem .5rem; }
.service-card h3 a { color: var(--color-ink); }
.service-card h3 a:hover { color: var(--color-teal); }
.service-meta { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: .75rem; font-size: .8125rem; color: var(--color-muted); }
.card-link { display: inline-flex; align-items: center; gap: .375rem; margin-top: 1rem; font-size: .875rem; font-weight: 600; color: var(--color-teal); }
.card-link:hover { color: var(--color-teal-dark); }

/* ─── Why Choose Us ─────────────────────────────────── */
.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.why-features { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.why-item { display: flex; gap: 1rem; align-items: flex-start; }
.why-icon { font-size: 1.75rem; line-height: 1; flex-shrink: 0; }
.why-item h4 { font-size: .9375rem; margin-bottom: .25rem; }
.why-item p { font-size: .875rem; color: var(--color-muted); }
@media (max-width: 768px) {
  .why-grid { grid-template-columns: 1fr; gap: 2rem; }
  .why-features { grid-template-columns: 1fr; }
}

/* ─── Leaders ───────────────────────────────────────── */
.leader-card { display: flex; flex-direction: column; }
.leader-photo { height: 20rem; overflow: hidden; }
.leader-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.leader-info h3 { font-size: 1.25rem; margin-bottom: .25rem; }
.leader-designation { color: var(--color-teal); font-weight: 500; margin-bottom: .25rem; }
.leader-quals { font-size: .875rem; color: var(--color-muted); margin-bottom: .75rem; }
.highlights-list { margin-top: .75rem; display: flex; flex-direction: column; gap: .375rem; }
.highlights-list li { font-size: .875rem; color: var(--color-muted); }
.leader-quote {
  margin-top: 1rem;
  border-left: 3px solid var(--color-teal);
  padding-left: 1rem;
  font-style: italic;
  color: var(--color-muted);
  font-size: .9rem;
}

/* Leader profile (full page) */
.leader-profile-inner { display: grid; grid-template-columns: 360px 1fr; }
.leader-profile-photo { position: relative; }
.leader-profile-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.highlight-badge {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  background: rgba(255,255,255,.95);
  border-radius: 9999px;
  padding: .375rem .875rem;
  font-size: .75rem;
  font-weight: 600;
  color: var(--color-teal);
  display: flex;
  align-items: center;
  gap: .375rem;
  box-shadow: var(--shadow-sm);
  margin-bottom: .375rem;
}
.highlight-badge:not(:last-of-type) { bottom: auto; }
@media (max-width: 768px) {
  .leader-profile-inner { grid-template-columns: 1fr; }
  .leader-profile-photo { height: 20rem; }
}
.tag-list { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .5rem; }

/* ─── Blog Cards ────────────────────────────────────── */
.blog-card h3 { font-size: 1.0625rem; margin-block: .75rem .5rem; }
.blog-card h3 a { color: var(--color-ink); }
.blog-card h3 a:hover { color: var(--color-teal); }
.blog-meta { display: flex; gap: 1rem; font-size: .8125rem; color: var(--color-muted); margin-top: .75rem; }

/* ─── Blog Post ─────────────────────────────────────── */
.post-layout { display: grid; grid-template-columns: 1fr 280px; gap: 3rem; align-items: start; }
@media (max-width: 900px) { .post-layout { grid-template-columns: 1fr; } }
.prose { line-height: 1.8; color: var(--color-ink); }
.prose p { margin-bottom: 1rem; }
.prose h2, .prose h3 { font-family: var(--font-heading); margin-block: 1.75rem 1rem; }
.prose ul, .prose ol { padding-left: 1.5rem; margin-bottom: 1rem; }
.prose li { margin-bottom: .375rem; }
.prose strong { font-weight: 600; }
.sidebar-post-list li { padding: .5rem 0; border-bottom: 1px solid var(--color-border); font-size: .875rem; }
.sidebar-post-list li a { color: var(--color-ink); }
.sidebar-post-list li a:hover { color: var(--color-teal); }

/* ─── Service Single ────────────────────────────────── */
.service-layout { display: grid; grid-template-columns: 1fr 300px; gap: 3rem; align-items: start; }
@media (max-width: 900px) { .service-layout { grid-template-columns: 1fr; } }
.process-steps { padding: 0; counter-reset: none; }
.process-step { display: flex; gap: 1.25rem; margin-bottom: 1.5rem; align-items: flex-start; }
.step-num {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  background: var(--color-teal);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: .9rem;
}
.step-body h4 { margin-bottom: .25rem; }
.step-body p { font-size: .9rem; color: var(--color-muted); }
.benefits-list { padding: 0; }
.benefits-list li { display: flex; gap: .75rem; align-items: flex-start; padding: .625rem 0; border-bottom: 1px solid var(--color-border); font-size: .9375rem; }
.benefit-check { color: var(--color-teal); font-weight: 700; flex-shrink: 0; }
.sidebar-stats h3 { margin-bottom: 1rem; }
.sidebar-stat { display: flex; justify-content: space-between; padding: .625rem 0; border-bottom: 1px solid var(--color-border); font-size: .9rem; }
.sidebar-stat-label { color: var(--color-muted); }
.sidebar-stat-value { font-weight: 600; }
.sidebar-service-list li { padding: .5rem 0; border-bottom: 1px solid var(--color-border); font-size: .875rem; }
.sidebar-service-list li a { color: var(--color-muted); }
.sidebar-service-list li.active a, .sidebar-service-list li a:hover { color: var(--color-teal); font-weight: 500; }
.service-meta-list { margin-top:.75rem; padding:0; list-style:none; font-size:.875rem; color:var(--color-muted); }
.service-meta-list li { padding: .25rem 0; }

/* ─── About Page ────────────────────────────────────── */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
@media (max-width: 768px) { .about-grid { grid-template-columns: 1fr; } }

/* ─── Foundation Stats ───────────────────────────────── */
.foundation-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  text-align: center;
}
@media (max-width: 768px) { .foundation-stats-row { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .foundation-stats-row { grid-template-columns: 1fr 1fr; } }
.foundation-stat-item {
  padding: 2rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: #fff;
}
.foundation-stat-icon { display: block; font-size: 2rem; margin-bottom: .5rem; }
.foundation-stat-num {
  display: block;
  font-size: 2.25rem;
  font-weight: 700;
  font-family: var(--font-heading);
  color: var(--color-teal);
  margin-bottom: .25rem;
}
.foundation-stat-lbl { display: block; font-size: .9375rem; font-weight: 600; color: var(--color-ink); margin-bottom: .25rem; }
.foundation-stat-sub { display: block; font-size: .8125rem; color: var(--color-muted); }
.about-values { display: flex; flex-direction: column; gap: 1rem; }
.value-card h3 { margin-bottom: .5rem; font-size: 1.0625rem; }
.value-card p { font-size: .9rem; color: var(--color-muted); }

/* ─── Team ──────────────────────────────────────────── */
.team-card { text-align: center; }
.team-photo { height: 12rem; overflow: hidden; }
.team-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.team-photo-placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-teal-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  font-family: var(--font-heading);
  color: var(--color-teal);
  font-weight: 700;
}
.team-role { font-size: .875rem; color: var(--color-muted); margin-bottom: .5rem; }
.team-card h4 { font-size: 1rem; margin-bottom: .25rem; }

/* ─── Contact ───────────────────────────────────────── */
.contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 900px) { .contact-layout { grid-template-columns: 1fr; } }
.hours-list { padding: 0; }
.hours-list li { display: flex; justify-content: space-between; padding: .5rem 0; border-bottom: 1px solid var(--color-border); font-size: .9rem; color: var(--color-muted); }
.contact-list { padding: 0; }
.contact-list li { display: flex; align-items: flex-start; gap: .75rem; padding: .75rem 0; border-bottom: 1px solid var(--color-border); font-size: .9rem; color: var(--color-muted); }
.contact-list li a { color: var(--color-teal); }

/* ─── Stories ───────────────────────────────────────── */
.story-header { display: flex; gap: 1rem; align-items: center; margin-bottom: 1rem; }
.story-avatar {
  width: 3rem;
  height: 3rem;
  background: var(--color-teal);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 700;
  font-family: var(--font-heading);
  flex-shrink: 0;
}
.story-rating { margin-bottom: .75rem; font-size: 1rem; }
.story-text { font-style: italic; color: var(--color-muted); font-size: .9375rem; margin-bottom: 1rem; }
.story-outcome { font-size: .875rem; color: var(--color-teal); font-weight: 500; }
.story-outcome span { margin-right: .375rem; }

/* ─── Media Page ────────────────────────────────────── */
.media-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  text-align: center;
}
@media (max-width: 640px) { .media-stats-row { grid-template-columns: repeat(2, 1fr); } }
.media-stat-item {
  padding: 1.25rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: #fff;
}
.media-stat-num {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  font-family: var(--font-heading);
  color: var(--color-teal);
  margin-bottom: .25rem;
}
.media-stat-lbl { font-size: .8125rem; color: var(--color-muted); }

.media-tabs { display: flex; gap: .5rem; margin-bottom: 2.5rem; flex-wrap: wrap; }
.tab-btn {
  padding: .625rem 1.5rem;
  border: 2px solid var(--color-border);
  border-radius: 9999px;
  background: #fff;
  font-family: var(--font-body);
  font-size: .9375rem;
  font-weight: 500;
  cursor: pointer;
  color: var(--color-muted);
  transition: all .2s;
}
.tab-btn.active, .tab-btn:hover { border-color: var(--color-teal); color: var(--color-teal); background: var(--color-teal-soft); }
.media-card h4 { margin-block: .75rem .5rem; }
.media-video-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: #000;
  border-radius: var(--radius) var(--radius) 0 0;
  overflow: hidden;
}
.media-video-wrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.media-coming-soon {
  text-align: center;
  padding: 4rem 2rem;
  color: var(--color-muted);
}
.media-coming-soon .coming-soon-icon { font-size: 3rem; margin-bottom: 1rem; }
.media-coming-soon h3 { font-size: 1.25rem; color: var(--color-ink); margin-bottom: .5rem; }
.media-coming-soon p { font-size: .9375rem; }

/* ─── CTA Section ───────────────────────────────────── */
.section-cta { padding-block: 5rem; background: linear-gradient(135deg, var(--color-teal), var(--color-teal-dark)); }
.cta-box { text-align: center; max-width: 40rem; margin-inline: auto; }
.cta-box h2 { color: #fff; font-size: clamp(1.5rem, 4vw, 2.5rem); margin-bottom: 1rem; }
.cta-box p { color: rgba(255,255,255,.85); margin-bottom: 2rem; font-size: 1.0625rem; }
.cta-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
/* .btn-outline-white is defined in style.css with correct 9999px radius */

/* ─── Footer ────────────────────────────────────────── */
.site-footer { background: var(--color-ink); color: rgba(255,255,255,.75); }
.footer-top { padding-block: 4rem 3rem; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 3rem; }
@media (max-width: 900px) { .footer-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; } }

.footer-logo-img { height: 2.5rem; width: auto; filter: brightness(0) invert(1); margin-bottom: 1rem; }
.footer-tagline { font-size: .875rem; color: rgba(255,255,255,.9); font-weight: 500; margin-bottom: .5rem; }
.footer-desc { font-size: .8125rem; margin-bottom: 1.25rem; }

.social-links { display: flex; gap: .75rem; margin-top: .5rem; }
.social-link {
  width: 2.25rem;
  height: 2.25rem;
  background: rgba(255,255,255,.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.75);
  transition: background .2s, color .2s;
}
.social-link:hover { background: var(--color-teal); color: #fff; }

.footer-col h4 { color: #fff; font-size: .875rem; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; margin-bottom: 1.25rem; }
.footer-col ul li { margin-bottom: .625rem; }
.footer-col ul li a { font-size: .875rem; color: rgba(255,255,255,.65); transition: color .2s; }
.footer-col ul li a:hover { color: #fff; }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-block: 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .8125rem;
}
.footer-bottom .container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: .5rem; }
.footer-bottom p { color: rgba(255,255,255,.5); }

/* ═══════════════════════════════════════════════════════
   NEW COMPONENT STYLES
   ═══════════════════════════════════════════════════════ */

/* ─── Gradient text utility ─────────────────────────── */
.gradient-text {
  background: linear-gradient(90deg, var(--color-teal), var(--color-coral));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ─── Pill badges (top of hero) ─────────────────────── */
.hero-pill {
  display: inline-flex;
  align-items: center;
  background: rgba(255,255,255,.8);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(8,145,178,.2);
  border-radius: 9999px;
  padding: .5rem 1rem;
  font-size: .875rem;
  font-weight: 500;
  color: var(--color-ink);
}
.hero-pill-coral {
  background: rgba(249,115,22,.1);
  border-color: rgba(249,115,22,.2);
  color: var(--color-coral);
}
.hero-pills { display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: 1.5rem; }

/* ─── Hero status badges ────────────────────────────── */
.hero-status { display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; padding-top: 2rem; }
.hero-status-item { display: flex; align-items: center; gap: .5rem; font-size: .875rem; color: #4b5563; }
.dot-pulse { width: .75rem; height: .75rem; border-radius: 50%; animation: pulse-dot 2s ease-in-out infinite; }
.dot-green { background: #22c55e; }
.dot-teal  { background: var(--color-teal); }
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.85)} }

/* ─── Hero impact card (right side) ────────────────── */
.hero-impact-card {
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 1.5rem;
  padding: 2rem;
  box-shadow: 0 25px 50px rgba(0,0,0,.1);
}
.hero-impact-title { text-align: center; margin-bottom: 2rem; }
.hero-impact-title h3 { font-size: 1.5rem; font-weight: 700; color: var(--color-ink); margin-bottom: .25rem; }
.hero-impact-title p  { font-size: .875rem; color: var(--color-muted); }
.hero-impact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-bottom: 2rem; }
.hero-impact-stat { text-align: center; }
.hero-impact-num { font-size: 1.875rem; font-weight: 700; font-family: var(--font-heading); display: block; margin-bottom: .25rem; }
.hero-impact-lbl { font-size: .875rem; color: #4b5563; }
.hero-featured-card {
  background: linear-gradient(90deg, #a855f7, var(--color-coral));
  border-radius: 1rem;
  padding: 1.5rem;
  color: #fff;
}
.hero-featured-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.hero-featured-title { display: flex; align-items: center; gap: .75rem; font-weight: 600; font-size: 1.125rem; }
.hero-featured-badge { background: rgba(255,255,255,.2); border-radius: 9999px; padding: .25rem .75rem; font-size: .75rem; font-weight: 500; }
.hero-featured-desc { font-size: .875rem; color: rgba(255,255,255,.9); margin-bottom: 1rem; }

/* ─── Section gradient background ──────────────────── */
.section-gradient {
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 60%, #eff6ff 100%);
  padding-block: 5rem;
}

/* ─── Soft card (credentials / values) ─────────────── */
.soft-card {
  background: linear-gradient(135deg, rgba(8,145,178,.04), rgba(8,145,178,.02));
  border: 1px solid rgba(8,145,178,.1);
  border-radius: var(--radius);
  padding: 1.5rem;
}
.soft-card-teal {
  background: linear-gradient(135deg, var(--color-teal) 0%, var(--color-teal-dark) 100%);
  color: #fff;
}
.soft-card-teal h3, .soft-card-teal p { color: rgba(255,255,255,.9); }
.cred-icon { display: inline-flex; align-items: center; justify-content: center; width: 2.75rem; height: 2.75rem; border-radius: 1rem; margin-right: 1rem; flex-shrink: 0; }
.cred-icon-soft  { background: rgba(249,115,22,.1); color: var(--color-coral); }
.cred-icon-white { background: rgba(255,255,255,.2); color: #fff; }
.cred-row { display: flex; align-items: flex-start; }
.cred-row h3 { font-size: 1.0625rem; font-weight: 700; margin-bottom: .25rem; }
.cred-row p { font-size: .875rem; line-height: 1.6; }

/* ─── Core values grid ──────────────────────────────── */
.values-icon { display: flex; justify-content: center; margin-bottom: 1rem; }
.values-icon-inner { padding: 1rem; border-radius: 1rem; background: var(--color-teal-soft); color: var(--color-teal); font-size: 1.5rem; }
.values-card { text-align: center; padding: 1.5rem; }
.values-card h3 { font-size: 1.0625rem; font-weight: 700; margin-bottom: .75rem; }
.values-card p { font-size: .875rem; color: var(--color-muted); line-height: 1.6; }

/* ─── Stats gradient section ────────────────────────── */
.stats-gradient-section { padding-block: 5rem; background: linear-gradient(135deg, #f8fafc 0%, #ffffff 60%, #eff6ff 100%); }
.stats-card-colored {
  text-align: center;
  padding: 2rem 1.5rem;
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
}
.stats-card-colored .stat-value { font-size: 2.25rem; font-weight: 700; font-family: var(--font-heading); display: block; margin-bottom: .25rem; }
.stats-card-colored .stat-desc  { font-size: .8125rem; color: var(--color-muted); margin-top: .25rem; }
.stat-teal   .stat-value { color: var(--color-teal); }
.stat-coral  .stat-value { color: var(--color-coral); }
.stat-lav    .stat-value { color: #a855f7; }
.stat-ink    .stat-value { color: var(--color-ink); }
.stat-icon { display: inline-flex; align-items: center; justify-content: center; width: 2.5rem; height: 2.5rem; border-radius: .75rem; margin-bottom: .75rem; }
.stat-icon-teal   { background: var(--color-teal-soft); color: var(--color-teal); }
.stat-icon-coral  { background: rgba(249,115,22,.1);   color: var(--color-coral); }
.stat-icon-lav    { background: rgba(168,85,247,.1);   color: #a855f7; }
.stat-icon-ink    { background: rgba(15,23,42,.08);    color: var(--color-ink); }

/* ─── Timeline ──────────────────────────────────────── */
.timeline { position: relative; max-width: 48rem; margin-inline: auto; }
.timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0; bottom: 0;
  width: 2px;
  background: var(--color-border);
}
.timeline-item { display: flex; gap: 2rem; margin-bottom: 2.5rem; position: relative; }
.timeline-item:nth-child(odd)  { flex-direction: row; }
.timeline-item:nth-child(even) { flex-direction: row-reverse; }
.timeline-side {
  flex: 1;
  text-align: right;
}
.timeline-item:nth-child(even) .timeline-side { text-align: left; }
.timeline-dot {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 1rem; height: 1rem;
  background: var(--color-teal);
  border: 3px solid #fff;
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(8,145,178,.2);
  top: .25rem;
  flex-shrink: 0;
}
.timeline-year { font-size: .75rem; font-weight: 700; color: var(--color-teal); text-transform: uppercase; letter-spacing: .05em; margin-bottom: .25rem; }
.timeline-event { font-weight: 700; color: var(--color-ink); margin-bottom: .25rem; }
.timeline-desc { font-size: .875rem; color: var(--color-muted); }
@media (max-width: 640px) {
  .timeline::before { left: 1rem; }
  .timeline-item { flex-direction: row !important; gap: 1.25rem; padding-left: 2rem; }
  .timeline-side { text-align: left !important; }
  .timeline-dot { left: 1rem; }
}

/* ─── Stats bar (small compact metrics row) ─────────── */
.stats-bar { padding-block: 2.5rem; background: #fff; border-bottom: 1px solid var(--color-border); }
.stats-bar-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.stats-bar-item { text-align: center; }
.stats-bar-num { font-size: 1.875rem; font-weight: 700; font-family: var(--font-heading); display: block; }
.stats-bar-lbl { font-size: .875rem; color: var(--color-muted); margin-top: .25rem; }
@media (max-width: 640px) { .stats-bar-grid { grid-template-columns: repeat(2,1fr); } }

/* ─── Filter / category pill bar ───────────────────── */
.filter-bar { display: flex; flex-wrap: wrap; justify-content: center; gap: .75rem; padding-block: 1.5rem 2.5rem; }
.filter-btn {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .625rem 1.5rem;
  border-radius: 9999px;
  font-family: var(--font-body);
  font-size: .9375rem;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid var(--color-teal-soft);
  background: #fff;
  color: var(--color-muted);
  transition: all .2s;
}
.filter-btn:hover, .filter-btn.active {
  background: var(--color-teal);
  border-color: var(--color-teal);
  color: #fff;
  box-shadow: 0 4px 6px rgba(8,145,178,.2);
}
.filter-count {
  font-size: .75rem;
  padding: .125rem .5rem;
  border-radius: 9999px;
  background: var(--color-teal-soft);
  color: var(--color-teal);
  transition: all .2s;
}
.filter-btn.active .filter-count, .filter-btn:hover .filter-count {
  background: rgba(255,255,255,.2);
  color: #fff;
}

/* ─── Search box ────────────────────────────────────── */
.search-wrap { max-width: 48rem; margin: 0 auto 1.5rem; position: relative; }
.search-icon { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); color: var(--color-muted); pointer-events: none; }
.search-wrap input {
  width: 100%;
  padding: 1rem 1rem 1rem 3rem;
  border: 1px solid var(--color-teal-soft);
  border-radius: 1rem;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-ink);
  background: #fff;
  transition: border-color .2s, box-shadow .2s;
}
.search-wrap input:focus { outline: none; border-color: var(--color-teal); box-shadow: 0 0 0 3px rgba(8,145,178,.1); }

/* ─── New leader card (3-col) ───────────────────────── */
.leader-new {
  background: linear-gradient(135deg, rgba(8,145,178,.03), rgba(8,145,178,.01));
  border: 1px solid rgba(8,145,178,.1);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 2rem;
}
.leader-new-inner { display: grid; grid-template-columns: 1fr 2fr; gap: 0; }
.leader-new-left { padding: 2.5rem 2rem; border-right: 1px solid rgba(8,145,178,.08); }
.leader-new-right { padding: 2.5rem; }
.leader-avatar {
  width: 12rem;
  height: 12rem;
  border-radius: 1.5rem;
  overflow: hidden;
  margin: 0 auto 1.5rem;
  background: linear-gradient(135deg, var(--color-teal), #a855f7);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  font-weight: 700;
  color: #fff;
  font-family: var(--font-heading);
  position: relative;
}
.leader-avatar img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.leader-new-meta { text-align: center; }
.leader-new-meta .section-label { margin-bottom: .75rem; }
.leader-new-name { font-size: 1.875rem; font-weight: 700; color: var(--color-ink); margin-bottom: .25rem; }
.leader-new-desig { font-size: 1rem; color: var(--color-muted); font-weight: 500; margin-bottom: .5rem; }
.leader-new-exp { color: var(--color-teal); font-weight: 600; margin-bottom: 1.5rem; }
.leader-mini-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1.5rem; }
.leader-mini-stat { text-align: center; padding: 1rem; background: #fff; border-radius: 1rem; box-shadow: var(--shadow-sm); }
.leader-mini-stat .num { font-size: 1.5rem; font-weight: 700; display: block; }
.leader-mini-stat .lbl { font-size: .75rem; color: var(--color-muted); }
.leader-mini-stat.teal .num { color: var(--color-teal); }
.leader-mini-stat.coral .num { color: var(--color-coral); }
.leader-section { margin-bottom: 2rem; }
.leader-section h3 { font-size: 1.125rem; font-weight: 700; color: var(--color-ink); margin-bottom: 1rem; display: flex; align-items: center; gap: .625rem; }
.leader-section h3 svg, .leader-section h3 .icon { color: var(--color-teal); }
.leader-content-box { background: #fff; border-radius: 1rem; padding: 1.5rem; box-shadow: var(--shadow-sm); }
.leader-quals-text { color: var(--color-teal); font-weight: 600; font-size: 1.0625rem; margin-bottom: 1rem; }
.highlight-chips { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.highlight-chip { display: flex; align-items: center; gap: .5rem; padding: .75rem; background: rgba(8,145,178,.05); border-radius: .75rem; font-size: .875rem; font-weight: 500; color: var(--color-ink); }
.highlight-chip-icon { width: 2rem; height: 2rem; border-radius: .5rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: .875rem; }
.specialty-dots { display: flex; flex-direction: column; gap: 1rem; }
.specialty-dot-item { display: flex; align-items: center; gap: .75rem; font-weight: 500; }
.specialty-dot-item::before { content: ''; width: .75rem; height: .75rem; background: var(--color-teal); border-radius: 50%; flex-shrink: 0; }
@media (max-width: 900px) {
  .leader-new-inner { grid-template-columns: 1fr; }
  .leader-new-left { border-right: none; border-bottom: 1px solid rgba(8,145,178,.08); }
  .leader-avatar { width: 8rem; height: 8rem; font-size: 2rem; }
  .highlight-chips { grid-template-columns: 1fr; }
}

/* ─── Team circular cards ───────────────────────────── */
.team-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
@media (max-width: 1024px) { .team-grid-4 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px)  { .team-grid-4 { grid-template-columns: repeat(2, 1fr); } }
.team-card-new { text-align: center; padding: 1.5rem 1rem; border-radius: var(--radius); transition: box-shadow .2s, transform .2s; }
.team-card-new:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.team-avatar-circle {
  width: 6rem;
  height: 6rem;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 1rem;
  background: linear-gradient(135deg, var(--color-teal), #a855f7);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 700;
  color: #fff;
  font-family: var(--font-heading);
  box-shadow: 0 8px 16px rgba(8,145,178,.2);
  position: relative;
}
.team-avatar-circle img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top; }
.team-card-new h4 { font-size: 1rem; font-weight: 700; color: var(--color-ink); margin-bottom: .25rem; }
.team-card-new .role { font-size: .875rem; color: var(--color-muted); margin-bottom: .75rem; }
.team-hidden { display: none; }

/* ─── Service icon cards ────────────────────────────── */
.service-icon-card { padding: 1.5rem; border-radius: var(--radius); border: 1px solid var(--color-border); background: #fff; transition: all .25s; height: 100%; }
.service-icon-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); border-color: rgba(8,145,178,.2); }
.service-icon-card.featured-teal { background: linear-gradient(135deg, var(--color-teal), var(--color-teal-dark)); border: none; color: #fff; }
.service-icon-card.featured-lav  { background: linear-gradient(135deg, #a855f7, var(--color-coral)); border: none; color: #fff; }
.service-icon-card.featured-teal h3, .service-icon-card.featured-teal p { color: #fff; }
.service-icon-card.featured-lav  h3, .service-icon-card.featured-lav  p { color: #fff; }
.svc-icon-wrap { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1.5rem; }
.svc-icon { width: 3rem; height: 3rem; border-radius: .875rem; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; }
.svc-icon-soft { background: var(--color-teal-soft); color: var(--color-teal); }
.svc-icon-white { background: rgba(255,255,255,.2); }
.svc-badges { display: flex; flex-direction: column; align-items: flex-end; gap: .375rem; }
.svc-stat-row { display: flex; justify-content: space-between; align-items: center; font-size: .875rem; padding: .375rem 0; border-top: 1px solid rgba(0,0,0,.06); margin-top: .5rem; }
.svc-stat-label { color: var(--color-muted); }
.svc-stat-label-light { color: rgba(255,255,255,.8); }
.svc-stat-value { font-weight: 600; }
.svc-stat-value-light { font-weight: 600; color: #fff; }
.svc-card-link { display: inline-flex; align-items: center; gap: .375rem; margin-top: 1rem; font-size: .875rem; font-weight: 600; color: var(--color-teal); }
.svc-card-link-white { color: rgba(255,255,255,.9); }
.service-icon-card a { text-decoration: none; }

/* ─── Carousel (stories) ────────────────────────────── */
.stories-section { padding-block: 5rem; }
.stories-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem 5rem; align-items: start; }
@media (max-width: 900px) { .stories-grid { grid-template-columns: 1fr; } }
.carousel-outer { position: relative; overflow: hidden; border-radius: var(--radius); }
.carousel-track { display: flex; transition: transform .5s ease; }
.carousel-slide { min-width: 100%; }
.carousel-controls { display: flex; align-items: center; justify-content: space-between; margin-top: 1.5rem; }
.carousel-btn {
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 50%;
  background: var(--color-teal-soft);
  color: var(--color-teal);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, color .2s;
  font-size: 1.25rem;
}
.carousel-btn:hover { background: var(--color-teal); color: #fff; }
.carousel-dots { display: flex; gap: .5rem; }
.carousel-dot {
  width: .75rem;
  height: .75rem;
  border-radius: 50%;
  background: var(--color-teal-soft);
  border: none;
  cursor: pointer;
  transition: background .2s;
}
.carousel-dot.active { background: var(--color-teal); }
.story-card-inner { background: linear-gradient(135deg, rgba(8,145,178,.04), rgba(8,145,178,.01)); border: 1px solid rgba(8,145,178,.1); border-radius: var(--radius); padding: 2rem; }
.story-quote-icon { width: 2.5rem; height: 2.5rem; background: rgba(249,115,22,.1); color: var(--color-coral); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 1.25rem; }
.story-patient-row { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1.5rem; }
.story-patient-info h3 { font-weight: 700; font-size: 1.125rem; color: var(--color-ink); margin-bottom: .25rem; }
.story-patient-meta { font-size: .875rem; color: var(--color-muted); }
.story-quote-text { font-size: 1.0625rem; font-style: italic; font-weight: 500; color: var(--color-ink); margin-bottom: 1.5rem; line-height: 1.7; }
.story-journey h4 { font-weight: 600; font-size: .875rem; margin-bottom: .25rem; }
.story-journey p { font-size: .875rem; color: var(--color-muted); margin-bottom: 1rem; }
.story-badges { display: flex; align-items: center; justify-content: space-between; }
.stories-right h3 { font-size: 1.875rem; font-weight: 700; color: var(--color-ink); margin-bottom: 1rem; font-family: var(--font-heading); }
.stories-right p { font-size: 1.0625rem; color: var(--color-muted); line-height: 1.7; margin-bottom: 2rem; }
.stories-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 2rem; }
.stories-stat { text-align: center; padding: 1.5rem 1rem; border-radius: 1rem; }
.stories-stat.teal { background: linear-gradient(135deg, var(--color-teal-soft), #fff); }
.stories-stat.coral { background: linear-gradient(135deg, rgba(249,115,22,.08), #fff); }
.stories-stat .num { font-size: 1.875rem; font-weight: 700; display: block; margin-bottom: .25rem; }
.stories-stat.teal .num { color: var(--color-teal); }
.stories-stat.coral .num { color: var(--color-coral); }
.stories-stat .lbl { font-size: .875rem; color: var(--color-muted); }
.stories-cta { display: flex; gap: 1rem; flex-wrap: wrap; }

/* ─── Blog featured section ─────────────────────────── */
.blog-featured-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-bottom: 3rem; }
@media (max-width: 768px) { .blog-featured-grid { grid-template-columns: 1fr; } }
.blog-feat-img { margin: -1.5rem -1.5rem 1.5rem; overflow: hidden; border-radius: var(--radius) var(--radius) 0 0; }
.blog-feat-img img { width: 100%; height: 14rem; object-fit: cover; }
.blog-feat-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.5rem; }

/* ─── Contact info cards ────────────────────────────── */
.contact-info-card { margin-bottom: 1rem; }
.contact-info-icon { width: 3rem; height: 3rem; border-radius: 1rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 1.25rem; }
.contact-info-icon.teal { background: var(--color-teal-soft); color: var(--color-teal); }
.contact-info-icon.coral { background: rgba(249,115,22,.1); color: var(--color-coral); }
.contact-info-icon.lav { background: rgba(168,85,247,.1); color: #a855f7; }
.contact-info-icon.ink { background: rgba(15,23,42,.08); color: var(--color-ink); }
.contact-info-row { display: flex; align-items: flex-start; gap: 1rem; }
.contact-info-row h3 { font-weight: 700; font-size: .9375rem; color: var(--color-ink); margin-bottom: .5rem; }
.contact-hours-row { display: flex; justify-content: space-between; font-size: .875rem; color: var(--color-muted); padding: .375rem 0; }
.contact-phone-row { display: flex; justify-content: space-between; align-items: center; font-size: .9rem; padding: .375rem 0; color: var(--color-muted); }
.contact-phone-row a { font-weight: 500; }
.contact-appointment-card { background: linear-gradient(135deg, var(--color-coral), #ea6a0a); color: #fff; border-radius: var(--radius); padding: 1.5rem; margin-top: 1rem; }
.contact-appointment-card h3 { color: #fff; font-size: 1.125rem; margin-bottom: .5rem; }
.contact-appointment-card p { color: rgba(255,255,255,.9); font-size: .875rem; margin-bottom: 1rem; }
.contact-layout-new { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 900px) { .contact-layout-new { grid-template-columns: 1fr; } }

/* ─── Foundation outreach ───────────────────────────── */
.outreach-icon { width: 4rem; height: 4rem; border-radius: 1rem; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem; font-size: 1.5rem; }
.outreach-icon.teal { background: var(--color-teal-soft); color: var(--color-teal); }
.outreach-icon.coral { background: rgba(249,115,22,.1); color: var(--color-coral); }
.outreach-icon.lav { background: rgba(168,85,247,.1); color: #a855f7; }
.outreach-card { text-align: center; padding: 2rem; }
.impact-row { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 1.5rem; align-items: start; padding: 2rem; }
@media (max-width: 768px) { .impact-row { grid-template-columns: 1fr 1fr; } }
.impact-row-location h3 { font-weight: 700; font-size: 1.0625rem; margin-bottom: .5rem; }
.impact-row-beneficiaries .num { font-size: 1.5rem; font-weight: 700; color: var(--color-coral); }
.impact-row-beneficiaries .lbl { font-size: .8125rem; color: var(--color-muted); }
.impact-row-detail h4 { font-size: .875rem; font-weight: 600; margin-bottom: .375rem; }
.impact-row-detail p { font-size: .875rem; color: var(--color-muted); }
.foundation-principles { display: flex; flex-direction: column; gap: 1rem; }
.principle-item { display: flex; align-items: flex-start; gap: .875rem; }
.principle-num { width: 1.5rem; height: 1.5rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 700; color: #fff; flex-shrink: 0; margin-top: .125rem; }
.principle-num.teal  { background: var(--color-teal); }
.principle-num.coral { background: var(--color-coral); }
.principle-num.lav   { background: #a855f7; }
.principle-item h4 { font-weight: 600; font-size: .9375rem; margin-bottom: .125rem; }
.principle-item p  { font-size: .875rem; color: var(--color-muted); }

/* ─── Media stats / tabs ────────────────────────────── */
.media-stats-bar { background: #fff; padding-block: 2rem; border-bottom: 1px solid var(--color-border); }

/* ─── Responsive hero ───────────────────────────────── */
@media (max-width: 1024px) {
  .hero-inner { grid-template-columns: 1fr; gap: 3rem; }
  .hero-impact-card { max-width: 28rem; margin-inline: auto; }
}
@media (max-width: 640px) {
  .hero-pills { gap: .5rem; }
  .hero-pill { font-size: .8125rem; padding: .375rem .875rem; }
  .hero-status { gap: 1rem; }
  .hero-impact-grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
}
