.zr-portrait-hero {
  position: relative;
  z-index: 9;
  width: min(86vw, 440px);
  margin: 32px auto 0;
  pointer-events: none;
}

.zr-portrait-hero img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: 50% 36%;
  border-radius: 8px;
  border: 1px solid rgba(249, 120, 21, 0.44);
  box-shadow:
    0 24px 70px rgba(0, 0, 0, 0.42),
    inset 0 0 0 1px rgba(255, 255, 255, 0.08);
  filter: grayscale(1) contrast(1.08) brightness(0.92);
}

.zr-portrait-hero::before {
  content: "";
  position: absolute;
  inset: 8px;
  z-index: 1;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 6px;
}

.zr-portrait-hero figcaption {
  margin-top: 8px;
  color: rgba(255, 255, 255, 0.62);
  font-size: 12px;
  font-weight: 600;
  text-align: right;
}

@media (min-width: 1024px) {
  .zr-portrait-hero {
    position: absolute;
    right: clamp(24px, 5vw, 96px);
    bottom: clamp(48px, 8vh, 88px);
    width: clamp(300px, 29vw, 480px);
    margin: 0;
    transform: rotate(-1.2deg);
  }
}

@media (max-width: 767px) {
  .zr-landing-page main section:first-of-type {
    min-height: auto !important;
    padding-top: 112px !important;
    padding-bottom: 56px !important;
    overflow-x: hidden;
  }

  .zr-landing-page main section:first-of-type > div:nth-child(2) {
    width: 100%;
    max-width: calc(100vw - 40px) !important;
    min-width: 0;
  }

  .zr-landing-page main section:first-of-type h1 {
    width: calc(100vw - 48px) !important;
    max-width: 100% !important;
    font-size: 34px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal;
  }

  .zr-landing-page main section:first-of-type h1 + p {
    width: calc(100vw - 48px) !important;
    max-width: 100% !important;
    font-size: 16px !important;
    line-height: 1.55 !important;
  }

  .zr-landing-page main section:first-of-type h1 + p + div {
    width: min(calc(100vw - 48px), 320px) !important;
    max-width: min(calc(100vw - 48px), 320px) !important;
    margin-right: auto !important;
    margin-left: auto !important;
    flex-direction: column;
    align-items: stretch;
  }

  .zr-landing-page main section:first-of-type h1 + p + div > * {
    box-sizing: border-box;
    justify-content: center;
    width: 100% !important;
    min-width: 0 !important;
    margin-right: 0;
    margin-left: 0;
  }

  .zr-portrait-hero {
    width: min(100%, 420px);
    margin-top: 28px;
  }

  .zr-portrait-hero img {
    aspect-ratio: 1.45 / 1;
  }

  .zr-portrait-hero figcaption {
    text-align: center;
  }
}

@media (max-width: 360px) {
  .zr-landing-page main section:first-of-type h1 {
    font-size: 30px !important;
  }
}
