.vp-page-patient {
  --vp-soft: #f0f6ff;
}

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

.vp-page-patient .vp-hero {
  min-height: 400px;
  align-items: flex-end;
}

.vp-page-patient .vp-hero .vp-container {
  width: 100%;
  max-width: none;
  padding: 0 80px 64px;
}

.vp-page-patient .vp-hero-media img {
  object-position: center 36%;
}

.vp-page-patient .vp-hero::after {
  background: rgba(0, 0, 0, 0.22);
}

.vp-page-patient .vp-hero .vp-eyebrow {
  margin-bottom: 24px;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 3px;
  line-height: 1.5;
  text-transform: uppercase;
}

.vp-page-patient .vp-hero h1 {
  color: #fff;
  font-size: clamp(58px, 5.6vw, 80px);
  line-height: 1.15;
  letter-spacing: 1px;
}

.vp-patient-assessment {
  padding: 84px 0;
  background: #fcfeff;
}

.vp-patient-assessment .vp-centered {
  width: min(100%, 900px);
  margin-bottom: 68px;
}

.vp-patient-assessment .vp-centered .vp-eyebrow {
  margin-bottom: 20px;
}

.vp-patient-assessment .vp-centered h2 {
  width: min(100%, 640px);
  margin: 0 auto;
  font-size: clamp(56px, 5.8vw, 84px);
  line-height: 1.2;
  letter-spacing: 1px;
}

.vp-patient-assessment .vp-lede {
  max-width: 900px;
  margin-top: 24px;
  color: #5b6470;
  font-size: 24px;
  line-height: 1.5;
}

.vp-assessment-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.vp-assessment-card,
.vp-assessment-media {
  height: 620px;
  min-height: 620px;
  border-radius: 8px;
}

.vp-assessment-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  background: #051730;
  padding: 44px;
}

.vp-assessment-steps {
  display: grid;
  gap: 20px;
  margin: 0 0 48px;
  padding: 0;
  list-style: none;
}

.vp-assessment-steps li {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
  min-height: 100px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.1);
  padding: 20px 24px;
}

.vp-step-number {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: #c69354;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
}

.vp-assessment-steps h3 {
  color: #fff;
  font-family: var(--vp-sans);
  font-size: 24px;
  font-weight: 600;
  line-height: 1.5;
}

.vp-assessment-steps p {
  margin: 4px 0 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 20px;
  line-height: 1.5;
}

.vp-assessment-card .vp-button {
  width: 100%;
  min-height: 58px;
  border-color: #c69354;
  background: #c69354;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 1.44px;
}

.vp-assessment-note {
  margin: 24px 0 0;
  color: rgba(255, 255, 255, 0.76);
  font-size: 14px;
  line-height: 1.5;
  text-align: center;
}

.vp-assessment-media {
  position: relative;
  overflow: hidden;
  background: #051730;
}

.vp-assessment-media img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: center center;
}

.vp-assessment-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5, 23, 48, 0.7) 0%, rgba(5, 23, 48, 0.42) 25.685%, rgba(5, 23, 48, 0) 100%);
  pointer-events: none;
}

.vp-patient-tags {
  position: absolute;
  top: 54px;
  left: 64px;
  right: 64px;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
}

.vp-patient-tags span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.3);
  color: rgba(255, 255, 255, 0.92);
  font-size: 16px;
  font-weight: 600;
  line-height: 1.25;
  padding: 8px 16px;
  white-space: nowrap;
}

.vp-patient-tags img {
  display: block;
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
}

.vp-page-patient .hf-newsletter {
  height: 853px;
  background: var(--vp-soft);
}

.vp-page-patient .hf-newsletter-inner {
  display: grid;
  grid-template-columns: 705px 551px;
  align-items: center;
  gap: 64px;
  width: min(100%, 1440px);
  height: 100%;
  margin: 0 auto;
  padding: 0 60px;
}

.vp-page-patient .hf-eyebrow {
  color: #ac753a;
  font-family: var(--vp-sans);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 4px;
  line-height: 30px;
  text-transform: uppercase;
}

.vp-page-patient .hf-newsletter-copy h2 {
  margin-top: 28px;
  color: #08234a;
  font-family: var(--vp-display);
  font-size: clamp(58px, 5.8vw, 84px);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 1px;
}

.vp-page-patient .hf-newsletter-copy {
  transform: translateY(22px);
}

.vp-page-patient .hf-newsletter-copy p:not(.hf-eyebrow) {
  margin-top: 28px;
  color: #3e4651;
  font-family: var(--vp-sans);
  font-size: 20px;
  line-height: 1.5;
}

.vp-page-patient .hf-newsletter-copy ul {
  display: grid;
  gap: 12px;
  margin-top: 30px;
  padding: 0;
  list-style: none;
}

.vp-page-patient .hf-newsletter-copy li {
  position: relative;
  padding-left: 22px;
  color: #08234a;
  font-family: var(--vp-sans);
  font-size: 20px;
  line-height: 1.5;
}

.vp-page-patient .hf-newsletter-copy li::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #ac753a;
}

.vp-page-patient .hf-newsletter-form {
  display: grid;
  align-content: start;
  gap: 27px;
  width: 551px;
  min-height: 685px;
  border-radius: 12px;
  background: #fff;
  padding: 44px;
}

.vp-page-patient .hf-newsletter-form h3 {
  color: #08234a;
  font-family: var(--vp-display);
  font-size: 44px;
  font-weight: 400;
  line-height: 1.2;
}

.vp-page-patient .hf-newsletter-form label {
  display: grid;
  gap: 8px;
  color: #0e0f0f;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}

.vp-page-patient .hf-newsletter-form input,
.vp-page-patient .hf-newsletter-form select {
  width: 100%;
  height: 56px;
  border: 1px solid #d8dde5;
  border-radius: 8px;
  background: #fff;
  color: #0e0f0f;
  font-family: var(--vp-sans);
  font-size: 16px;
  padding: 0 20px;
}

.vp-page-patient .hf-newsletter-form input::placeholder,
.vp-page-patient .hf-newsletter-form select:invalid {
  color: #8b929b;
}

.vp-page-patient .hf-newsletter-form select {
  appearance: none;
  -webkit-appearance: none;
  padding-right: 54px;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg width='14' height='8' viewBox='0 0 14 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L7 7L13 1' stroke='%238B929B' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 24px center;
  background-size: 14px 8px;
}

.vp-page-patient .hf-newsletter-form select:valid {
  color: #0e0f0f;
}

.vp-page-patient .hf-newsletter-form button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 58px;
  border: 0;
  border-radius: 8px;
  background: #08234a;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 2px;
  line-height: 1;
  text-transform: uppercase;
}

.vp-page-patient .hf-newsletter-form button::after {
  content: "";
  width: 16px;
  height: 16px;
  margin-left: 16px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.vp-page-patient .hf-newsletter-note,
.vp-page-patient .hf-newsletter-status {
  color: #8b929b;
  font-size: 14px;
  line-height: 1.5;
  text-align: center;
}

.vp-page-patient .hf-newsletter-note a {
  color: #ac753a;
}

@media (max-width: 1180px) {
  .vp-assessment-grid,
  .vp-page-patient .hf-newsletter-inner {
    grid-template-columns: 1fr;
  }

  .vp-page-patient .hf-newsletter {
    height: auto;
    padding: 76px 0;
  }

  .vp-page-patient .hf-newsletter-form {
    width: 100%;
  }

  .vp-page-patient .hf-newsletter-copy {
    transform: none;
  }
}

@media (max-width: 700px) {
  .vp-page-patient .vp-container {
    padding-right: 24px;
    padding-left: 24px;
  }

  .vp-page-patient .vp-hero {
    min-height: 340px;
  }

  .vp-page-patient .vp-hero .vp-container {
    padding: 0 32px 48px;
  }

  .vp-page-patient .vp-hero h1 {
    font-size: 52px;
  }

  .vp-patient-assessment {
    padding: 64px 0;
  }

  .vp-patient-assessment .vp-lede {
    font-size: 19px;
  }

  .vp-assessment-card,
  .vp-assessment-media {
    height: auto;
    min-height: 430px;
  }

  .vp-assessment-media img {
    height: 100%;
    min-height: 430px;
  }

  .vp-assessment-card {
    padding: 28px;
  }

  .vp-assessment-steps li {
    grid-template-columns: 28px minmax(0, 1fr);
    min-height: 0;
    padding: 18px;
  }

  .vp-step-number {
    width: 28px;
    height: 28px;
    font-size: 14px;
  }

  .vp-assessment-steps h3 {
    font-size: 18px;
  }

  .vp-assessment-steps p {
    font-size: 15px;
  }

  .vp-patient-tags {
    top: 18px;
    left: 18px;
    right: 18px;
    justify-content: center;
  }

  .vp-patient-tags span {
    font-size: 12px;
  }

  .vp-page-patient .hf-newsletter-inner {
    padding: 0 24px;
  }

  .vp-page-patient .hf-newsletter-copy p:not(.hf-eyebrow),
  .vp-page-patient .hf-newsletter-copy li {
    font-size: 17px;
  }

  .vp-page-patient .hf-newsletter-form {
    min-height: 0;
    padding: 28px;
  }
}

.vp-page-patient .vp-assessment-card .vp-assessment-note {
  margin-top: 24px !important;
}
