/* ===========================================================
   StateLicensure marketing site
   Tokens: per handoff
   Aesthetic: NEJM × Bloomberg terminal — clinical, dense, data-forward
   =========================================================== */

:root {
  --bg: #f7f7f5;
  --bg-sunken: #efefec;
  --surface: #ffffff;
  --ink: #111110;
  --ink-2: #44443f;
  --ink-3: #76766f;
  --ink-4: #a8a8a0;
  --border: #e5e5e2;
  --border-strong: #d4d4cf;
  --accent: #4338ca;
  --accent-ink: #312e81;
  --accent-tint: #ecebfb;
  --ok: #166534;
  --warn: #92400e;
  --risk: #9f1239;
  --ok-tint: #dcf0e1;
  --warn-tint: #fbeacd;
  --risk-tint: #fbe0e6;

  --serif: "Newsreader", "Source Serif Pro", Georgia, serif;
  --sans: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;
  --mono: "Geist Mono", "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

/* ---------- Layout ---------- */
.wrap {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 32px;
}
.wrap-narrow {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 32px;
}

/* ---------- Top ticker ---------- */
.ticker {
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  overflow: hidden;
}
.ticker-inner {
  display: flex;
  gap: 40px;
  padding: 7px 32px;
  white-space: nowrap;
  animation: tickerScroll 60s linear infinite;
}
.ticker-item { display: inline-flex; gap: 8px; align-items: baseline; }
.ticker-item .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--ok); display: inline-block; transform: translateY(-1px); }
.ticker-item .dot.warn { background: var(--warn); }
.ticker-item .dot.risk { background: var(--risk); }
.ticker-item b { color: var(--ink); font-weight: 500; }
@keyframes tickerScroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ---------- Nav ---------- */
.nav {
  border-bottom: 1px solid var(--border);
  background: rgba(247, 247, 245, 0.85);
  backdrop-filter: blur(10px);
  position: sticky;
  top: 0;
  z-index: 50;
}
.nav-inner {
  display: flex;
  align-items: center;
  height: 76px;
  gap: 40px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  letter-spacing: -0.01em;
  font-size: 18px;
}
.brand-mark {
  width: 32px;
  height: 32px;
  display: block;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
}
.brand-mark img { width: 100%; height: 100%; display: block; }
.nav-links {
  display: flex;
  gap: 32px;
  font-size: 15px;
  color: var(--ink-2);
}
.nav-links a {
  position: relative;
  padding: 4px 0;
  cursor: pointer;
}
.nav-links a:hover { color: var(--ink); }
.nav-links a.active { color: var(--ink); }
.nav-links a.active::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -30px;
  height: 2px;
  background: var(--ink);
}
.nav .btn {
  padding: 10px 18px;
  font-size: 14.5px;
}
.nav-spacer { flex: 1; }
.nav-right { display: flex; align-items: center; gap: 18px; font-size: 15px; }
.nav-right .signin { color: var(--ink); cursor: pointer; font-weight: 600; }
.nav-right .signin:hover { color: var(--accent); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px;
  border-radius: 6px;
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 120ms, border-color 120ms, transform 60ms;
  background: none;
  color: inherit;
  white-space: nowrap;
}
.btn-primary {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
  font-weight: 600;
}
.btn-primary:hover { background: var(--accent-ink); border-color: var(--accent-ink); }
.btn-primary:active { transform: translateY(1px); }
.btn-ghost { color: var(--ink); }
.btn-ghost:hover { background: var(--bg-sunken); }
.btn-outline { border-color: var(--border-strong); background: var(--surface); color: var(--ink); font-weight: 600; }
.btn-outline:hover { border-color: var(--ink); }
.btn-lg { padding: 12px 20px; font-size: 14px; }
.btn .arr { font-family: var(--mono); margin-left: 2px; opacity: 0.8; }

/* ---------- Type ---------- */
h1, h2, h3 { font-family: var(--serif); font-weight: 400; letter-spacing: -0.02em; color: var(--ink); margin: 0; line-height: 1.08; }
h1 { font-size: 64px; }
h2 { font-size: 40px; }
h3 { font-size: 22px; letter-spacing: -0.015em; }
.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.lede { font-size: 18px; color: var(--ink-2); line-height: 1.5; max-width: 60ch; }
.muted { color: var(--ink-3); }
.serif-em { font-family: var(--serif); font-style: italic; font-weight: 400; }
.mono { font-family: var(--mono); }

/* ---------- Hero ---------- */
.hero {
  padding: 80px 0 56px;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 56px;
  align-items: center;
}
.hero h1 .accent { color: var(--accent); }
.hero .lede { margin-top: 22px; }
.hero-ctas { margin-top: 32px; display: flex; gap: 12px; align-items: center; }
.hero-meta {
  margin-top: 32px;
  display: flex;
  gap: 28px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.hero-meta b { color: var(--ink); font-weight: 500; }

/* ---------- Dashboard preview ---------- */
.preview {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 1px 0 rgba(17, 17, 16, 0.02), 0 20px 60px -30px rgba(17, 17, 16, 0.18);
  overflow: hidden;
  font-size: 13px;
}
.preview-chrome {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}
.preview-dots { display: flex; gap: 5px; }
.preview-dots span { width: 9px; height: 9px; border-radius: 50%; background: var(--border-strong); }
.preview-url {
  flex: 1;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-3);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 3px 10px;
  text-align: center;
}
.preview-body { padding: 18px 18px 22px; }
.preview-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.preview-toolbar h4 { font-family: var(--serif); font-size: 18px; margin: 0; font-weight: 500; }
.preview-toolbar .sub { font-family: var(--mono); font-size: 11px; color: var(--ink-3); margin-top: 2px; letter-spacing: 0.04em; }
.preview-chips { display: flex; gap: 6px; font-family: var(--mono); font-size: 10.5px; }
.chip {
  border: 1px solid var(--border);
  padding: 4px 8px;
  border-radius: 4px;
  color: var(--ink-2);
  background: var(--bg);
}
.chip.active { background: var(--ink); color: var(--bg); border-color: var(--ink); }

.preview-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.preview-table th {
  text-align: left;
  font-family: var(--mono);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding: 8px 8px;
  border-bottom: 1px solid var(--border);
}
.preview-table th.num { text-align: right; }
.preview-table td {
  padding: 11px 8px;
  border-bottom: 1px solid var(--border);
  font-family: var(--mono);
  font-size: 12px;
  vertical-align: middle;
}
.preview-table tr:last-child td { border-bottom: 0; }
.preview-table td.state { font-family: var(--sans); color: var(--ink); font-weight: 500; font-size: 13px; }
.preview-table td.num { text-align: right; color: var(--ink-2); }
.preview-table td.lic { letter-spacing: 0.04em; color: var(--ink-2); }
.status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.status .pill {
  width: 7px; height: 7px; border-radius: 50%;
}
.status.ok { color: var(--ok); }
.status.ok .pill { background: var(--ok); }
.status.warn { color: var(--warn); }
.status.warn .pill { background: var(--warn); }
.status.risk { color: var(--risk); }
.status.risk .pill { background: var(--risk); }

.preview-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed var(--border);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.preview-footer .blink {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--ok);
  margin-right: 6px;
  animation: blink 1.6s ease-in-out infinite;
}
@keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0.35; } }

/* ---------- Social proof strip ---------- */
.proof {
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.proof-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: stretch;
}
.proof-cell {
  padding: 28px 32px;
  border-left: 1px solid var(--border);
}
.proof-cell:first-child { border-left: 0; }
.proof-num {
  font-family: var(--serif);
  font-size: 44px;
  letter-spacing: -0.03em;
  color: var(--ink);
  line-height: 1;
}
.proof-num .unit { font-family: var(--mono); font-size: 13px; color: var(--ink-3); margin-left: 4px; letter-spacing: 0; }
.proof-label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 10px;
}

/* ---------- Section ---------- */
.section {
  padding: 88px 0;
  border-bottom: 1px solid var(--border);
}
.section-head { margin-bottom: 48px; max-width: 720px; }
.section-head .eyebrow { margin-bottom: 14px; display: block; }
.section-head h2 + .lede { margin-top: 18px; }

/* ---------- Features ---------- */
.features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.features-4 {
  grid-template-columns: repeat(2, 1fr);
}
.features-4 .feature {
  border-bottom: 1px solid var(--border);
}
.features-4 .feature:nth-child(3),
.features-4 .feature:nth-child(4) {
  border-bottom: 0;
}
.features-4 .feature p {
  min-height: 4.5em;
}
/* 5th card spans full width */
.features-4 .feature:nth-child(5) {
  grid-column: 1 / -1;
  border-bottom: 0;
}
.feature {
  padding: 36px 32px 40px;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
.feature:last-child { border-right: 0; }
.feature .ix {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
  color: var(--ink-3);
}
.feature h3 { font-size: 26px; }
.feature p { color: var(--ink-2); font-size: 14.5px; line-height: 1.55; margin: 0; }
.feature .ftag {
  margin-top: auto;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  text-transform: uppercase;
  padding-top: 22px;
}
.feature .mini {
  margin-top: 4px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 14px;
  font-family: var(--mono);
  font-size: 11.5px;
  color: var(--ink-2);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.feature .mini .row { display: flex; justify-content: space-between; align-items: center; }
.feature .mini .row span:first-child { color: var(--ink); }
.feature .mini .row b { font-weight: 500; color: var(--ink); }

/* ---------- How it works ---------- */
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.step { position: relative; padding-top: 28px; border-top: 2px solid var(--ink); }
.step .num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--ink-3);
  margin-bottom: 8px;
}
.step h3 { font-size: 24px; margin-bottom: 12px; }
.step p { color: var(--ink-2); margin: 0; font-size: 14.5px; }

/* ---------- Pricing strip ---------- */
.pricing-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr) auto;
  align-items: stretch;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  overflow: hidden;
}
.pricing-strip-4 {
  grid-template-columns: repeat(4, 1fr);
}
.pricing-strip-4 .col:last-child { display: block; background: var(--surface); padding: 28px 24px; }
.pricing-strip .col {
  padding: 28px 28px 28px;
  border-right: 1px solid var(--border);
}
.pricing-strip .col:last-child { border-right: 0; display: flex; flex-direction: column; justify-content: center; padding: 28px; gap: 10px; background: var(--bg); }
.pricing-strip .plan { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.pricing-strip .price { font-family: var(--serif); font-size: 36px; letter-spacing: -0.02em; margin-top: 4px; }
.pricing-strip .price .per { font-family: var(--mono); font-size: 12px; color: var(--ink-3); margin-left: 4px; letter-spacing: 0; }
.pricing-strip .meta { font-size: 13px; color: var(--ink-2); margin-top: 8px; }

.cta-band {
  padding: 40px 0 48px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-sunken);
  color: var(--ink);
  position: relative;
  overflow: hidden;
}
.cta-band h2 { color: var(--ink); font-size: 28px; max-width: none; letter-spacing: -0.018em; }
.cta-band .lede { color: var(--ink-3); margin-top: 10px; font-size: 15px; }
.cta-band .hero-ctas { margin-top: 20px; }
.cta-band .btn-outline { background: var(--surface); color: var(--ink); border-color: var(--border-strong); }
.cta-band .btn-outline:hover { border-color: var(--ink); background: var(--surface); }
.cta-band .grid-bg {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(17,17,16,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(17,17,16,0.04) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse at right, black, transparent 70%);
}
.cta-band-inner { position: relative; }
.cta-band .eyebrow { color: var(--ink-3) !important; }

/* ---------- Footer ---------- */
.foot {
  padding: 56px 0 40px;
  background: var(--bg);
}
.foot-top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--border);
}
.foot h5 {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  margin: 0 0 14px;
}
.foot ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 14px; color: var(--ink-2); }
.foot ul a { cursor: pointer; }
.foot ul a:hover { color: var(--ink); }
.foot-bottom {
  margin-top: 28px;
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  text-transform: uppercase;
}
.foot-disclaimer {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.04em;
  margin-top: 20px;
  padding: 14px;
  border: 1px dashed var(--border-strong);
  border-radius: 6px;
  background: var(--bg);
}

/* ---------- Pricing page ---------- */
.price-hero {
  padding: 80px 0 64px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.price-hero h1 { font-size: 64px; text-wrap: balance; }
.price-hero .lede { margin-top: 22px; max-width: 72ch; }

.price-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  background: var(--surface);
}
.price-card {
  padding: 32px 24px 36px;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
}
.price-card:last-child { border-right: 0; }
.price-card.featured {
  background: var(--ink);
  color: var(--bg);
}
.price-card.featured h3, .price-card.featured .price { color: var(--bg); }
.price-card.featured .feat-tag { color: var(--bg); }
.price-card.featured ul li { color: rgba(247,247,245,0.85); }
.price-card.featured ul li::before { color: var(--bg); }
.price-card.featured .price-meta { color: rgba(247,247,245,0.6); }
.price-card.featured .btn-outline { background: transparent; color: var(--bg); border-color: rgba(247,247,245,0.3); }
.price-card.featured .btn-outline:hover { border-color: var(--bg); }
.price-card.featured .btn-primary { background: var(--bg); color: var(--ink); border-color: var(--bg); }
.price-card.featured .btn-primary:hover { background: white; border-color: white; }

.price-card .plan-name {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.price-card.featured .plan-name { color: rgba(247,247,245,0.5); }
.price-card .price {
  font-family: var(--serif);
  font-size: 48px;
  letter-spacing: -0.025em;
  margin-top: 14px;
  line-height: 1;
}
.price-card .price .per { font-family: var(--mono); font-size: 13px; color: var(--ink-3); margin-left: 6px; letter-spacing: 0; }
.price-card.featured .price .per { color: rgba(247,247,245,0.5); }
.price-card .price-meta { margin-top: 10px; font-size: 13px; color: var(--ink-3); }
.price-card h3 { margin-top: 22px; font-size: 22px; }
.price-card ul {
  list-style: none; padding: 0; margin: 22px 0 28px;
  display: flex; flex-direction: column; gap: 11px;
  font-size: 14px; color: var(--ink-2);
}
.price-card ul li {
  position: relative;
  padding-left: 22px;
  line-height: 1.5;
}
.price-card ul li::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
  font-family: var(--mono);
}
.price-card .cta { margin-top: auto; }

.compare {
  margin-top: 56px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  overflow: hidden;
}
.compare table { width: 100%; border-collapse: collapse; }
.compare th, .compare td { padding: 14px 20px; text-align: left; font-size: 14px; border-bottom: 1px solid var(--border); }
.compare th {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  background: var(--bg);
}
.compare th:not(:first-child), .compare td:not(:first-child) { text-align: center; }
.compare td:first-child { color: var(--ink); font-weight: 500; }
.compare td:not(:first-child) { font-family: var(--mono); font-size: 13px; color: var(--ink-2); }
.compare .check { color: var(--ok); }
.compare .dash { color: var(--ink-4); }
.compare tr:last-child td { border-bottom: 0; }

.faq { margin-top: 56px; }
.faq-row {
  border-bottom: 1px solid var(--border);
}
.faq-row:first-child { border-top: 1px solid var(--border); }
.faq-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 22px 0;
  cursor: pointer;
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.faq-q .toggle {
  font-family: var(--mono);
  font-size: 14px;
  color: var(--ink-3);
  transition: transform 200ms;
}
.faq-row.open .faq-q .toggle { transform: rotate(45deg); }
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 260ms ease, padding 260ms ease;
  color: var(--ink-2);
  font-size: 15px;
  line-height: 1.6;
}
.faq-row.open .faq-a {
  max-height: 240px;
  padding: 0 0 22px;
}
.faq-a p { margin: 0 0 10px; }
.faq-a .cite {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 6px;
}

/* ---------- About ---------- */
.about-hero { padding: 88px 0 64px; border-bottom: 1px solid var(--border); }
.about-hero h1 { font-size: 64px; }
.about-hero .lede { margin-top: 24px; font-size: 20px; max-width: 72ch; }

.principles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.principle {
  padding: 36px 32px;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.principle:nth-child(2n) { border-right: 0; }
.principle:nth-last-child(-n+2) { border-bottom: 0; }
.principle .ix {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--ink-3);
}
.principle h3 { font-size: 22px; margin-top: 8px; }
.principle p { color: var(--ink-2); margin: 12px 0 0; font-size: 14.5px; }

.sources {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--border);
}
.source {
  padding: 28px 24px;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.source:last-child { border-right: 0; }
.source .code {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.06em;
}
.source .name {
  font-family: var(--serif);
  font-size: 20px;
  letter-spacing: -0.015em;
  color: var(--ink);
  line-height: 1.2;
}
.source .url {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.02em;
  margin-top: auto;
}

/* ---------- Legal ---------- */
.legal-hero { padding: 80px 0 40px; border-bottom: 1px solid var(--border); }
.legal-body { padding: 56px 0 80px; }
.legal-body h2 { font-size: 28px; margin-top: 40px; margin-bottom: 12px; }
.legal-body h2:first-child { margin-top: 0; }
.legal-body p, .legal-body li { font-size: 15px; color: var(--ink-2); line-height: 1.65; }
.legal-body p { margin: 0 0 14px; }
.legal-body ul { padding-left: 22px; margin: 0 0 14px; }
.legal-body li { margin-bottom: 8px; }
.legal-body .meta-line {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 32px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
}

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
  h1 { font-size: 44px; }
  h2 { font-size: 32px; }
  .hero { padding: 56px 0 40px; }
  .hero-grid, .features, .steps, .price-grid, .proof-inner, .principles, .sources, .pricing-strip { grid-template-columns: 1fr; }
  .feature, .principle, .source, .proof-cell, .pricing-strip .col { border-right: 0 !important; border-bottom: 1px solid var(--border); }
  .foot-top { grid-template-columns: 1fr 1fr; }
  .nav-links { display: none; }
}

/* ===========================================================
   Screenshot frames
   =========================================================== */
.ss-frame {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 4px 6px -1px rgba(17,17,16,0.06), 0 32px 80px -20px rgba(17,17,16,0.22);
  background: #fff;
}
.ss-frame img {
  width: 100%;
  display: block;
  margin: 0;
}
.ss-frame-sm img {
  width: 100%;
  display: block;
  margin: 0;
}
/* Legacy: screenshots with macOS chrome */
.ss-frame-chrome img {
  margin-top: -6%;
  margin-bottom: -32%;
}

/* ===========================================================
   Masthead (used by editorial / clinical variants)
   =========================================================== */
.masthead {
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.masthead-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 10px 32px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.masthead-inner .mh-mid { text-align: center; color: var(--ink); font-weight: 500; }
.masthead-inner span:last-child { text-align: right; }

/* ===========================================================
   DESIGN VARIANT 1 · Terminal (default) — no overrides
   =========================================================== */

/* ===========================================================
   DESIGN VARIANT 2 · Editorial — broadsheet
   =========================================================== */
.dz-editorial {
  --border-strong: #1f1f1c;
}
.dz-editorial .hero { padding: 96px 0 72px; }
.dz-editorial .hero h1 { font-size: 84px; line-height: 1.02; letter-spacing: -0.028em; }
.dz-editorial .hero-grid { grid-template-columns: 1fr; gap: 36px; }
.dz-editorial .hero-grid > div:first-child { max-width: 16ch; }
.dz-editorial .hero-grid > div:first-child .lede { max-width: 64ch; column-count: 2; column-gap: 32px; column-rule: 1px solid var(--border); font-size: 16.5px; }
.dz-editorial .hero-grid > div:last-child { margin-top: 24px; }
.dz-editorial .eyebrow {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-2);
}
.dz-editorial h1, .dz-editorial h2 { letter-spacing: -0.028em; font-weight: 400; }
.dz-editorial .section-head h2 { font-size: 56px; }
.dz-editorial .price-hero h1, .dz-editorial .about-hero h1 { font-size: 76px; }
.dz-editorial .nav { border-bottom: 2px solid var(--ink); }
.dz-editorial .nav-inner { height: 88px; }
.dz-editorial .brand { font-family: var(--serif); font-size: 26px; letter-spacing: -0.02em; }
.dz-editorial .feature { border-right: 1px solid var(--ink); }
.dz-editorial .feature:last-child { border-right: 0; }
.dz-editorial .features { border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink); }
.dz-editorial .step { border-top: 4px solid var(--ink); }
.dz-editorial .proof-num { font-size: 56px; }
.dz-editorial .price-card h3 { font-family: var(--serif); }
.dz-editorial .btn-primary { border-radius: 0; }
.dz-editorial .btn-outline, .dz-editorial .btn-ghost { border-radius: 0; }
.dz-editorial .preview { border-radius: 0; }
.dz-editorial .price-grid, .dz-editorial .compare, .dz-editorial .pricing-strip { border-radius: 0; }
.dz-editorial .price-card.featured { background: var(--ink); }
.dz-editorial .cta-band h2 { font-size: 64px; }

/* Drop-cap on first p in section-head lede on editorial */
.dz-editorial .about-hero .lede::first-letter,
.dz-editorial .price-hero .lede::first-letter {
  font-family: var(--serif);
  font-size: 64px;
  float: left;
  line-height: 0.9;
  margin: 4px 8px 0 0;
  color: var(--accent);
}

/* ===========================================================
   DESIGN VARIANT 3 · Swiss — neutral, structured, sans
   =========================================================== */
.dz-swiss {
  --bg: #fafafa;
  --bg-sunken: #f2f2f2;
  --serif: var(--sans);
  --border: #e7e7e4;
  --border-strong: #cfcfca;
}
.dz-swiss h1, .dz-swiss h2, .dz-swiss h3 {
  font-family: var(--sans);
  font-weight: 600;
  letter-spacing: -0.025em;
}
.dz-swiss h1 { font-weight: 500; letter-spacing: -0.035em; }
.dz-swiss .serif-em { font-style: normal; font-weight: 500; }
.dz-swiss .hero { padding: 96px 0 72px; }
.dz-swiss .hero h1 { font-size: 72px; line-height: 1; }
.dz-swiss .section { padding: 112px 0; }
.dz-swiss .section-head h2 { font-size: 48px; }
.dz-swiss .lede { font-size: 17px; }
.dz-swiss .preview { border-radius: 4px; box-shadow: none; }
.dz-swiss .btn { border-radius: 3px; }
.dz-swiss .btn-primary { font-weight: 600; }
.dz-swiss .features, .dz-swiss .pricing-strip, .dz-swiss .price-grid { border-radius: 4px; }
.dz-swiss .proof-num { font-family: var(--sans); font-weight: 500; }
.dz-swiss .proof-num .unit { font-weight: 400; }
.dz-swiss .feature { padding-top: 48px; }
.dz-swiss .feature::before {
  content: "";
  position: absolute;
  top: 0;
  left: 32px;
  right: 32px;
  height: 3px;
  background: var(--ink);
}
.dz-swiss .nav { background: rgba(250,250,250,0.9); }
.dz-swiss .price-hero h1, .dz-swiss .about-hero h1 { font-size: 64px; }
.dz-swiss .step { border-top-width: 3px; }
.dz-swiss .preview-table td.state { font-weight: 600; }

/* ===========================================================
   DESIGN VARIANT 4 · Mono — brutalist monospace
   =========================================================== */
.dz-mono {
  --bg: #f4f3ee;
  --bg-sunken: #ebe9e1;
  --surface: #fbfaf6;
  --border: #1f1f1c;
  --border-strong: #1f1f1c;
  --serif: var(--mono);
  --sans: var(--mono);
}
.dz-mono * { letter-spacing: 0 !important; }
.dz-mono h1, .dz-mono h2, .dz-mono h3 {
  font-family: var(--mono);
  font-weight: 500;
  letter-spacing: -0.02em !important;
  text-transform: none;
}
.dz-mono .serif-em { font-style: normal; font-weight: 500; text-decoration: underline; text-decoration-color: var(--accent); text-decoration-thickness: 3px; text-underline-offset: 6px; }
.dz-mono h1 { font-size: 56px; line-height: 1.04; }
.dz-mono h2 { font-size: 34px; }
.dz-mono .section-head h2 { font-size: 40px; }
.dz-mono .lede { font-family: var(--mono); font-size: 14px; line-height: 1.65; }
.dz-mono .nav { border-bottom-width: 2px; }
.dz-mono .nav-links a { font-family: var(--mono); font-size: 12.5px; }
.dz-mono .brand { font-family: var(--mono); }
.dz-mono .brand-mark { border-radius: 0; }
.dz-mono .btn { border-radius: 0; font-family: var(--mono); font-size: 12.5px; padding: 10px 16px; }
.dz-mono .btn-primary { border: 2px solid var(--accent); }
.dz-mono .btn-outline { border-width: 2px; }
.dz-mono .preview { border-radius: 0; border-width: 2px; box-shadow: 8px 8px 0 var(--ink); }
.dz-mono .features, .dz-mono .pricing-strip, .dz-mono .price-grid, .dz-mono .compare, .dz-mono .principles, .dz-mono .sources { border-radius: 0; border-width: 2px; }
.dz-mono .feature, .dz-mono .principle, .dz-mono .source, .dz-mono .pricing-strip .col, .dz-mono .price-card { border-right-width: 2px; }
.dz-mono .step { border-top: 4px solid var(--ink); }
.dz-mono .proof { border-bottom-width: 2px; }
.dz-mono .proof-cell { border-left-width: 2px; }
.dz-mono .proof-num { font-family: var(--mono); font-size: 36px; font-weight: 500; }
.dz-mono .eyebrow { font-family: var(--mono); }
.dz-mono .ticker { border-bottom-width: 2px; }
.dz-mono .cta-band h2 { font-size: 44px; }
.dz-mono .feature .mini { background: var(--surface); border-width: 2px; }
.dz-mono .foot-disclaimer { border-style: solid; border-width: 2px; }

/* ===========================================================
   DESIGN VARIANT 5 · Clinical — soft cream
   =========================================================== */
.dz-clinical {
  --bg: #faf6ed;
  --bg-sunken: #f1ecde;
  --surface: #fffdf6;
  --border: #e8e0cc;
  --border-strong: #d9cfb4;
  --ink: #1b1a14;
  --ink-2: #4a4538;
  --ink-3: #847c66;
  --ink-4: #b3aa90;
}
.dz-clinical h1, .dz-clinical h2, .dz-clinical h3 {
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.022em;
}
.dz-clinical h1 { font-size: 72px; line-height: 1.04; }
.dz-clinical .hero { padding: 104px 0 80px; }
.dz-clinical .section { padding: 104px 0; }
.dz-clinical .lede { font-size: 19px; line-height: 1.6; color: var(--ink-2); }
.dz-clinical .preview { border-radius: 16px; box-shadow: 0 1px 0 rgba(27,26,20,0.03), 0 30px 80px -40px rgba(27,26,20,0.2); }
.dz-clinical .btn { border-radius: 999px; padding: 11px 20px; }
.dz-clinical .btn-lg { padding: 13px 24px; }
.dz-clinical .features, .dz-clinical .pricing-strip, .dz-clinical .price-grid, .dz-clinical .compare { border-radius: 16px; }
.dz-clinical .feature .mini { border-radius: 12px; }
.dz-clinical .price-card.featured { background: var(--ink); border-radius: 0; }
.dz-clinical .price-grid .price-card:first-child { border-top-left-radius: 16px; border-bottom-left-radius: 16px; }
.dz-clinical .price-grid .price-card:last-child  { border-top-right-radius: 16px; border-bottom-right-radius: 16px; }
.dz-clinical .nav { background: rgba(250, 246, 237, 0.85); }
.dz-clinical .foot-disclaimer { border-radius: 12px; background: var(--bg-sunken); border-style: solid; }
.dz-clinical .preview-url { border-radius: 999px; padding: 4px 14px; }
.dz-clinical .step { border-top-width: 1px; border-top-color: var(--border-strong); padding-top: 32px; position: relative; }
.dz-clinical .step::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 56px;
  height: 3px;
  background: var(--accent);
}
.dz-clinical .cta-band { background: var(--bg-sunken); }

/* ===========================================================
   Variant interactions with components that exist in pages
   =========================================================== */
.dz-editorial .price-card,
.dz-editorial .feature {
  font-family: var(--sans);
}
.dz-editorial .feature h3,
.dz-editorial .price-card h3 { font-family: var(--serif); }

