/* Final public-page consistency layer. Loaded after page-specific CSS. */

.ch-hero,
.programs-hero,
.blog-hero {
  background: var(--color-surface-warm);
  min-height: 72vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 160px var(--section-padding-x) 100px;
  position: relative;
  overflow: hidden;
}

.ch-hero__badge,
.programs-hero__badge,
.blog-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 36px;
  font-family: var(--font-body);
  font-size: var(--text-label-size);
  font-weight: 500;
  letter-spacing: var(--text-label-spacing);
  text-transform: uppercase;
  color: var(--color-text-muted-warm);
  position: relative;
  z-index: 1;
}

.ch-hero__badge-icon,
.programs-hero__badge svg,
.blog-hero__badge svg {
  width: 16px;
  height: 16px;
  opacity: 0.7;
}

.ch-hero__title,
.programs-hero__title,
.blog-hero__title {
  font-family: var(--font-heading);
  font-size: var(--text-page-title-size);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.01em;
  color: var(--color-ink);
  margin: 0 0 28px;
  position: relative;
  z-index: 1;
}

.ch-hero__title {
  margin-bottom: 0;
}

.programs-hero__sub,
.blog-hero__sub {
  font-family: var(--font-body);
  font-size: var(--text-page-body-size);
  font-weight: 400;
  line-height: var(--text-page-body-height);
  letter-spacing: 0.02em;
  color: var(--color-text-soft);
  margin: 0;
  max-width: 680px;
  position: relative;
  z-index: 1;
}

main .section-heading,
main .ab-heading,
.booking-info-title,
.ono-header__title,
.decision-title,
.decision-card__title,
.decision-step__number,
.decision-step__title,
.group-section-title,
.article-title,
.related-title,
.section-title {
  font-family: var(--font-heading) !important;
  font-weight: 400 !important;
  color: var(--color-ink);
}

main .space-paragraph,
main .ab-text,
main .ab-lead,
.booking-info-text,
.booking-info-list li,
.blog-card__excerpt,
.team-card__body,
.ono-card__body,
.decision-intro,
.decision-list li,
.decision-step__body,
.group-card__desc,
.ch-what__text,
.ch-benefit-card__desc,
.ch-data-point__desc,
.ch-for__item {
  font-family: var(--font-body) !important;
  font-size: var(--text-page-body-size) !important;
  font-weight: 400 !important;
  line-height: var(--text-page-body-height) !important;
}

.blog-card,
.ono-card,
.decision-card,
.decision-step,
.group-card,
.ch-benefit-card,
.booking-left {
  background: var(--color-surface);
  border-color: var(--color-border-soft);
  transition:
    transform var(--motion-duration-fast) ease,
    box-shadow var(--motion-duration-fast) ease,
    background var(--motion-duration-fast) ease;
}

.blog-card:hover,
.ono-card:hover,
.decision-card:hover,
.decision-step:hover,
.group-card:hover,
.ch-benefit-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

/* Keep the Programs Teams block on its original dark treatment. */
.prog-section--dark .teams-title {
  color: var(--color-surface) !important;
}

.prog-section--dark .team-card {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  box-shadow: none !important;
  color: var(--color-surface);
}

.prog-section--dark .team-card:hover {
  background: rgba(255, 255, 255, 0.05) !important;
  box-shadow: none !important;
  transform: translateY(-3px);
}

.prog-section--dark .team-card__number {
  color: rgba(255, 255, 255, 0.15) !important;
}

.prog-section--dark .team-card__title {
  color: var(--color-surface) !important;
}

.prog-section--dark .team-card__body {
  color: rgba(255, 255, 255, 0.82) !important;
}

.prog-section--dark .team-card__list li {
  color: rgba(255, 255, 255, 0.7) !important;
  border-bottom-color: rgba(255, 255, 255, 0.1) !important;
}

.prog-section--dark .team-card__list li::before {
  background: rgba(255, 255, 255, 0.4) !important;
}

.prog-reveal,
.ch-reveal {
  opacity: 0;
  transform: translateY(36px);
  transition:
    opacity var(--motion-duration-reveal) var(--motion-ease-out),
    transform var(--motion-duration-reveal) var(--motion-ease-out);
}

.prog-reveal.is-visible,
.ch-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.prog-reveal--delay-1,
.ch-reveal--delay-1 {
  transition-delay: var(--motion-delay-1);
}

.prog-reveal--delay-2,
.ch-reveal--delay-2 {
  transition-delay: var(--motion-delay-2);
}

.ch-reveal--delay-3 {
  transition-delay: var(--motion-delay-3);
}

.ch-reveal--delay-4 {
  transition-delay: var(--motion-delay-4);
}

@media (max-width: 900px) {
  .ch-hero,
  .programs-hero,
  .blog-hero {
    min-height: 60vh;
    padding: 140px var(--section-padding-x) 80px;
  }
}

@media (max-width: 600px) {
  .ch-hero,
  .programs-hero,
  .blog-hero {
    min-height: 50vh;
    padding: 120px 24px 64px;
  }
}
