:root {
  --landing-bg: #081015;
  --landing-ink: #f7fbfd;
  --landing-muted: #b9cbd1;
  --landing-line: rgba(255, 255, 255, .13);
  --landing-gold: #e4bd7e;
  --landing-teal: #35e4cf;
  --landing-blue: #7aa7ff;
  --landing-coral: #f26d5b;
}

.landing-page {
  min-height: 100vh;
  background: var(--landing-bg);
  color: var(--landing-ink);
}

.landing-page.recovery-page {
  background:
    linear-gradient(90deg, rgba(8, 16, 21, .96) 0%, rgba(8, 16, 21, .88) 44%, rgba(8, 16, 21, .48) 72%, rgba(8, 16, 21, .9) 100%),
    url("/business-recovery-hero.jpg") center top / cover fixed no-repeat;
}

.landing-page.creator-page {
  background:
    linear-gradient(90deg, rgba(8, 12, 18, .96) 0%, rgba(8, 12, 18, .86) 44%, rgba(8, 12, 18, .45) 72%, rgba(8, 12, 18, .88) 100%),
    url("/creator-hero.jpg") center top / cover fixed no-repeat;
}

.landing-page::before {
  opacity: .35 !important;
}

.landing-page header {
  background: rgba(7, 14, 18, .82) !important;
  border-bottom: 1px solid rgba(255, 255, 255, .11) !important;
  box-shadow: 0 14px 44px rgba(0, 0, 0, .24);
}

.landing-page .top {
  width: min(1180px, calc(100% - 32px));
  min-height: 74px;
}

.landing-page .brand {
  color: #fff !important;
  letter-spacing: .18em;
  white-space: nowrap;
}

.landing-page .nav a,
.landing-page .button {
  min-height: 46px;
  border-color: rgba(255, 255, 255, .14) !important;
  background: rgba(255, 255, 255, .055) !important;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
  white-space: nowrap;
}

.landing-page .nav a:hover,
.landing-page .button:hover {
  transform: translateY(-2px);
  border-color: rgba(53, 228, 207, .42) !important;
  background: rgba(255, 255, 255, .09) !important;
  box-shadow: 0 16px 38px rgba(0, 0, 0, .24);
}

.landing-page .button.primary {
  border-color: rgba(228, 189, 126, .62) !important;
  background: linear-gradient(135deg, #f5d59f, #e4bd7e) !important;
  color: #081015 !important;
  box-shadow: 0 18px 44px rgba(228, 189, 126, .18);
}

.landing-page .hero {
  min-height: min(860px, calc(100vh - 74px));
  display: grid;
  align-items: center;
  padding: clamp(54px, 8vw, 96px) 0 !important;
  border-top: 0 !important;
}

.landing-page .hero-layout {
  display: grid;
  gap: clamp(24px, 5vw, 58px);
  align-items: center;
}

.landing-page .hero-copy {
  max-width: 820px;
}

.landing-page .eyebrow {
  color: var(--landing-teal) !important;
}

.landing-page h1 {
  max-width: 850px !important;
  font-size: clamp(3.1rem, 8vw, 7rem) !important;
  line-height: .9 !important;
  text-wrap: balance;
}

.landing-page .lead {
  max-width: 740px !important;
  color: rgba(247, 251, 253, .9) !important;
}

.landing-page .hero-visual {
  border: 1px solid rgba(255, 255, 255, .13);
  border-radius: 8px;
  overflow: hidden;
  min-height: 390px;
  background-position: center;
  background-size: cover;
  box-shadow: 0 34px 90px rgba(0, 0, 0, .42);
  position: relative;
}

.landing-page.recovery-page .hero-visual {
  background-image:
    linear-gradient(180deg, rgba(8, 16, 21, .02), rgba(8, 16, 21, .55)),
    url("/business-recovery-hero.jpg");
}

.landing-page.creator-page .hero-visual {
  background-image:
    linear-gradient(180deg, rgba(8, 12, 18, .02), rgba(8, 12, 18, .55)),
    url("/creator-hero.jpg");
}

.landing-page .hero-visual::after {
  content: "";
  position: absolute;
  inset: auto 18px 18px 18px;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--landing-coral), var(--landing-gold), var(--landing-teal), var(--landing-blue));
  box-shadow: 0 0 26px rgba(53, 228, 207, .24);
}

.landing-page .hero-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 22px;
}

.landing-page .proof-chip {
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 8px;
  background: rgba(0, 0, 0, .26);
  padding: 14px;
}

.landing-page .proof-chip strong {
  display: block;
  color: #fff;
  font-size: 1.05rem;
}

.landing-page .proof-chip span {
  color: rgba(247, 251, 253, .72);
  font-size: .86rem;
}

.landing-page section {
  background: rgba(8, 16, 21, .78);
  backdrop-filter: blur(10px);
}

.landing-page section:nth-of-type(even) {
  background: rgba(13, 22, 26, .82);
}

.landing-page .card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .07), rgba(255, 255, 255, .025)),
    rgba(8, 16, 21, .72) !important;
  border-color: rgba(255, 255, 255, .12) !important;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.landing-page .card:hover {
  transform: translateY(-4px);
  border-color: rgba(228, 189, 126, .38) !important;
  box-shadow: 0 26px 70px rgba(0, 0, 0, .28);
}

.landing-page .card.hot,
.landing-page .card.featured {
  background:
    linear-gradient(135deg, rgba(228, 189, 126, .14), rgba(53, 228, 207, .08), rgba(255, 255, 255, .035)),
    rgba(8, 16, 21, .76) !important;
}

.landing-page .split {
  gap: clamp(24px, 5vw, 52px) !important;
}

.landing-page h2 {
  max-width: 760px;
  text-wrap: balance;
}

.landing-page p {
  max-width: 68ch;
}

.landing-page .cta {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(228, 189, 126, .18), rgba(53, 228, 207, .12), rgba(122, 167, 255, .1)),
    rgba(8, 16, 21, .86) !important;
  box-shadow: 0 34px 90px rgba(0, 0, 0, .3);
}

.landing-page .cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: .42;
  pointer-events: none;
}

.landing-page .cta > * {
  position: relative;
}

.landing-page footer {
  background: rgba(6, 12, 16, .94);
}

@media (min-width: 900px) {
  .landing-page .hero-layout {
    grid-template-columns: minmax(0, .94fr) minmax(360px, .72fr);
  }
}

@media (max-width: 720px) {
  .landing-page.recovery-page,
  .landing-page.creator-page {
    background-attachment: scroll;
    background-position: 62% 0;
  }

  .landing-page .hero {
    min-height: auto;
  }

  .landing-page .hero-proof {
    grid-template-columns: 1fr;
  }

  .landing-page .hero-visual {
    min-height: 260px;
  }

  .landing-page .top {
    min-height: 68px;
  }

  .landing-page .nav {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }

  .landing-page .nav a {
    justify-content: center;
    text-align: center;
    white-space: normal;
  }
}
