:root {
  color: #121615;
  background: #eef2e8;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: #eef2e8;
}

a {
  color: inherit;
}

.hero {
  position: relative;
  min-height: 88svh;
  display: grid;
  align-items: center;
  background:
    linear-gradient(90deg, rgba(9, 16, 14, 0.82), rgba(9, 16, 14, 0.28) 62%, rgba(9, 16, 14, 0.04)),
    url("https://images.unsplash.com/photo-1516321318423-f06f85e504b3?auto=format&fit=crop&w=1800&q=82")
      center / cover;
  color: #f8fff0;
  overflow: hidden;
}

.hero__content {
  width: min(620px, calc(100% - 40px));
  margin-left: clamp(20px, 8vw, 120px);
  animation: enter 760ms ease-out both;
}

.eyebrow,
.section-label {
  margin: 0 0 18px;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  max-width: 10ch;
  margin-bottom: 22px;
  font-size: clamp(4rem, 11vw, 8.5rem);
  line-height: 0.84;
  letter-spacing: 0;
}

.hero__copy {
  max-width: 36rem;
  margin-bottom: 34px;
  font-size: clamp(1.1rem, 2vw, 1.45rem);
  line-height: 1.45;
}

.button {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  padding: 0 22px;
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: 6px;
  background: #d7ff65;
  color: #121615;
  font-weight: 800;
  text-decoration: none;
  transition: transform 180ms ease, background 180ms ease, color 180ms ease;
}

.button:hover {
  transform: translateY(-2px);
  background: #f8fff0;
}

.band {
  padding: clamp(70px, 12vw, 140px) 20px;
}

.band__inner,
.final {
  width: min(940px, 100%);
  margin: 0 auto;
}

.band h2,
.final h2 {
  max-width: 760px;
  margin-bottom: 24px;
  font-size: clamp(2.2rem, 5vw, 5rem);
  line-height: 0.96;
  letter-spacing: 0;
}

.band p:not(.section-label) {
  max-width: 680px;
  color: #35413c;
  font-size: 1.18rem;
  line-height: 1.7;
}

.workflow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid #c6d2c2;
  border-bottom: 1px solid #c6d2c2;
}

.workflow > div {
  min-height: 260px;
  padding: clamp(28px, 4vw, 56px);
  border-right: 1px solid #c6d2c2;
  background: #f8fff0;
  transition: background 180ms ease;
}

.workflow > div:hover {
  background: #e4f4cf;
}

.workflow > div:last-child {
  border-right: 0;
}

.workflow span {
  display: block;
  margin-bottom: 42px;
  color: #55645f;
  font-weight: 800;
}

.workflow h3 {
  margin-bottom: 16px;
  font-size: 1.5rem;
  line-height: 1.1;
}

.workflow p {
  max-width: 18rem;
  color: #35413c;
  line-height: 1.55;
}

.handoff {
  padding: clamp(68px, 10vw, 118px) 20px;
  background: #121615;
  color: #f8fff0;
}

.handoff__inner {
  width: min(1040px, 100%);
  margin: 0 auto;
}

.handoff h2 {
  max-width: 780px;
  margin-bottom: 34px;
  font-size: clamp(2rem, 4.8vw, 4.8rem);
  line-height: 0.98;
  letter-spacing: 0;
}

.handoff ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin: 0;
  padding: 0;
  list-style: none;
  background: rgba(248, 255, 240, 0.18);
}

.handoff li {
  min-width: 0;
  padding: clamp(22px, 3vw, 34px);
  background: #1d2421;
  color: #c9d7c4;
  line-height: 1.55;
}

.handoff strong {
  color: #d7ff65;
}

.offers {
  display: grid;
  grid-template-columns: minmax(260px, 0.8fr) minmax(0, 1.2fr);
  gap: clamp(36px, 7vw, 96px);
  padding: clamp(76px, 11vw, 136px) clamp(20px, 7vw, 96px);
  background: #eef2e8;
  border-bottom: 1px solid #c6d2c2;
}

.offers__intro h2 {
  max-width: 620px;
  margin-bottom: 0;
  font-size: clamp(2rem, 4.6vw, 4.6rem);
  line-height: 0.98;
  letter-spacing: 0;
}

.offers__intro,
.offers__list,
.offers__list a > * {
  min-width: 0;
}

.offers__list {
  border-top: 1px solid #aebcaf;
}

.offers__list a {
  display: grid;
  grid-template-columns: 88px minmax(170px, 0.8fr) minmax(220px, 1fr);
  gap: 24px;
  align-items: center;
  min-height: 112px;
  padding: 24px 0;
  border-bottom: 1px solid #aebcaf;
  color: #121615;
  text-decoration: none;
  transition: color 180ms ease, padding-left 180ms ease;
}

.offers__list a:hover {
  color: #426500;
  padding-left: 10px;
}

.offers__list span {
  font-weight: 900;
}

.offers__list strong {
  font-size: clamp(1.12rem, 2vw, 1.48rem);
  line-height: 1.12;
}

.offers__list em {
  color: #35413c;
  font-style: normal;
  line-height: 1.52;
}

.final {
  padding: clamp(78px, 12vw, 150px) 20px;
  background: #121615;
  color: #f8fff0;
}

.final p:not(.section-label) {
  max-width: 720px;
  color: #c9d7c4;
  font-size: 1.05rem;
  line-height: 1.65;
}

.button--dark {
  border-color: #d7ff65;
  background: #d7ff65;
  color: #121615;
}

@keyframes enter {
  from {
    opacity: 0;
    transform: translateY(18px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 760px) {
  .hero {
    min-height: 82svh;
    background-position: 58% center;
  }

  .hero__content {
    margin: 0 auto;
  }

  h1 {
    max-width: 100%;
    font-size: clamp(3.2rem, 14vw, 4rem);
    line-height: 0.92;
  }

  .workflow {
    grid-template-columns: 1fr;
  }

  .workflow > div {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid #d8cec0;
  }

  .workflow > div:last-child {
    border-bottom: 0;
  }

  .handoff ul {
    grid-template-columns: 1fr;
  }

  .offers {
    grid-template-columns: 1fr;
    padding-right: 32px;
    padding-left: 32px;
  }

  .offers__list a {
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
    min-height: auto;
    width: 100%;
    max-width: 100%;
  }

  .offers__intro h2 {
    font-size: clamp(1.65rem, 8vw, 2.4rem);
    line-height: 1.02;
  }

  .offers__list strong,
  .offers__list em {
    display: block;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
  }
}
