/* ============================================================================
   pages/landing.css — public landing page (phase 5).
   Page layer only: layout + spacing. All values from tokens.css.
   ============================================================================ */

/* ---- Hero ------------------------------------------------------------------ */

.hero {
  text-align: center;
  max-inline-size: 720px;
  margin-inline: auto;
  padding-block: var(--space-16) var(--space-10);
}
.hero__title { margin-block-end: var(--space-4); }
.hero__sub   { color: var(--ink-2); margin-block-end: var(--space-8); }
.hero__actions {
  display: flex;
  justify-content: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.hero__note { margin-block-start: var(--space-4); }

/* ---- Sections ---------------------------------------------------------------- */

.landing-section { padding-block: var(--space-10); }
.landing-section__title {
  text-align: center;
  margin-block-end: var(--space-8);
}

/* ---- How it works: three numbered step cards ---------------------------------- */

.steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-5);
}
@media (max-width: 900px) {
  .steps {
    grid-template-columns: 1fr;
    max-inline-size: 560px;
    margin-inline: auto;
  }
}

.step__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-block-end: var(--space-4);
}
.step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 40px;
  block-size: 40px;
  border-radius: var(--radius-pill);
  background: var(--primary-tint);
  color: var(--icon-accent);
  font-weight: 700;
}
.step__icon { color: var(--icon-accent); }
.step h3 { margin-block-end: var(--space-2); }

/* ---- Why us: icon + text feature rows ------------------------------------------ */

.feats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6) var(--space-8);
  max-inline-size: 900px;
  margin-inline: auto;
}
@media (max-width: 700px) {
  .feats { grid-template-columns: 1fr; }
}

.feat {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}
.feat__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 48px;
  block-size: 48px;
  border-radius: var(--radius-md);
  background: var(--primary-tint);
  color: var(--icon-accent);
}
.feat h3 { margin-block-end: var(--space-1); }

/* ---- Closing call-to-action band -------------------------------------------------- */

.cta-band {
  text-align: center;
  padding-block: var(--space-10);
  margin-block: var(--space-4) var(--space-16);
}
.cta-band h2 { margin-block-end: var(--space-2); }
.cta-band p {
  max-inline-size: 52ch;
  margin-inline: auto;
  margin-block-end: var(--space-6);
}
