:root {
  --ink: #1d1d1f;
  --muted: #6e6e73;
  --line: rgba(29, 29, 31, .1);
  --bg: #f5f5f7;
  --panel: #ffffff;
  --soft: #eceef1;
  --accent: #a9efd6;
  --accent-ink: #08231d;
  --teal: #16745d;
  --radius: 8px;
  --button-radius: 8px;
  --button-shadow: 0 14px 32px rgba(20, 22, 21, .12);
  --surface-shadow: 0 24px 70px rgba(20, 22, 21, .1), 0 3px 12px rgba(20, 22, 21, .06);
}

body {
  background: linear-gradient(180deg, #fbfbfd 0%, var(--bg) 38%, #ffffff 100%) !important;
}

.site-header {
  top: 16px !important;
}

.header-shell {
  border-radius: 8px !important;
  background: rgba(250, 250, 252, .78) !important;
  border-color: rgba(255, 255, 255, .58) !important;
  color: var(--ink) !important;
  box-shadow: 0 18px 52px rgba(20, 22, 21, .12) !important;
}

.brand-icon,
.nav-link,
.language-switch,
.language-switch a,
.nav-link.solid,
.button,
.kicker,
.eyebrow,
.outcome,
.step,
.plan,
.media-panel {
  border-radius: 8px !important;
}

.brand-copy small,
.primary-nav .nav-link,
.nav-link,
.language-switch a {
  color: rgba(29, 29, 31, .72) !important;
}

.primary-nav .nav-link:hover,
.top-actions > .nav-link {
  background: rgba(29, 29, 31, .05) !important;
  border-color: rgba(29, 29, 31, .08) !important;
  color: var(--ink) !important;
}

.language-switch {
  background: rgba(29, 29, 31, .04) !important;
  border-color: rgba(29, 29, 31, .08) !important;
}

.language-switch a.active,
.nav-link.solid {
  background: #ffffff !important;
  color: var(--ink) !important;
  box-shadow: 0 10px 24px rgba(20, 22, 21, .1) !important;
}

.hero {
  min-height: 92svh !important;
  padding: 108px 28px 36px !important;
  background:
    radial-gradient(circle at 82% 18%, rgba(169, 239, 214, .18), transparent 22%),
    linear-gradient(180deg, #f4f5f6 0%, #eff1f2 38%, #f6f7f8 100%) !important;
  color: var(--ink) !important;
}

.hero-inner {
  width: min(1240px, 100%) !important;
  margin: 0 auto !important;
  min-height: calc(92svh - 84px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr) !important;
  gap: 24px !important;
  align-items: center !important;
}

.hero-copy {
  max-width: 560px !important;
  display: grid !important;
  gap: 18px !important;
  min-width: 0 !important;
}

h1 {
  max-width: 10ch !important;
  font-size: 76px !important;
  line-height: .92 !important;
  letter-spacing: 0 !important;
}

h2 {
  font-size: 44px !important;
  letter-spacing: 0 !important;
}

.kicker {
  width: max-content !important;
  max-width: 100% !important;
  background: rgba(169, 239, 214, .18) !important;
  border-color: rgba(22, 116, 93, .18) !important;
  color: var(--teal) !important;
}

.hero p {
  max-width: 48ch !important;
  margin: 0 !important;
  font-size: 20px !important;
  color: rgba(29, 29, 31, .72) !important;
}

.button.primary {
  background: linear-gradient(180deg, #bdf7e4, var(--accent)) !important;
  color: var(--accent-ink) !important;
}

.button.ghost {
  color: var(--ink) !important;
  border-color: rgba(29, 29, 31, .14) !important;
  background: rgba(255, 255, 255, .72) !important;
}

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

.hero-proof-strip div {
  display: grid;
  gap: 4px;
  padding: 14px;
  border: 1px solid rgba(29, 29, 31, .08);
  border-radius: 8px;
  background: rgba(255, 255, 255, .74);
  box-shadow: var(--surface-shadow);
}

.hero-proof-strip strong {
  font-size: 13px;
  font-weight: 800;
}

.hero-proof-strip span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.product-stage {
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(18, 23, 22, .98), rgba(20, 25, 24, .95)) !important;
  color: #fff;
  overflow: hidden;
  box-shadow: 0 36px 90px rgba(12, 18, 16, .24), inset 0 1px 0 rgba(255, 255, 255, .06);
  min-width: 0;
}

.product-stage-bar {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
  flex-wrap: wrap;
  padding: 18px 18px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  background: linear-gradient(180deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .01));
}

.product-stage-bar span,
.stage-lane-head span,
.stage-focus-head span,
.stage-draft-card span {
  display: inline-flex;
  color: rgba(169, 239, 214, .94);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.product-stage-bar strong,
.stage-focus-head strong {
  display: block;
  margin-top: 4px;
  font-size: 18px;
  line-height: 1.15;
}

.product-stage-bar em {
  padding: 7px 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, .08);
  color: rgba(255, 255, 255, .84);
  font-style: normal;
  font-weight: 700;
}

.product-stage-grid {
  display: grid;
  grid-template-columns: minmax(0, .74fr) minmax(0, 1.12fr) minmax(0, .62fr);
  gap: 12px;
  padding: 16px;
}

.stage-lane,
.stage-focus-card,
.stage-rail {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.stage-lane-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}

.stage-lane-head small {
  color: rgba(255, 255, 255, .54);
  font-size: 12px;
}

.stage-queue-card,
.stage-focus-card,
.stage-rail article,
.stage-draft-card {
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 8px;
  background: rgba(255, 255, 255, .04);
}

.stage-queue-card {
  padding: 14px;
}

.stage-queue-card strong {
  display: block;
  margin-bottom: 6px;
  font-size: 14px;
}

.stage-queue-card p,
.stage-draft-card p {
  margin: 0;
  color: rgba(255, 255, 255, .72) !important;
  font-size: 13px !important;
  line-height: 1.5;
}

.stage-protect { background: rgba(243, 201, 95, .12) !important; }
.stage-lead { background: rgba(169, 239, 214, .12) !important; }
.stage-question { background: rgba(255, 255, 255, .05) !important; }

.stage-focus-card {
  padding: 16px;
}

.stage-focus-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
  flex-wrap: wrap;
}

.stage-focus-head small {
  padding: 6px 9px;
  border-radius: 8px;
  background: rgba(169, 239, 214, .12);
  color: rgba(169, 239, 214, .94);
  font-size: 12px;
  font-weight: 700;
}

.stage-comment-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.stage-comment-chip-row span {
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 8px;
  padding: 7px 9px;
  background: rgba(255, 255, 255, .04);
  color: rgba(255, 255, 255, .74);
  font-size: 12px;
  font-weight: 700;
}

.stage-draft-card {
  padding: 14px;
}

.stage-rail article {
  display: grid;
  gap: 6px;
  padding: 14px;
}

.stage-rail span {
  color: rgba(255, 255, 255, .62);
  font-size: 12px;
  font-weight: 700;
}

.stage-rail strong {
  font-size: 22px;
  line-height: 1.05;
}

.section {
  padding: 84px 28px !important;
}

.band {
  background: #ffffff !important;
}

.outcome,
.step,
.plan {
  background: rgba(255, 255, 255, .88) !important;
  border-color: rgba(29, 29, 31, .08) !important;
  box-shadow: var(--surface-shadow) !important;
}

.outcome span,
.step span,
.plan span,
.eyebrow {
  color: var(--teal) !important;
}

.eyebrow,
.lead-pill {
  background: #eef8f4 !important;
  border-color: #c7e9dd !important;
}

.media-photo {
  overflow: hidden;
  box-shadow: var(--surface-shadow) !important;
}

.media-photo img {
  width: 100%;
  height: auto;
  display: block;
}

.story-copy {
  display: grid;
  gap: 24px;
  align-content: start;
}

.story-copy .lead {
  margin: 0 !important;
  max-width: 34ch !important;
}

.story .workflow {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
  margin-top: 0 !important;
}

.story .step {
  min-height: 0 !important;
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 22px !important;
}

.story .step p {
  margin: 0 !important;
}

.story .media-panel {
  min-height: 520px !important;
}

.final .button.ghost {
  color: var(--ink) !important;
  border-color: var(--line) !important;
  background: #ffffff !important;
}

footer {
  background: #ffffff !important;
}

@media (max-width: 1280px) {
  .story {
    grid-template-columns: 1fr !important;
    gap: 30px !important;
  }

  .story .workflow {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .workflow,
  .pricing {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .product-stage-grid {
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr) !important;
  }

  .stage-rail {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1180px) {
  .hero-inner {
    grid-template-columns: 1fr !important;
  }

  .outcomes {
    grid-template-columns: 1fr !important;
  }

  .workflow,
  .pricing {
    grid-template-columns: 1fr !important;
  }

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

  .product-stage-grid {
    grid-template-columns: 1fr !important;
  }

  .stage-rail {
    grid-column: auto;
  }
}

@media (max-width: 980px) {
  h1 {
    font-size: 54px !important;
  }

  h2 {
    font-size: 34px !important;
  }

  .hero-proof-strip {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 620px) {
  .site-header {
    top: 10px !important;
  }

  .hero {
    min-height: auto !important;
    padding: 112px 18px 34px !important;
  }

  .hero-inner {
    width: 100% !important;
    gap: 18px !important;
  }

  h1 {
    font-size: 38px !important;
    line-height: 1.02 !important;
  }

  h2 {
    font-size: 28px !important;
  }

  .hero-proof-strip,
  .product-stage-grid {
    grid-template-columns: 1fr !important;
  }
}
