/* ── Hero ── */
.hero {
  background: var(--ink);
  position: relative;
  padding: var(--sp-24) 0;
  overflow: hidden;
  border-radius: 0 0 28px 28px;
}
.hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(13,26,14,.92) 0%, rgba(13,26,14,.86) 45%, rgba(13,26,14,.55) 100%);
  pointer-events: none;
  z-index: 1;
}
.hero__inner { position: relative; z-index: 2; max-width: 760px; }
.hero__eyebrow {
  font-family: var(--font-head);
  font-weight: 700;
  font-size: var(--text-xs);
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: var(--sp-5);
  display: block;
}
.hero__h1 {
  font-family: var(--font-display);
  font-size: var(--text-hero);
  color: var(--white);
  line-height: .95;
  margin-bottom: 0;
  letter-spacing: .02em;
}
.hero__h1 span { color: var(--gold); display: block; }
.hero__rule { margin: var(--sp-8) 0; }
.hero__sub {
  font-size: var(--text-md);
  color: rgba(255,255,255,.8);
  line-height: 1.65;
  margin-bottom: var(--sp-10);
  max-width: 620px;
}
.hero__ctas {
  display: flex;
  gap: var(--sp-5);
  flex-wrap: wrap;
}

/* ── RPM Strip ── */
.rpm-strip {
  background: var(--gold);
  padding: var(--sp-8) 0;
}
.rpm-strip__inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-8);
}
.rpm-item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-5);
}
.rpm-item__icon {
  width: 44px; height: 44px;
  background: rgba(13,26,14,.15);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rpm-item__icon svg { color: var(--ink); width: 22px; height: 22px; }
.rpm-item__word {
  font-family: var(--font-display);
  font-size: 26px;
  color: var(--ink);
  letter-spacing: .06em;
  line-height: 1;
  margin-bottom: var(--sp-2);
}
.rpm-item__desc {
  font-family: var(--font-head);
  font-weight: 700;
  font-size: var(--text-xs);
  color: rgba(13,26,14,.72);
  text-transform: uppercase;
  letter-spacing: .04em;
  line-height: 1.4;
}

/* ── Intro / Mission ── */
.intro-section { background: var(--cream); }
.intro__photo {
  height: 440px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.intro__link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-head);
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--gold);
  margin-top: var(--sp-8);
  transition: gap var(--ease), color var(--ease);
}
.intro__link:hover { gap: var(--sp-5); color: var(--gold-md); }

/* ── Services Grid ── */
.services-section { background: var(--warm); }
.services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-8);
}

/* ── Education Section ── */
.education-section { background: var(--ink); border-radius: 24px; margin: 0 16px; overflow: hidden; }
.education-section h2 { color: var(--white); }
.education__sub {
  color: rgba(255,255,255,.72);
  font-size: var(--text-md);
  margin-bottom: var(--sp-8);
  line-height: 1.65;
}
.education__photo {
  height: 100%;
  min-height: 380px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* ── Who We Serve ── */
.audience-section { background: var(--warm); }
.audience-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-8);
}
.audience-grid--5 {
  grid-template-columns: repeat(3, 1fr);
}
.audience-grid--5 .audience-card:nth-child(4),
.audience-grid--5 .audience-card:nth-child(5) {
  grid-column: auto;
}
/* Center the bottom row of 2 in a 3-col grid */
@media (min-width: 769px) {
  .audience-grid--5 {
    grid-template-columns: repeat(6, 1fr);
  }
  .audience-grid--5 .audience-card {
    grid-column: span 2;
  }
  .audience-grid--5 .audience-card:nth-child(4) {
    grid-column: 2 / span 2;
  }
  .audience-grid--5 .audience-card:nth-child(5) {
    grid-column: 4 / span 2;
  }
}

/* ── Programs Section ── */
.programs-section { background: var(--green); border-radius: 24px; margin: 0 16px; overflow: hidden; }

/* ── Gallery Section ── */
.gallery-section { background: var(--ink); border-radius: 24px; margin: 0 16px; overflow: hidden; }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-6);
}

/* ── Before / After Slider ── */
.ba-slider-hero {
  position: relative;
  height: 440px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: ew-resize;
  user-select: none;
  margin-bottom: var(--sp-10);
  touch-action: none;
}
.ba-slider-hero__before,
.ba-slider-hero__after {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.ba-slider-hero__after  { clip-path: inset(0 50% 0 0); transition: none; }
.ba-slider-hero__handle {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  width: 3px;
  background: var(--white);
  transform: translateX(-50%);
  pointer-events: none;
  box-shadow: 0 0 8px rgba(0,0,0,.4);
}
.ba-slider-hero__knob {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 46px; height: 46px;
  background: var(--white);
  border-radius: 50%;
  box-shadow: 0 2px 16px rgba(0,0,0,.35);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink);
}
.ba-slider-hero__lbl {
  position: absolute;
  bottom: var(--sp-5);
  font-family: var(--font-head);
  font-weight: 700;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: .1em;
  background: rgba(13,26,14,.75);
  color: var(--white);
  padding: var(--sp-2) var(--sp-4);
  border-radius: 100px;
  pointer-events: none;
}
.ba-slider-hero__lbl--before { left: var(--sp-5); }
.ba-slider-hero__lbl--after  { right: var(--sp-5); }
.ba-slider-hero__hint {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--font-head);
  font-weight: 600;
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  background: rgba(0,0,0,.35);
  padding: var(--sp-3) var(--sp-6);
  border-radius: 100px;
  pointer-events: none;
  margin-top: 38px;
  opacity: 1;
  transition: opacity .3s;
}
.ba-slider-hero.dragging .ba-slider-hero__hint { opacity: 0; }
@media (max-width: 768px) {
  .ba-slider-hero { height: 280px; }
}

/* ── Reviews Section ── */
.reviews-section { background: var(--warm); }
.reviews-header-ctas {
  display: flex;
  gap: var(--sp-5);
  justify-content: center;
  margin-top: var(--sp-8);
  flex-wrap: wrap;
}

/* ── Process Section ── */
.process-section { background: var(--white); }
.process-hero-line {
  text-align: center;
  margin-top: var(--sp-12);
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  color: var(--green);
  letter-spacing: .04em;
}

/* ── Service Areas ── */
.areas-section { background: var(--cream); }
.areas__photo {
  height: 480px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* ── Quote Form ── */
.quote-section { background: var(--warm); }
.quote-trust h3 {
  font-family: var(--font-display);
  font-size: 28px;
  color: var(--ink);
  letter-spacing: .04em;
  margin-bottom: var(--sp-8);
}

/* ── FAQ ── */
.faq-section { background: var(--white); }

@media (max-width: 768px) {
  .hero { padding: var(--sp-16) 0; border-radius: 0 0 16px 16px; }
  .rpm-strip__inner { grid-template-columns: 1fr; gap: var(--sp-6); }
  .services-grid { grid-template-columns: 1fr; }
  .audience-grid, .audience-grid--5 { grid-template-columns: 1fr; }
  .audience-grid--5 .audience-card,
  .audience-grid--5 .audience-card:nth-child(4),
  .audience-grid--5 .audience-card:nth-child(5) { grid-column: auto; }
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .intro__photo { height: 260px; }
  .areas__photo { height: 280px; }
  .education__photo { min-height: 240px; }
  .education-section,
  .programs-section,
  .gallery-section { margin: 0 8px; border-radius: 16px; }
}

@media (max-width: 480px) {
  .gallery-grid { grid-template-columns: 1fr; }
}
