/* Runbook marketing site — layout layer over the shared Ledger tokens.
   styles/tokens.css supplies color, type, and the identity; this file
   only arranges the page. Calm proof: generous whitespace, ledger
   tables, the double rule used sparingly and only where something is
   final and true. */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
[id] { scroll-margin-top: 118px; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--color-ink);
  font-family: "Public Sans", "Inter", system-ui, sans-serif;
  font-size: 17px;
  line-height: 1.6;
  overflow-x: hidden;
}
body:has(.floating-nav) { padding-top: 108px; }
a { color: var(--color-primary-dark); }
.mono { font-family: var(--font-mono); }

.wrap { max-width: 1120px; margin: 0 auto; padding: 0 24px; }
.narrow { max-width: 720px; }
.prose-centered { margin: 0 auto; }

.announcement {
  display: none;
  background: var(--green-cool-90);
  color: #fff;
  font-size: 13px;
}
.announcement.is-visible { display: block; }
.announcement .wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  min-height: 34px;
  text-align: center;
}
.announcement a { color: #fff; font-weight: 800; }

/* Wordmark */
.wordmark { display: inline-flex; flex-direction: column; gap: 3px; text-decoration: none; }
.wordmark b { font-weight: 700; font-size: 24px; letter-spacing: 0; color: var(--ink-navy); line-height: 1; }
.wordmark i { display: block; border-top: 1.5px solid var(--seal); border-bottom: 1.5px solid var(--seal); height: 5px; }

/* Top bar */
.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 28px;
  padding: 14px 18px;
  margin: 0;
  background: rgb(255 255 255 / 0.94);
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: 0 12px 34px rgb(0 0 0 / 0.08);
  position: fixed;
  top: 18px;
  left: 50%;
  width: min(1072px, calc(100vw - 48px));
  transform: translateX(-50%);
  z-index: 50;
  backdrop-filter: blur(14px);
}
.topbar nav { display: flex; gap: 20px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
.topbar nav a { font-size: 14px; font-weight: 600; color: var(--color-ink); text-decoration: none; }
.topbar nav a:hover { text-decoration: underline; }
.topbar nav a span { color: var(--gray); font-size: 12px; margin-left: 3px; }
.topbar nav .signin-link { color: var(--green-cool-60); font-weight: 800; }
.topbar .btn { padding: 10px 18px; }
.btn {
  display: inline-block; padding: 12px 22px; border-radius: 4px; font-size: 15px; font-weight: 700;
  text-decoration: none; border: none; cursor: pointer; font-family: inherit;
}
.btn-primary { background: var(--emerald); color: #fff; }
.btn-primary:hover { background: var(--emerald-600); }
.btn-ghost { border: 1.5px solid var(--border-strong); color: var(--color-ink); background: none; }

/* Hero */
.hero { padding: 84px 0 64px; }
.hero h1 { font-size: clamp(34px, 5.4vw, 58px); line-height: 1.08; letter-spacing: 0; margin: 0 0 18px; max-width: 16ch; }
.hero p.lede { font-size: 19px; color: var(--slate-700); max-width: 54ch; margin: 0 0 30px; }
.hero .ctas { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.hero .fine { font-size: 12.5px; color: var(--gray); margin-top: 14px; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr); gap: 48px; align-items: center; }
.hero-payroll {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 0.78fr);
  gap: 58px;
  align-items: center;
  padding: 92px 0 74px;
}
.homepage-hero {
  min-height: 700px;
  padding-top: 78px;
}
.hero-payroll h1 { max-width: 15ch; }
.hero-copy { min-width: 0; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 28px 0 22px; }
.hero-proof-points {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 640px;
}
.hero-proof-points span {
  border: 1px solid var(--divider);
  background: #fff;
  border-radius: 999px;
  color: var(--ink-navy);
  font-size: 13px;
  font-weight: 700;
  padding: 7px 11px;
}
.hero-visual {
  position: relative;
  display: grid;
  gap: 16px;
  min-height: 0;
}
.hero-scene {
  min-height: 260px;
  border-radius: 8px;
  overflow: hidden;
  background:
    linear-gradient(160deg, rgb(9 38 43 / 0.88), rgb(9 38 43 / 0.28)),
    linear-gradient(0deg, rgb(13 95 84 / 0.68), rgb(246 244 238 / 0.12)),
    repeating-linear-gradient(90deg, rgb(255 255 255 / 0.12) 0 1px, transparent 1px 74px),
    var(--green-cool-70);
  border: 1px solid var(--divider);
  box-shadow: var(--shadow-card);
  position: relative;
}
.hero-scene::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 46%;
  background:
    linear-gradient(180deg, transparent, rgb(0 0 0 / 0.2)),
    repeating-linear-gradient(0deg, rgb(255 255 255 / 0.18) 0 2px, transparent 2px 42px);
}
.scene-roster {
  position: absolute;
  left: 36px;
  right: 36px;
  bottom: 42px;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  align-items: end;
}
.scene-roster span {
  width: 58px;
  height: 132px;
  border-radius: 999px 999px 12px 12px;
  background: linear-gradient(180deg, #f9d8b6 0 22%, var(--ink-navy) 22% 70%, var(--emerald) 70%);
  border: 1px solid rgb(255 255 255 / 0.32);
  box-shadow: 0 14px 24px rgb(0 0 0 / 0.24);
}
.scene-roster span:nth-child(2) { height: 154px; background: linear-gradient(180deg, #8b573d 0 20%, #12353a 20% 72%, var(--seal) 72%); }
.scene-roster span:nth-child(3) { height: 118px; background: linear-gradient(180deg, #d9a470 0 24%, #142f35 24% 70%, var(--emerald) 70%); }
.scene-roster span:nth-child(4) { height: 145px; background: linear-gradient(180deg, #6f432e 0 21%, #12353a 21% 72%, var(--seal) 72%); }
.scene-card {
  position: absolute;
  z-index: 2;
  left: 24px;
  top: 24px;
  background: rgb(255 255 255 / 0.94);
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 14px 16px;
  box-shadow: 0 16px 30px rgb(0 0 0 / 0.16);
}
.scene-card b { display: block; color: var(--ink-navy); }
.scene-card small { display: block; color: var(--slate-700); margin-top: 2px; }
.hero-visual .product-shell {
  position: static;
}
.hero-visual .task-board,
.hero-visual .mock-note { display: none; }
.hero-visual .run-list div { padding: 10px 14px; }
.photo-card {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  margin: 0;
  min-width: 0;
  overflow: hidden;
}
.photo-card img {
  aspect-ratio: 16 / 10;
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}
.photo-card figcaption {
  background: #fff;
  border-top: 1px solid var(--divider);
  color: var(--slate-700);
  font-size: 14px;
  line-height: 1.45;
  padding: 12px 14px;
}
.hero-photo img { aspect-ratio: 16 / 9; }
.resource-hero-photo {
  margin-top: 28px;
  max-width: 780px;
}
.resource-hero-photo img { aspect-ratio: 16 / 7; }
.trust-photo { margin-top: 18px; }
.product-photo img,
.trust-hero-photo img { aspect-ratio: 4 / 3; }
.hero-proof-column {
  display: grid;
  gap: 16px;
  min-width: 0;
}
.position-line {
  max-width: 46ch;
  margin: -12px 0 26px;
  color: var(--ink-navy);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.45;
}

.product-shell {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  padding: 18px;
  min-width: 0;
}
.product-shell-top {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: start;
  border-bottom: 2px double var(--seal);
  padding-bottom: 14px;
}
.product-shell-top div { display: grid; gap: 2px; }
.product-shell-top strong { font-size: 19px; color: var(--ink-navy); }
.product-shell-top b { color: var(--green-cool-70); font-size: 13px; text-align: right; }
.eyebrow {
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.payroll-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 16px 0;
}
.payroll-summary div {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-radius: 6px;
  padding: 12px;
}
.payroll-summary span, .run-list span, .task-board small {
  display: block;
  color: var(--slate-700);
  font-size: 12px;
}
.payroll-summary b { display: block; margin-top: 2px; font-family: var(--font-mono); font-size: 18px; }
.run-list { border: 1px solid var(--divider); border-radius: 8px; overflow: hidden; }
.run-list div {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--slate-200);
}
.run-list div:last-child { border-bottom: none; }
.run-list b { font-family: var(--font-mono); white-space: nowrap; }
.task-board { display: grid; gap: 8px; margin-top: 14px; }
.task-board div {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr) auto;
  gap: 9px;
  align-items: center;
  background: var(--gray-warm-2);
  border: 1px solid var(--divider);
  border-radius: 6px;
  padding: 10px 12px;
}
.task-board b { font-size: 13px; }
.dot { width: 9px; height: 9px; border-radius: 50%; background: var(--emerald); }
.dot.warn { background: var(--seal); }
.mock-note { color: var(--gray); font-size: 12px; line-height: 1.45; margin: 12px 0 0; }

.logo-band {
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
  background: #fff;
}
.trust-ribbon .promise-strip {
  justify-content: center;
  gap: 34px;
}
.promise-strip {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding-top: 18px;
  padding-bottom: 18px;
  color: var(--slate-700);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.kicker {
  font-size: 11.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--seal); margin: 0 0 10px;
}

/* Sections */
section.band { padding: 64px 0; }
section.band.tight { padding: 24px 0; }
section.band.alt { background: #fff; border-top: 1px solid var(--divider); border-bottom: 1px solid var(--divider); }
h2.title { font-size: 30px; letter-spacing: 0; line-height: 1.2; margin: 0 0 12px; }
p.sub { font-size: 16px; color: var(--slate-700); max-width: 60ch; margin: 0 0 28px; }
.section-head { display: flex; justify-content: space-between; gap: 32px; align-items: end; margin-bottom: 24px; }
.section-head .title { max-width: 17ch; }
.section-head .sub { margin: 0; }
.wide-head .title { max-width: 18ch; }
.wide-head .sub { max-width: 64ch; }
.trust-signal-band {
  background: #fff;
  border-bottom: 1px solid var(--divider);
}
.trust-signal {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
  gap: 48px;
  align-items: center;
}
.trust-signal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.trust-signal-grid.wide {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.trust-signal-grid div {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 18px;
}
.trust-signal-grid b {
  display: block;
  color: var(--ink-navy);
  margin-bottom: 6px;
}
.trust-signal-grid span {
  color: var(--slate-700);
  font-size: 14px;
  line-height: 1.55;
}
.center-head {
  display: grid;
  justify-items: center;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
.center-head .title {
  max-width: 22ch;
  margin-left: auto;
  margin-right: auto;
}
.center-head .sub {
  max-width: 68ch;
  margin-left: auto;
  margin-right: auto;
}

.demo-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) 320px;
  gap: 72px;
  align-items: center;
  margin-top: 34px;
}
.demo-accordion {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--divider);
}
.demo-accordion article {
  border-bottom: 1px solid var(--divider);
  padding: 22px 0;
  position: relative;
}
.demo-accordion article::after {
  content: "+";
  position: absolute;
  top: 22px;
  right: 0;
  color: var(--green-cool-60);
  font-weight: 800;
}
.demo-accordion h3 {
  font-size: 17px;
  margin: 0 34px 9px 0;
  color: var(--ink-navy);
}
.demo-accordion p {
  color: var(--slate-700);
  max-width: 62ch;
  margin: 0;
  font-size: 14.5px;
  line-height: 1.65;
}
.demo-accordion a,
.text-link {
  display: inline-block;
  margin-top: 12px;
  color: var(--green-cool-70);
  font-size: 13px;
  font-weight: 800;
}
.phone-preview {
  width: 246px;
  min-height: 450px;
  justify-self: center;
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 28px;
  box-shadow: 0 28px 70px rgb(0 0 0 / 0.12);
  padding: 34px 22px;
  opacity: 0.92;
}
.phone-top {
  color: var(--seal);
  text-align: center;
  font-weight: 800;
  margin-bottom: 28px;
}
.phone-line {
  height: 12px;
  background: var(--gray-warm-5);
  border-radius: 999px;
  margin: 12px 0;
}
.phone-line.strong {
  width: 68%;
  background: var(--gold-5v);
}
.phone-pay {
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 18px;
  margin: 28px 0;
}
.phone-pay span {
  display: block;
  color: var(--slate-700);
  font-size: 12px;
}
.phone-pay b {
  display: block;
  color: var(--ink-navy);
  font-family: var(--font-mono);
  margin-top: 4px;
}
.phone-list { display: grid; gap: 10px; }
.phone-list span {
  height: 34px;
  border: 1px solid var(--divider);
  border-radius: 8px;
  background: var(--paper);
}

.quote-band {
  text-align: center;
  padding: 72px 0;
  background: #fff;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.quote-band span {
  color: var(--gray);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.quote-band blockquote {
  max-width: 720px;
  margin: 18px auto 16px;
  color: var(--ink-navy);
  font-size: 26px;
  line-height: 1.38;
  font-weight: 700;
}
.quote-band a {
  color: var(--green-cool-70);
  font-size: 13px;
  font-weight: 800;
}

.split-copy .title { max-width: 18ch; }
.benefit-panel {
  display: grid;
  gap: 12px;
}
.benefit-panel div {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 20px;
}
.band.alt .benefit-panel div { background: var(--paper); }
.benefit-panel b {
  display: block;
  color: var(--ink-navy);
  margin-bottom: 5px;
}
.benefit-panel span {
  color: var(--slate-700);
  font-size: 14.5px;
  line-height: 1.6;
}

.more-band { padding-top: 76px; }
.more-tiles {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
  margin-top: 26px;
}
.more-tiles a {
  min-height: 118px;
  color: var(--color-ink);
  text-decoration: none;
  background: #fff;
  border: 1px solid var(--divider);
  border-bottom: 3px solid var(--seal);
  border-radius: 8px;
  padding: 18px;
}
.more-tiles a:nth-child(2) { border-bottom-color: var(--gold-60v); }
.more-tiles a:nth-child(3) { border-bottom-color: var(--emerald); }
.more-tiles a:nth-child(4) { border-bottom-color: var(--green-cool-60); }
.more-tiles a:nth-child(5) { border-bottom-color: var(--cyan-50); }
.more-tiles span {
  display: block;
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.more-tiles b {
  display: block;
  font-size: 14px;
  line-height: 1.35;
}
.plan-band .center-head .sub { margin-bottom: 20px; }

.benchmark-band {
  background: var(--green-cool-80);
  color: #fff;
  text-align: center;
  padding: 70px 0;
}
.benchmark-band h2 {
  max-width: 720px;
  margin: 0 auto 34px;
  font-size: 32px;
  line-height: 1.2;
}
.benchmark-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin: 0 auto 30px;
  max-width: 900px;
}
.benchmark-grid div {
  padding: 0 28px;
  border-right: 1px solid rgb(255 255 255 / 0.25);
}
.benchmark-grid div:last-child { border-right: none; }
.benchmark-grid b {
  display: block;
  font-size: 24px;
  line-height: 1.2;
  margin-bottom: 8px;
}
.benchmark-grid span {
  display: block;
  color: var(--gray-warm-10);
  font-size: 13px;
  line-height: 1.5;
}

.setup-layout {
  display: grid;
  grid-template-columns: minmax(260px, 0.72fr) minmax(0, 1fr);
  gap: 70px;
  align-items: start;
}
.setup-steps {
  display: grid;
  gap: 18px;
}
.setup-steps article {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 6px 16px;
}
.setup-steps span {
  grid-row: span 2;
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--green-cool-70);
  color: #fff;
  font-family: var(--font-mono);
  font-weight: 800;
}
.setup-steps h3 {
  color: var(--ink-navy);
  font-size: 17px;
  margin: 0;
}
.setup-steps p {
  color: var(--slate-700);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
}
.setup-steps .btn { justify-self: start; margin-top: 6px; }

.faq-band .title { margin-bottom: 24px; }
.faq-list {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--divider);
}
.faq-list details {
  border-bottom: 1px solid var(--divider);
  padding: 18px 0;
}
.faq-list summary {
  cursor: pointer;
  color: var(--ink-navy);
  font-weight: 800;
}
.faq-list p {
  color: var(--slate-700);
  max-width: 78ch;
  margin: 10px 0 0;
  font-size: 14.5px;
  line-height: 1.65;
}

.answers-band { text-align: center; }
.answers-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
  text-align: center;
}
.answers-grid article {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 22px;
}
.answers-grid h3 {
  color: var(--ink-navy);
  font-size: 17px;
  margin: 0 0 8px;
}
.answers-grid p {
  color: var(--slate-700);
  font-size: 13.5px;
  line-height: 1.55;
  margin: 0 0 12px;
}
.answers-grid a {
  color: var(--green-cool-70);
  font-size: 13px;
  font-weight: 800;
}

.cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; }
.card { background: #fff; border: 1px solid var(--divider); border-radius: 8px; padding: 22px 20px; }
.band.alt .card { background: var(--paper); }
.card h3 { font-size: 17px; margin: 0 0 8px; }
.card p { font-size: 14px; color: var(--slate-700); margin: 0; line-height: 1.65; }
.visually-hidden { position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

.proof-panel {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  padding: 18px;
  max-width: 100%;
  min-width: 0;
  margin: 0;
}
.proof-head { display: flex; justify-content: space-between; gap: 16px; border-bottom: 2px double var(--seal); padding-bottom: 12px; margin-bottom: 10px; }
.proof-head span, .proof-checks span, .status {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.proof-head span { color: var(--seal); }
.proof-head strong { color: var(--ink-navy); }
.proof-row { display: flex; justify-content: space-between; gap: 18px; border-bottom: 1px solid var(--slate-200); padding: 12px 0; }
.proof-row span { color: var(--slate-700); }
.proof-row b { font-family: var(--font-mono); overflow-wrap: anywhere; text-align: right; }
.proof-checks { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin: 16px 0 12px; }
.proof-checks span { background: var(--gray-warm-2); border: 1px solid var(--divider); color: var(--green-cool-70); padding: 8px; }
.proof-panel p { color: var(--gray); font-size: 12px; line-height: 1.5; margin: 0; }

.status-strip, .milestone-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.status-strip div, .milestone-grid div {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 14px;
}
.status-strip b, .milestone-grid b { display: block; margin: 8px 0 4px; font-size: 15px; }
.status-strip small, .milestone-grid small { color: var(--slate-700); line-height: 1.45; }
.milestone-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); margin: 28px 0; }

.status { display: inline-block; padding: 4px 7px; border-radius: 3px; font-weight: 700; }
.status.live { background: var(--green-cool-10); color: var(--green-cool-70); }
.status.engine { background: var(--cyan-5); color: var(--cyan-50); }
.status.build { background: var(--gold-5v); color: var(--gold-60v); }
.status.planned { background: var(--gray-warm-5); color: var(--gray-warm-70); }

.feature-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.feature {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 22px;
  min-height: 190px;
}
.band.alt .feature { background: var(--paper); }
.feature h3 { margin: 14px 0 8px; font-size: 19px; }
.feature p { margin: 0; color: var(--slate-700); font-size: 14.5px; line-height: 1.65; }

.module-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.module-card {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 20px;
  min-height: 230px;
}
.module-card b {
  display: inline-block;
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 12px;
  margin-bottom: 18px;
}
.module-card h3 { color: var(--ink-navy); font-size: 18px; margin: 0 0 8px; }
.module-card p { color: var(--slate-700); font-size: 14px; line-height: 1.6; margin: 0; }

.split-feature {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.78fr);
  gap: 54px;
  align-items: center;
}
.split-feature.reverse { grid-template-columns: minmax(360px, 0.82fr) minmax(0, 0.95fr); }
.stacked-list { display: grid; gap: 12px; margin: 26px 0; }
.stacked-list div {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 16px;
}
.band:not(.alt) .stacked-list div { background: var(--paper); }
.stacked-list b { display: block; color: var(--ink-navy); margin-bottom: 3px; }
.stacked-list span { color: var(--slate-700); font-size: 14.5px; line-height: 1.55; }
.proof-stack { display: grid; gap: 12px; }
.proof-card {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-left: 5px solid var(--seal);
  border-radius: 8px;
  padding: 18px 20px;
}
.proof-card span {
  display: block;
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 7px;
}
.proof-card b { color: var(--ink-navy); font-size: 17px; line-height: 1.35; }

.persona-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.persona-grid article {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 22px;
  min-height: 220px;
}
.persona-grid span {
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.persona-grid h3 { color: var(--ink-navy); font-size: 20px; line-height: 1.25; margin: 14px 0 8px; }
.persona-grid p { color: var(--slate-700); font-size: 14.5px; line-height: 1.6; margin: 0; }

.support-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.support-grid div {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 18px;
}
.support-grid b { display: block; color: var(--ink-navy); margin-bottom: 5px; }
.support-grid span { color: var(--slate-700); font-size: 14px; line-height: 1.55; }

.payroll-roadmap {
  display: grid;
  gap: 10px;
}
.payroll-roadmap div {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 8px 16px;
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 16px;
}
.payroll-roadmap span {
  grid-row: span 2;
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.payroll-roadmap b { color: var(--ink-navy); }
.payroll-roadmap small { color: var(--slate-700); line-height: 1.45; }

.compare { border: 1px solid var(--divider); border-radius: 8px; overflow: hidden; background: #fff; }
.compare-row { display: grid; grid-template-columns: 0.8fr 1fr 1.2fr; gap: 0; border-bottom: 1px solid var(--slate-200); }
.compare-row:last-child { border-bottom: none; }
.compare-row span { padding: 15px 16px; border-right: 1px solid var(--slate-200); font-size: 14px; line-height: 1.55; }
.compare-row span:last-child { border-right: none; }
.compare-head { background: var(--green-cool-70); color: #fff; font-weight: 700; }
.compare-head span { border-color: rgb(255 255 255 / 0.18); }
.proof-callout {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-left: 6px solid var(--seal);
  border-radius: 8px;
  padding: 20px 22px;
  margin: 0 0 22px;
  max-width: 760px;
}
.proof-callout h3 { margin: 0 0 8px; font-size: 21px; line-height: 1.25; color: var(--ink-navy); }
.proof-callout p { margin: 0; color: var(--slate-700); line-height: 1.65; }

.record-demo {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.62fr);
  gap: 24px;
  align-items: start;
}
.record-flow {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.record-flow article,
.surface-grid article,
.liability-report-card,
.notice-case,
.packet-checklist div {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
}
.record-flow article {
  min-height: 188px;
  padding: 18px;
}
.record-flow span,
.surface-grid span,
.packet-checklist span {
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 12.5px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.record-flow h3,
.surface-grid h3,
.notice-case h3 {
  color: var(--ink-navy);
  font-size: 18px;
  line-height: 1.25;
  margin: 14px 0 8px;
}
.record-flow p,
.surface-grid p,
.notice-case p {
  color: var(--slate-700);
  font-size: 15px;
  line-height: 1.6;
  margin: 0;
}
.record-panel {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  padding: 18px;
}
.record-status {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 14px 0;
}
.record-status div {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-radius: 6px;
  padding: 12px;
}
.record-status span {
  display: block;
  color: var(--slate-700);
  font-size: 13px;
}
.record-status b {
  display: block;
  color: var(--ink-navy);
  font-family: var(--font-mono);
  font-size: 16px;
  margin-top: 3px;
}

.surface-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.surface-grid article {
  display: grid;
  align-content: start;
  min-height: 270px;
  padding: 22px;
}
.surface-mini {
  align-self: end;
  background: var(--paper);
  border: 1px solid var(--divider);
  border-radius: 8px;
  margin-top: 18px;
  padding: 12px;
}
.surface-mini b {
  color: var(--ink-navy);
  display: block;
  font-family: var(--font-mono);
  font-size: 18px;
}
.surface-mini small {
  color: var(--slate-700);
  display: block;
  line-height: 1.45;
  margin-top: 2px;
}

.liability-report-card { padding: 18px; }
.liability-table {
  border: 1px solid var(--divider);
  border-radius: 8px;
  overflow: hidden;
}
.liability-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px 120px;
  border-bottom: 1px solid var(--slate-200);
}
.liability-row:last-child { border-bottom: none; }
.liability-row span,
.liability-row b,
.liability-row em {
  border-right: 1px solid var(--slate-200);
  padding: 11px 12px;
}
.liability-row em {
  border-right: none;
  color: var(--green-cool-70);
  font-style: normal;
  font-weight: 800;
}
.liability-row b {
  color: var(--ink-navy);
  font-family: var(--font-mono);
  font-weight: 800;
  text-align: right;
}
.liability-head {
  background: var(--green-cool-70);
  color: #fff;
  font-weight: 800;
}
.liability-head span {
  border-color: rgb(255 255 255 / 0.18);
}
.record-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0 0;
}
.record-links span {
  background: var(--gray-warm-2);
  border: 1px solid var(--divider);
  border-radius: 999px;
  color: var(--ink-navy);
  font-size: 13px;
  font-weight: 800;
  padding: 6px 10px;
}

.notice-packet {
  display: grid;
  grid-template-columns: minmax(260px, 0.6fr) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}
.notice-case {
  border-left: 6px solid var(--seal);
  padding: 24px;
}
.notice-case .kicker { margin-bottom: 12px; }
.packet-checklist {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.packet-checklist div {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 4px 12px;
  min-height: 112px;
  padding: 16px;
}
.packet-checklist span {
  align-self: start;
  background: var(--green-cool-70);
  border-radius: 50%;
  color: #fff;
  display: inline-grid;
  height: 34px;
  letter-spacing: 0;
  place-items: center;
  width: 34px;
}
.packet-checklist b {
  color: var(--ink-navy);
  display: block;
}
.packet-checklist small {
  color: var(--slate-700);
  grid-column: 2;
  line-height: 1.45;
}

.differentiator-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

.differentiator-grid article,
.lead-form,
.lead-aside,
.intake-card {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
}

.differentiator-grid article { padding: 22px; }
.differentiator-grid span {
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
}
.differentiator-grid h3 { margin: 12px 0 8px; font-size: 18px; line-height: 1.25; }
.differentiator-grid p { margin: 0; color: var(--slate-700); font-size: 14px; line-height: 1.6; }

.truth-box {
  margin-top: 22px;
  background: var(--green-cool-90);
  color: #fff;
  border-radius: 8px;
  padding: 26px;
}
.truth-box h3 { color: #fff; margin: 0 0 8px; }
.truth-box p { color: var(--gray-warm-10); max-width: 82ch; margin: 0; line-height: 1.65; }

.metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}
.metric-grid article {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  min-height: 230px;
  padding: 24px;
}
.metric-grid span {
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 12.5px;
  font-weight: 800;
}
.metric-grid h3 {
  color: var(--ink-navy);
  font-size: 20px;
  line-height: 1.2;
  margin: 10px 0 8px;
}
.metric-grid p {
  color: var(--slate-700);
  font-size: 15px;
  margin: 0;
}

.review-hero-card,
.review-provider-card {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  padding: 22px;
}
.review-verdict {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-left: 5px solid var(--seal);
  border-radius: 8px;
  margin: 16px 0;
  padding: 18px;
}
.review-verdict span {
  color: var(--seal);
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.review-verdict b {
  color: var(--ink-navy);
  display: block;
  font-size: 24px;
  line-height: 1.2;
  margin: 8px 0;
}
.review-verdict p {
  color: var(--slate-700);
  margin: 0;
}
.review-case-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.review-case-grid article {
  background: var(--paper);
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 20px;
  min-height: 220px;
}
.review-case-grid span {
  color: var(--seal);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
}
.review-case-grid h3 {
  color: var(--ink-navy);
  font-size: 19px;
  line-height: 1.25;
  margin: 14px 0 8px;
}
.review-case-grid p {
  color: var(--slate-700);
  font-size: 14.5px;
  line-height: 1.6;
  margin: 0;
}

.lead-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(280px, 0.7fr);
  gap: 28px;
  align-items: start;
}
.lead-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  padding: 26px;
}
.lead-form .full { grid-column: 1 / -1; }
.lead-form label { display: block; font-weight: 800; margin-bottom: 7px; }
.lead-form h2 { color: var(--ink-navy); margin: 0 0 8px; }
.lead-form p { color: var(--slate-700); margin: 0; }
.lead-form input,
.lead-form select,
.lead-form textarea {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--slate-300);
  border-radius: 6px;
  padding: 11px 12px;
  font: inherit;
  background: #fff;
  color: var(--ink);
}
.lead-form textarea { resize: vertical; }
.checkbox-line {
  align-items: flex-start;
  color: var(--slate-700);
  display: flex;
  gap: 10px;
  line-height: 1.45;
}
.checkbox-line input {
  flex: 0 0 auto;
  margin-top: 5px;
  width: auto;
}
.lead-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.lead-contact-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
}
.lead-contact-card h2,
.lead-contact-card p {
  margin: 0;
}
.pricing-included-ledger { margin: 32px 0; }
.form-note {
  grid-column: 1 / -1;
  color: var(--slate-700);
  font-size: 13px;
  line-height: 1.55;
  margin: 0;
}
.lead-aside,
.intake-card { padding: 26px; }
.lead-aside h2,
.intake-card h2 { margin-top: 0; color: var(--ink-navy); }
.intake-card ol { margin: 0; padding-left: 20px; color: var(--slate-700); line-height: 1.65; }
.check-list { display: grid; gap: 10px; margin: 16px 0 24px; }
.check-list span {
  border-left: 4px solid var(--green-cool-60);
  background: var(--paper);
  padding: 10px 12px;
  font-weight: 800;
}

.proof-steps {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin-top: 24px;
}
.proof-steps .step,
.proof-steps > article {
  background: #fff;
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 16px 14px;
  min-height: 150px;
}
.proof-steps .step span,
.proof-steps > article span {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--green-cool-70);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
}
.proof-steps .step h3,
.proof-steps > article h3 { margin: 14px 0 8px; font-size: 16px; line-height: 1.25; }
.proof-steps .step p,
.proof-steps > article p { margin: 0; color: var(--slate-700); font-size: 13.5px; line-height: 1.55; }

.resources-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 0.72fr); gap: 42px; align-items: start; }
.resource-list { display: grid; gap: 10px; }
.resource-list a {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  text-decoration: none;
  background: var(--paper);
  border: 1px solid var(--divider);
  border-radius: 8px;
  padding: 14px 16px;
  color: var(--color-ink);
  font-weight: 700;
}
.resource-list span { color: var(--seal); font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; }

.award-strip {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 160px;
  gap: 32px;
  align-items: center;
  border: 1px solid var(--divider);
  background: #fff;
  border-radius: 8px;
  padding: 28px;
}
.award-strip h2 { font-size: 26px; line-height: 1.2; margin: 12px 0 10px; }
.award-strip p { color: var(--slate-700); margin: 0; }
.award-strip .disclosure-note {
  color: var(--gray);
  font-size: 14px;
  margin-top: 10px;
}
.award-mark {
  display: grid;
  place-items: center;
  aspect-ratio: 1;
  border: 3px double var(--seal);
  color: var(--ink-navy);
  font-family: var(--font-mono);
  font-size: 28px;
  font-weight: 700;
  text-align: center;
}
.award-mark span { color: var(--seal); font-size: 15px; }
.logo-mark {
  align-content: center;
  background: var(--paper);
  gap: 8px;
  padding: 16px;
}
.logo-mark img {
  display: block;
  height: auto;
  max-width: 86px;
  width: 100%;
}
.logo-mark span {
  color: var(--ink-navy);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 1.35;
  text-transform: uppercase;
}

.pricing-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin: 32px 0; }
.pricing-grid-four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.price-card { border: 1px solid var(--divider); border-radius: 8px; background: #fff; padding: 22px; }
.price-card.emphasized { border-color: var(--seal); box-shadow: var(--shadow-card); }
.price-card h2 { margin: 14px 0 8px; font-size: 22px; }
.price-card .price { font-family: var(--font-mono); font-size: 26px; font-weight: 700; color: var(--ink-navy); margin: 0 0 12px; }
.price-card p:not(.price) { color: var(--slate-700); font-size: 14.5px; line-height: 1.6; }

/* Ledger demo table */
.ledger { background: #fff; border: 1px solid var(--divider); border-radius: 8px; overflow: hidden; }
.ledger .row { display: flex; gap: 14px; padding: 11px 16px; border-bottom: 1px solid var(--slate-200); align-items: baseline; font-size: 14px; }
.ledger .row:last-child { border-bottom: none; }
.ledger .date { font-family: var(--font-mono); font-size: 11.5px; color: var(--gray); width: 88px; flex-shrink: 0; }
.ledger .type { font-family: var(--font-mono); font-size: 11.5px; color: var(--seal); width: 150px; flex-shrink: 0; }
.ledger .amt { font-family: var(--font-mono); margin-left: auto; white-space: nowrap; }
.ledger .total { font-weight: 700; }
.ledger .total .amt { border-top: 1.5px solid var(--seal); border-bottom: 1.5px solid var(--seal); padding: 1px 0; }
.cite { font-size: 12px; color: var(--gray); padding: 10px 16px; background: var(--gray-warm-2); border-top: 1px solid var(--slate-200); }
.cite .mono { font-size: 11px; }

/* Quote / heritage */
.heritage { text-align: center; padding: 72px 24px; }
.heritage p { font-size: 20px; line-height: 1.6; max-width: 46ch; margin: 0 auto 14px; }
.heritage .rule { width: 120px; border-top: 2px solid var(--seal); border-bottom: 2px solid var(--seal); height: 5px; margin: 22px auto 0; }
.heritage .who { font-size: 13px; color: var(--gray); }

/* CTA band */
.cta-band { text-align: center; padding: 72px 0; }
.cta-band h2 { font-size: 32px; margin: 0 0 10px; letter-spacing: 0; }
.cta-band p { color: var(--slate-700); margin: 0 0 26px; }

/* Footer */
footer { border-top: 1px solid var(--divider); padding: 44px 0 56px; background: #fff; }
.foot { display: flex; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.foot nav { display: flex; gap: 40px; flex-wrap: wrap; }
.foot nav div { display: flex; flex-direction: column; gap: 8px; }
.foot nav b { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray); margin-bottom: 2px; }
.foot nav a { font-size: 13.5px; color: var(--color-ink); text-decoration: none; }
.foot nav a:hover { text-decoration: underline; }
.foot .legalese { font-size: 12px; color: var(--gray); margin-top: 28px; line-height: 1.7; max-width: 72ch; }
.noted { font-size: 13px; font-weight: 600; color: var(--color-ink); margin-top: 10px; }

.mega-footer { background: var(--green-cool-90); color: #fff; padding: 64px 0 42px; }
.mega-footer .wordmark b { color: #fff; }
.mega-footer .foot-brand,
.footer-topline {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
  border-bottom: 1px solid rgb(255 255 255 / 0.18);
  padding-bottom: 28px;
  margin-bottom: 30px;
}
.mega-footer .foot-brand p,
.footer-topline p { color: var(--gray-warm-10); margin: 0; max-width: 56ch; }
.verify-link { color: #fff; font-weight: 700; }
.mega-grid,
.footer-directory { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 42px; }
.mega-grid div,
.footer-directory section { display: flex; flex-direction: column; gap: 8px; }
.mega-grid b,
.footer-directory h2 {
  color: var(--gray-warm-20);
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 26px 0 4px;
}
.mega-grid b:first-child,
.footer-directory h2:first-child { margin-top: 0; }
.mega-grid a,
.footer-directory a { color: #fff; text-decoration: none; font-size: 14px; line-height: 1.35; opacity: 0.9; }
.mega-grid a:hover,
.footer-directory a:hover { opacity: 1; text-decoration: underline; }
.talk-shop {
  display: grid;
  grid-template-columns: minmax(220px, 0.6fr) minmax(0, 1fr);
  gap: 42px;
  border-top: 1px solid rgb(255 255 255 / 0.24);
  margin-top: 44px;
  padding-top: 30px;
}
.talk-shop h2 {
  color: #fff;
  font-size: 18px;
  line-height: 1.25;
  margin: 0 0 8px;
}
.talk-shop p { color: var(--gray-warm-20); margin: 0; line-height: 1.6; }
.talk-shop nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px 28px;
}
.talk-shop a { color: #fff; text-decoration: none; opacity: 0.9; }
.talk-shop a:hover { opacity: 1; text-decoration: underline; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  border-top: 1px solid rgb(255 255 255 / 0.24);
  margin-top: 34px;
  padding-top: 22px;
}
.footer-bottom p { margin: 0; color: #fff; font-weight: 700; }
.footer-bottom nav { display: flex; gap: 16px; flex-wrap: wrap; justify-content: flex-end; }
.footer-bottom a { color: var(--gray-warm-10); text-decoration: none; font-size: 13px; }
.footer-bottom a:hover { text-decoration: underline; }
.mega-footer .legalese { color: var(--gray-warm-20); font-size: 12px; line-height: 1.7; max-width: 92ch; margin: 22px 0 0; }

/* Prose pages (about, legal) */
.prose { padding: 56px 0 80px; }
.prose h1 { font-size: 36px; letter-spacing: 0; margin: 0 0 8px; }
.prose .updated { font-size: 12.5px; color: var(--gray); margin-bottom: 30px; }
.prose h2 { font-size: 21px; margin: 36px 0 10px; }
.prose p, .prose li { font-size: 15.5px; line-height: 1.75; color: var(--color-ink); }
.prose .notice {
  padding: 12px 16px; background: var(--gold-5v); border-left: 0.5rem solid var(--color-warning);
  border-radius: 4px; font-size: 13.5px; color: var(--slate-700); margin: 18px 0;
}

/* Type scale lift: Safari renders the dense payroll UI too small at the old
   12-14px defaults. Keep display type stable while making operational copy readable. */
.topbar nav a { font-size: 15px; }
.topbar nav a span { font-size: 13px; }
.btn { font-size: 16px; }
.kicker,
.eyebrow,
.promise-strip,
.status,
.proof-head span,
.proof-checks span,
.module-card b,
.persona-grid span,
.proof-card span,
.payroll-roadmap span,
.proof-steps .step span,
.proof-steps > article span,
.resource-list span,
.ledger .date,
.ledger .type {
  font-size: 12.5px;
}
.hero-proof-points span,
.announcement,
.demo-accordion a,
.text-link,
.quote-band a,
.more-tiles span,
.answers-grid a,
.footer-bottom a,
.noted,
.heritage .who {
  font-size: 14px;
}
.payroll-summary span,
.run-list span,
.task-board small,
.mock-note,
.proof-panel p,
.cite,
.foot .legalese,
.mega-footer .legalese,
.prose .updated {
  font-size: 13.5px;
}
.task-board b,
.answers-grid p,
.proof-steps .step p,
.proof-steps > article p,
.prose .notice {
  font-size: 14.5px;
}
.card p,
.module-card p,
.support-grid span,
.compare-row span,
.ledger .row,
.footer-directory a,
.mega-grid a,
.foot nav a,
.trust-signal-grid span {
  font-size: 15px;
}
.demo-accordion p,
.benefit-panel span,
.faq-list p,
.feature p,
.stacked-list span,
.persona-grid p,
.price-card p:not(.price),
.prose p,
.prose li {
  font-size: 16px;
}
p.sub { font-size: 17px; }
.hero p.lede { font-size: 20px; }
.demo-accordion h3,
.answers-grid h3,
.card h3,
.proof-card b,
.setup-steps h3 {
  font-size: 18px;
}

@media (max-width: 920px) {
  .topbar { align-items: flex-start; }
  .topbar nav { gap: 12px; }
  .hero-grid, .hero-payroll, .resources-layout, .award-strip, .split-feature, .split-feature.reverse, .demo-layout, .setup-layout, .trust-signal, .lead-layout, .record-demo, .notice-packet { grid-template-columns: 1fr; }
  .homepage-hero { min-height: auto; }
  .hero-visual { min-height: auto; display: grid; gap: 18px; }
  .hero-visual .product-shell { position: static; }
  .section-head { display: block; }
  .section-head .title { max-width: none; }
  .status-strip, .feature-grid, .pricing-grid, .mega-grid, .footer-directory, .module-grid, .persona-grid, .support-grid, .more-tiles, .answers-grid, .trust-signal-grid.wide, .differentiator-grid, .metric-grid, .review-case-grid, .record-flow, .surface-grid, .packet-checklist { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .proof-steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .promise-strip { flex-wrap: wrap; justify-content: flex-start; }
  .trust-ribbon .promise-strip { justify-content: flex-start; gap: 14px 22px; }
  .talk-shop { grid-template-columns: 1fr; }
  .talk-shop nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer-bottom { align-items: flex-start; display: grid; grid-template-columns: 1fr; }
  .footer-bottom nav { justify-content: flex-start; }
  .compare-row { grid-template-columns: 1fr; }
  .compare-row span { border-right: none; border-bottom: 1px solid var(--slate-200); }
  .compare-row span:last-child { border-bottom: none; }
  .benchmark-grid { grid-template-columns: 1fr; gap: 20px; }
  .benchmark-grid div { border-right: none; border-bottom: 1px solid rgb(255 255 255 / 0.25); padding: 0 0 20px; }
  .benchmark-grid div:last-child { border-bottom: none; padding-bottom: 0; }
}

@media (max-width: 620px) {
  body:has(.floating-nav) { padding-top: 206px; }
  .wrap { padding: 0 18px; }
  .announcement .wrap { flex-direction: column; gap: 2px; padding-top: 8px; padding-bottom: 8px; }
  .topbar { display: block; margin-top: 0; top: 12px; padding: 12px; width: calc(100vw - 36px); }
  .topbar nav { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; margin-top: 14px; width: 100%; max-width: none; }
  .topbar nav a { text-align: center; font-size: 13px; padding: 6px 4px; }
  .topbar nav a span { display: none; }
  .topbar nav .btn { grid-column: 1 / 3; width: 100%; text-align: center; padding: 10px 12px; }
  .topbar nav .signin-link { grid-column: 3; width: 100%; text-align: center; align-self: center; }
  .hero { padding: 42px 0 44px; }
  .hero h1 { font-size: 34px; max-width: none; overflow-wrap: anywhere; }
  .homepage-hero h1 { font-size: 38px; }
  .hero-payroll { gap: 30px; }
  .hero-grid > *, .hero-payroll > *, .hero-proof-column, .photo-card, .proof-panel, .product-shell, .review-hero-card, .review-provider-card, .status-strip, .feature-grid, .pricing-grid, .milestone-grid, .proof-steps, .module-grid, .persona-grid, .support-grid, .payroll-roadmap, .mega-grid, .footer-directory, .talk-shop, .footer-bottom, .demo-layout, .more-tiles, .answers-grid, .setup-layout, .benefit-panel, .trust-signal, .trust-signal-grid, .differentiator-grid, .lead-layout, .metric-grid, .review-case-grid, .record-demo, .record-flow, .record-panel, .surface-grid, .liability-report-card, .notice-packet, .packet-checklist { max-width: 354px; }
  .hero p.lede { font-size: 18px; }
  .hero-scene { min-height: 240px; }
  .scene-roster { left: 18px; right: 18px; bottom: 28px; }
  .scene-roster span { width: 42px; height: 104px; }
  .scene-roster span:nth-child(2) { height: 124px; }
  .scene-roster span:nth-child(3) { height: 92px; }
  .scene-roster span:nth-child(4) { height: 112px; }
  .scene-card { left: 14px; right: 14px; top: 14px; }
  .btn { width: 100%; text-align: center; }
  .hero-actions { display: grid; grid-template-columns: 1fr; gap: 10px; margin: 22px 0 18px; }
  .hero-proof-points { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
  .hero-proof-points span { display: flex; align-items: center; justify-content: center; min-height: 38px; text-align: center; font-size: 13px; line-height: 1.2; padding: 8px 10px; }
  .payroll-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .task-board div { grid-template-columns: 10px minmax(0, 1fr); }
  .task-board small { grid-column: 2; }
  .phone-preview { width: 100%; min-height: 380px; }
  .quote-band blockquote { font-size: 22px; }
  .status-strip, .feature-grid, .pricing-grid, .milestone-grid, .proof-steps, .module-grid, .persona-grid, .support-grid, .mega-grid, .footer-directory, .talk-shop nav, .more-tiles, .answers-grid, .trust-signal-grid, .trust-signal-grid.wide, .differentiator-grid, .lead-form, .metric-grid, .review-case-grid, .record-flow, .surface-grid, .record-status, .packet-checklist { grid-template-columns: 1fr; }
  .lead-form .full { grid-column: auto; }
  .proof-checks { grid-template-columns: 1fr; }
  .proof-head { display: grid; grid-template-columns: 1fr; gap: 6px; }
  .proof-row { display: grid; grid-template-columns: 1fr; gap: 3px; }
  .proof-row b { text-align: left; }
  .run-list div { display: grid; grid-template-columns: 1fr; gap: 3px; }
  .run-list b { white-space: normal; }
  .liability-row { grid-template-columns: 1fr; }
  .liability-row span,
  .liability-row b,
  .liability-row em {
    border-right: none;
    border-bottom: 1px solid var(--slate-200);
    text-align: left;
  }
  .liability-row em { border-bottom: none; }
  .packet-checklist div { grid-template-columns: 1fr; }
  .packet-checklist small { grid-column: auto; }
  .module-card, .persona-grid article { min-height: auto; }
  .payroll-roadmap div { grid-template-columns: 1fr; }
  .payroll-roadmap span { grid-row: auto; }
  .setup-steps article { grid-template-columns: 1fr; }
  .setup-steps span { grid-row: auto; }
  .ledger .row { display: grid; grid-template-columns: 1fr; gap: 4px; }
  .ledger .date, .ledger .type { width: auto; }
  .ledger .amt { margin-left: 0; }
  .mega-footer .foot-brand,
  .footer-topline { display: block; }
  .mega-footer .foot-brand p,
  .footer-topline p { margin: 12px 0; }
}
