.vp-page-health-span-programs {
  --hsp-white: #fcfeff;
  --hsp-cream: #fffdfa;
  --hsp-soft: #f0f6ff;
  --hsp-navy-950: #050e1a;
  --hsp-navy-900: #020b17;
  --hsp-navy-800: #051730;
  --hsp-navy-700: #08234a;
  --hsp-navy-600: #0d3c7e;
  --hsp-grey: #3e4651;
  --hsp-grey-800: #222830;
  --hsp-beige-600: #ac753a;
  --hsp-beige-400: #bf8f5c;
  --hsp-beige-300: #c89d6f;
  --hsp-beige-100: #dabb9a;
  --hsp-border: rgba(193, 200, 212, 0.3);
  background: var(--hsp-white);
}

.vp-page-health-span-programs .vp-container {
  width: min(100%, 1440px);
  padding-right: 60px;
  padding-left: 60px;
}

.vp-page-health-span-programs .vp-section {
  padding-top: 84px;
  padding-bottom: 84px;
}

.vp-page-health-span-programs .vp-eyebrow {
  margin: 0;
  color: var(--hsp-beige-600);
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.5;
  text-transform: uppercase;
}

.vp-page-health-span-programs h1,
.vp-page-health-span-programs h2,
.vp-page-health-span-programs h3 {
  letter-spacing: 0;
}

.vp-page-health-span-programs .vp-lede {
  width: min(100%, 800px);
  max-width: none;
  margin: 0 auto;
  color: var(--hsp-grey);
  font-size: 24px;
  line-height: 1.5;
}

.hsp-hero {
  min-height: 700px;
  align-items: center;
  overflow: hidden;
}

.hsp-hero .vp-container {
  padding-right: 80px;
  padding-left: 80px;
}

.hsp-hero .vp-hero-media img {
  object-position: center 38%;
}

.hsp-hero::after {
  z-index: -1;
  background: linear-gradient(90deg, rgba(5, 23, 48, 0.7) 0%, rgba(5, 23, 48, 0.7) 41%, rgba(5, 23, 48, 0) 100%);
}

.hsp-hero .vp-container {
  padding-top: 0;
  padding-bottom: 0;
}

.hsp-hero-copy {
  max-width: 897px;
}

.hsp-hero h1 {
  max-width: 897px;
  color: var(--hsp-cream);
  font-size: 100px;
  line-height: 1.15;
}

.hsp-hero .vp-lede {
  width: 748px;
  margin: 24px 0 0;
  color: var(--hsp-cream);
  font-size: 24px;
}

.hsp-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  margin-top: 56px;
}

.vp-page-health-span-programs .hsp-button {
  min-width: 200px;
  min-height: 63px;
  gap: 16px;
  border: 0;
  padding: 16px 32px;
  color: var(--hsp-white);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1;
  text-transform: uppercase;
}

.vp-page-health-span-programs .hsp-button img {
  width: 24px;
  height: 14px;
  flex: 0 0 auto;
}

.vp-page-health-span-programs .hsp-button-gold {
  background: var(--hsp-beige-600);
}

.vp-page-health-span-programs .hsp-button-gold:hover,
.vp-page-health-span-programs .hsp-button-gold:focus-visible {
  background: #915f2d;
}

.hsp-split {
  display: grid;
  grid-template-columns: minmax(0, 682px) minmax(0, 574px);
  gap: 64px;
  align-items: stretch;
}

.hsp-copy {
  display: flex;
  min-width: 0;
  flex-direction: column;
  gap: 24px;
}

.hsp-copy h2 {
  color: var(--hsp-navy-700);
  font-size: 68px;
  line-height: 1.2;
}

.hsp-body {
  display: grid;
  gap: 16px;
}

.hsp-body p,
.hsp-body li {
  color: var(--hsp-navy-950);
  font-size: 24px;
  line-height: 1.5;
}

.hsp-body strong {
  color: var(--hsp-grey);
  font-weight: 600;
}

.hsp-body ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 36px;
}

.hsp-media {
  position: relative;
  min-height: 714px;
  overflow: hidden;
  border-radius: 12px;
  background: #dce8f4;
}

.hsp-media-tall {
  min-height: 834px;
}

.hsp-media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hsp-section-head {
  display: flex;
  max-width: 928px;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  margin: 0 auto 64px;
  text-align: center;
}

.hsp-section-head h2 {
  color: var(--hsp-navy-700);
  font-size: 84px;
  line-height: 1.2;
}

.hsp-science {
  background: var(--hsp-navy-800);
}

.hsp-science .vp-eyebrow {
  color: #d1ac84;
}

.hsp-science .hsp-section-head h2,
.hsp-science .hsp-section-head .vp-lede {
  color: var(--hsp-white);
}

.hsp-science .hsp-section-head .vp-lede {
  width: min(100%, 902px);
}

.hsp-science-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

.hsp-science-card {
  display: flex;
  min-height: 268px;
  flex-direction: column;
  justify-content: space-between;
  border-radius: 8px;
  background: rgba(252, 254, 255, 0.1);
  padding: 40px 32px;
}

.hsp-number {
  display: block;
  color: #d1ac84;
  font-size: 24px;
  font-weight: 600;
  line-height: 1.5;
}

.hsp-science-card h3 {
  color: var(--hsp-white);
  font-size: 32px;
  line-height: 1.2;
}

.hsp-science-note {
  width: min(100%, 902px);
  margin: 42px auto 0;
  color: var(--hsp-white);
  font-size: 24px;
  font-style: italic;
  line-height: 1.5;
  text-align: center;
}

.hsp-program-intro .hsp-section-head {
  margin-bottom: 0;
}

.hsp-program-intro .hsp-section-head h2 {
  white-space: nowrap;
}

.hsp-program-intro .hsp-section-head .vp-lede {
  width: min(100%, 852px);
}

.hsp-program-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  width: 100%;
}

.hsp-program-card {
  display: flex;
  min-height: 670px;
  flex-direction: column;
  justify-content: space-between;
  padding: 40px 32px;
  color: #fff;
  text-decoration: none;
}

.hsp-program-card-dark {
  background: var(--hsp-navy-700);
}

.hsp-program-card-deep {
  background: var(--hsp-navy-900);
}

.hsp-program-card-featured {
  background: var(--hsp-beige-300);
  justify-content: flex-start;
  gap: 40px;
}

.hsp-program-icon {
  width: 38px;
  height: 38px;
}

.hsp-program-card-bottom,
.hsp-program-details {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.hsp-program-title,
.hsp-program-details h3 {
  color: #fff;
  font-family: var(--vp-display);
  font-size: 48px;
  font-weight: 400;
  line-height: 1.2;
}

.hsp-program-arrow {
  display: inline-flex;
  width: 52px;
  height: 52px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
}

.hsp-program-arrow img {
  width: 28px;
  height: 28px;
}

.hsp-program-details {
  gap: 16px;
}

.hsp-program-card-featured .hsp-program-details h3 {
  margin-top: 48px;
}

.hsp-program-details p {
  margin-top: 0;
  color: #fff;
  font-size: 20px;
  line-height: 1.5;
}

.hsp-program-subtitle {
  margin-top: 0;
}

.hsp-program-button {
  display: inline-flex;
  min-height: 54px;
  width: 100%;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
  border-radius: 8px;
  background: var(--hsp-cream);
  color: var(--hsp-navy-950);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0;
  text-decoration: none;
  text-transform: uppercase;
}

.hsp-values {
  background: var(--hsp-soft);
}

.hsp-values .hsp-section-head .vp-lede {
  width: min(100%, 800px);
}

.hsp-value-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 32px;
}

.hsp-value-card {
  display: flex;
  min-height: 328px;
  flex-direction: column;
  gap: 32px;
  border: 1px solid var(--hsp-border);
  border-radius: 8px;
  background: var(--hsp-white);
  padding: 40px 32px;
}

.hsp-value-card h3 {
  color: var(--hsp-navy-700);
  font-size: 42px;
  line-height: 1.2;
}

.hsp-value-card p {
  color: var(--hsp-grey-800);
  font-size: 16px;
  line-height: 1.5;
}

.hsp-fit .hsp-section-head {
  margin-bottom: 64px;
}

.hsp-fit-list {
  display: grid;
  width: min(100%, 820px);
  gap: 16px;
  margin: 0 auto;
}

.hsp-fit-item {
  display: flex;
  min-height: 96px;
  align-items: center;
  gap: 20px;
  border: 1px solid var(--hsp-border);
  border-radius: 8px;
  background: var(--hsp-white);
  box-shadow: 0 12px 12px rgba(0, 0, 0, 0.05);
  padding: 32px;
}

.hsp-fit-item-tall {
  min-height: 124px;
  align-items: flex-start;
}

.hsp-fit-item img {
  width: 32px;
  height: 32px;
  flex: 0 0 auto;
}

.hsp-fit-item p {
  color: var(--hsp-navy-700);
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
  text-transform: uppercase;
}

.hsp-midlife-band {
  display: grid;
  min-height: 600px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hsp-midlife-copy {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--hsp-navy-800);
  padding: 84px 60px;
}

.hsp-midlife-copy > div {
  width: min(100%, 600px);
}

.hsp-midlife-copy h2 {
  color: var(--hsp-white);
  font-size: 56px;
  line-height: 1.2;
}

.hsp-midlife-body {
  display: grid;
  gap: 8px;
  margin-top: 16px;
}

.hsp-midlife-body p {
  color: var(--hsp-soft);
  font-size: 16px;
  line-height: 1.5;
}

.hsp-midlife-media {
  position: relative;
  min-height: 600px;
  overflow: hidden;
}

.hsp-midlife-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(5, 23, 48, 0.4);
}

.hsp-midlife-media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hsp-next .hsp-section-head {
  margin-bottom: 64px;
}

.hsp-step-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 32px;
}

.hsp-step-card {
  min-height: 228px;
  border-radius: 8px;
  background: var(--hsp-white);
  padding: 40px 32px;
}

.hsp-step-card h3 {
  color: var(--hsp-navy-700);
  font-size: 42px;
  line-height: 1.2;
}

.hsp-step-card h3 span {
  font-size: 0.68em;
  font-weight: 400;
  margin-left: 0.12em;
}

.hsp-step-card p {
  margin-top: 8px;
  color: var(--hsp-grey-800);
  font-size: 20px;
  line-height: 1.5;
}

.hsp-next-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  margin-top: 44px;
}

.hsp-next-actions .hsp-button {
  width: min(100%, 640px);
}

.hsp-text-link {
  color: var(--hsp-beige-400);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 31px;
  text-transform: uppercase;
}

.hsp-compliance {
  padding: 64px 60px;
  background: var(--hsp-white);
}

.hsp-compliance h2 {
  color: var(--hsp-navy-700);
  font-size: 44px;
  line-height: 1.2;
}

.hsp-compliance p {
  width: min(100%, 892px);
  margin-top: 16px;
  color: var(--hsp-navy-950);
  font-size: 24px;
  line-height: 1.5;
}

@media (max-width: 1180px) {
  .vp-page-health-span-programs .vp-container,
  .hsp-hero .vp-container {
    padding-right: 32px;
    padding-left: 32px;
  }

  .hsp-hero h1 {
    font-size: 72px;
  }

  .hsp-hero .vp-lede {
    width: min(100%, 748px);
  }

  .hsp-split {
    grid-template-columns: 1fr;
  }

  .hsp-media,
  .hsp-media-tall {
    min-height: 520px;
  }

  .hsp-section-head h2 {
    font-size: 64px;
  }

  .hsp-copy h2 {
    font-size: 58px;
  }

  .hsp-science-grid,
  .hsp-value-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hsp-program-strip {
    grid-template-columns: 1fr;
  }

  .hsp-program-card {
    min-height: 420px;
  }
}

@media (max-width: 760px) {
  .vp-page-health-span-programs .vp-container,
  .hsp-hero .vp-container {
    padding-right: 20px;
    padding-left: 20px;
  }

  .vp-page-health-span-programs .vp-section {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .vp-page-health-span-programs .vp-eyebrow {
    font-size: 16px;
  }

  .hsp-hero {
    min-height: 620px;
  }

  .hsp-hero::after {
    background: linear-gradient(180deg, rgba(5, 23, 48, 0.24) 0%, rgba(5, 23, 48, 0.88) 100%);
    backdrop-filter: none;
  }

  .hsp-hero h1 {
    font-size: 48px;
  }

  .hsp-hero .vp-lede,
  .vp-page-health-span-programs .vp-lede,
  .hsp-body p,
  .hsp-body li,
  .hsp-science-note,
  .hsp-compliance p {
    font-size: 18px;
  }

  .hsp-action-row {
    gap: 16px;
    margin-top: 36px;
  }

  .vp-page-health-span-programs .hsp-button {
    width: 100%;
    min-height: 56px;
    padding: 14px 20px;
    font-size: 15px;
  }

  .hsp-split {
    gap: 40px;
  }

  .hsp-copy h2,
  .hsp-section-head h2,
  .hsp-midlife-copy h2 {
    font-size: 42px;
  }

  .hsp-media,
  .hsp-media-tall,
  .hsp-midlife-media {
    min-height: 340px;
  }

  .hsp-science-grid,
  .hsp-value-grid,
  .hsp-step-grid,
  .hsp-midlife-band {
    grid-template-columns: 1fr;
  }

  .hsp-science-card,
  .hsp-value-card,
  .hsp-step-card {
    min-height: 0;
  }

  .hsp-program-card {
    min-height: 360px;
  }

  .hsp-program-title,
  .hsp-program-details h3 {
    font-size: 40px;
  }

  .hsp-program-details p,
  .hsp-step-card p {
    font-size: 18px;
  }

  .hsp-fit-item,
  .hsp-fit-item-tall {
    min-height: 0;
    align-items: flex-start;
    padding: 24px;
  }

  .hsp-fit-item p {
    font-size: 16px;
  }

  .hsp-midlife-copy {
    padding: 64px 20px;
  }

  .hsp-compliance {
    padding: 56px 20px;
  }
}

/* QA pass: Figma uppercase section labels. */
.vp-page-health-span-programs .vp-eyebrow {
  font-weight: 600;
  letter-spacing: 3px;
}

.vp-page-health-span-programs .hsp-science-note {
  margin: 24px auto 0 !important;
  text-align: center !important;
}

.vp-page-health-span-programs .hsp-step-card h3 span {
  font-size: 1em !important;
  font-weight: 400;
  margin-left: 0.12em;
}

@media (max-width: 760px) {
  .vp-page-health-span-programs .hsp-program-intro .hsp-section-head h2 {
    max-width: calc(100vw - 40px);
    font-size: clamp(36px, 10vw, 42px);
    line-height: 1.14;
    white-space: normal;
    text-wrap: balance;
  }
}
