/* ============================================================
   Layout — grid, containers, sections
   ============================================================ */

.container {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

section {
  padding-block: var(--section-pad);
}

.section--cobalt {
  background-color: var(--color-cobalt);
  color: var(--color-on-cobalt);
}

.section--surface {
  background-color: var(--color-surface);
}

.section-title {
  margin-top: 0;
}

.prose {
  max-width: var(--measure);
}

/* ---- header ------------------------------------------------ */

.site-head {
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
  background-color: var(--color-bg);
  box-shadow: var(--shadow-nav);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding-block: var(--space-4);
}

.nav-links {
  display: flex;
  gap: var(--space-8);
}

/* ---- hero ---------------------------------------------------- */

.hero {
  padding-block: var(--hero-pad-top) var(--hero-pad-bottom);
  border-bottom: var(--border-w) solid var(--color-line);
}

.hero-line {
  display: block;
}

.hero-line:last-child {
  color: var(--color-cobalt);
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: var(--space-16);
  align-items: center;
  margin-top: var(--space-12);
}

.hero-copy {
  max-width: var(--measure);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-10);
}

/* ---- how it works: the route -------------------------------- */

.steps {
  display: grid;
  gap: var(--space-10);
  margin-top: var(--space-16);
  max-width: var(--measure);
}

.step {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-6);
}

/* ---- scenarios ------------------------------------------------ */

.scenarios {
  display: grid;
  gap: var(--space-24);
  margin-top: var(--space-16);
}

.scenario {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-16);
  align-items: center;
}

.scenario--flip > .scenario-copy {
  order: 2;
}

/* ---- services -------------------------------------------------- */

.services {
  margin-top: var(--space-16);
}

.service {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
  gap: var(--space-8);
  padding-block: var(--space-10);
  border-top: var(--border-w) solid var(--color-cobalt-line);
}

/* ---- contact ----------------------------------------------------- */

.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: var(--space-20);
  align-items: start;
}

/* ---- footer -------------------------------------------------------- */

.site-foot {
  background-color: var(--color-cobalt-night);
  color: var(--color-on-cobalt);
  padding-block: var(--space-16);
}

.foot-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-8);
}

.foot-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
}

/* ---- responsive ------------------------------------------------------ */

@media (max-width: 768px) {
  .nav-links {
    display: none;
  }

  .hero-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-12);
  }

  .scenario {
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-8);
  }

  .scenario--flip > .scenario-copy {
    order: 0;
  }

  .service {
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-2);
  }

  .contact-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-12);
  }
}
