/* =============================================================
   Medi marketing site — shared styles
   Loaded by every page in ui_kits/marketing/
   ============================================================ */
@import url('../../colors_and_type.css');

html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 24px;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; }

.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
}

.medi-public-shell .container {
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 28px;
  padding-right: 28px;
}

/* ---------- Top nav ---------- */
.topnav {
  position: sticky; top: 0; z-index: 50;
  background: oklch(0.99 0.003 85 / 0.85);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--border-faint);
}
.topnav-inner {
  display: flex;
  align-items: center;
  height: 64px;
  gap: 32px;
}
.topnav .brand {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 600; letter-spacing: -0.02em;
  font-size: 18px; color: var(--fg);
}
.topnav .brand .mark { width: 28px; height: 28px; }
.topnav nav { display: flex; gap: 24px; }
.topnav nav a {
  font-size: 14px;
  color: var(--fg-secondary);
  font-weight: 500;
  display: inline-flex; align-items: center; gap: 4px;
  transition: color 120ms var(--ease-out);
}
.topnav nav a:hover { color: var(--fg); }
.topnav .right { margin-left: auto; display: flex; align-items: center; gap: 16px; }
.signin {
  font-size: 14px; color: var(--fg-secondary); font-weight: 500;
}
.signin:hover { color: var(--fg); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  border-radius: var(--radius-md);
  padding: 8px 14px;
  font: 600 14px/1 var(--font-sans);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background-color 120ms var(--ease-out), border-color 120ms var(--ease-out), color 120ms var(--ease-out);
}
.btn-primary { background: var(--primary); color: var(--primary-fg); }
.btn-primary:hover { background: var(--primary-hover); }
.btn-secondary { background: var(--surface); color: var(--fg); border-color: var(--border); }
.btn-secondary:hover { background: var(--hover-tint); border-color: var(--border-strong); }
.btn-ghost { background: transparent; color: var(--fg); }
.btn-ghost:hover { background: var(--hover-tint); }
.btn-lg { padding: 11px 18px; font-size: 15px; }
.btn svg { width: 14px; height: 14px; }

/* ---------- Section primitives ---------- */
.section {
  padding: 80px 0;
  border-top: 1px solid var(--border-faint);
}
.section.flush { border-top: 0; }
.section-eyebrow {
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 16px;
  display: inline-flex; align-items: center; gap: 8px;
  /* Soft radial halo behind each character so the eyebrow reads cleanly
     against the cloud duotone underneath. Stacked text-shadows in the
     page background color make each glyph dissolve into a 28-30px
     pillow of bg, with no rectangular container. */
  text-shadow:
    0 0 8px var(--bg),
    0 0 18px var(--bg),
    0 0 30px var(--bg);
}
.section-eyebrow::before {
  content: ""; width: 18px; height: 1px; background: var(--primary);
}
.section-title {
  font-size: 40px; line-height: 46px;
  font-weight: 600; letter-spacing: -0.035em;
  color: var(--fg);
  max-width: 720px;
  margin: 0 0 16px;
  /* Same radial halo trick as .section-eyebrow — gives each letter a
     soft pillow of bg, so the title reads against the cloud duotone
     without needing a hard white container box. */
  text-shadow:
    0 0 10px var(--bg),
    0 0 24px var(--bg),
    0 0 44px var(--bg);
}
.section-lede {
  font-size: 18px; line-height: 28px;
  color: var(--fg-secondary);
  max-width: 640px;
  margin: 0;
}

.brand-statement {
  position: relative;
  padding: 42px 0 24px;
}
.brand-statement .container {
  display: grid;
  gap: 10px;
}
.brand-statement p {
  margin: 0;
  max-width: 720px;
  color: var(--fg-secondary);
  font-size: 17px;
  line-height: 27px;
  text-shadow:
    0 0 10px var(--bg),
    0 0 24px var(--bg),
    0 0 44px var(--bg);
}
.brand-statement h2 {
  max-width: 860px;
  margin: 0;
  color: var(--fg);
  font-size: clamp(34px, 4.8vw, 58px);
  line-height: 1;
  font-weight: 600;
  letter-spacing: 0;
  text-shadow:
    0 0 10px var(--bg),
    0 0 24px var(--bg),
    0 0 44px var(--bg);
}

/* ---------- Hand-drawn margin annotations ---------- */
.margin-note {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--primary);
  opacity: 0.65;
  pointer-events: none;
  z-index: 5;
}
.handwriting {
  font-family: 'Caveat', 'Kalam', cursive;
  font-weight: 500;
  font-size: 28px;
  letter-spacing: 0;
  line-height: 1;
  white-space: nowrap;
  transform: rotate(-3deg);
}
.squiggle-arrow {
  width: 76px; height: 38px;
  flex-shrink: 0;
}
.margin-note-hero { right: -180px; top: 96px; }
.margin-note-migration { left: -180px; top: 40px; }
.margin-note-migration .handwriting { transform: rotate(3deg); }

@media (max-width: 1480px) {
  .margin-note-hero { right: 12px; top: 240px; }
  .margin-note-migration { left: 12px; top: -20px; }
}
@media (max-width: 1100px) {
  .margin-note { display: none; }
}

/* ---------- Hero ---------- */
.hero {
  padding: 88px 0 64px;
  position: relative;
  overflow: hidden;
}
.hero-watermark {
  position: absolute;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  opacity: 0.05;
  color: var(--primary);
  right: -90px;
  top: -40px;
  width: 780px;
  height: auto;
  transform: rotate(-6deg);
}
.hero .container { position: relative; z-index: 1; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 4px 4px 4px 12px;
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: var(--radius-full);
  font-size: 13px; font-weight: 500;
  color: var(--fg-secondary);
  margin-bottom: 28px;
}
.hero-eyebrow .pill {
  background: var(--primary-quiet); color: var(--primary);
  padding: 2px 8px; border-radius: var(--radius-full);
  font-size: 11px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
}
.hero h1 {
  font-size: 64px; line-height: 68px;
  font-weight: 600; letter-spacing: -0.045em;
  color: var(--fg);
  max-width: 1120px;
  margin: 0 0 24px;
}
.hero h1 em {
  font-style: italic;
  font-family: var(--font-serif);
  font-weight: 400;
  color: oklch(0.42 0.10 251);
  letter-spacing: -0.02em;
  font-feature-settings: "liga" 1;
}
.hero p.lede {
  font-size: 19px; line-height: 30px;
  color: var(--fg-secondary);
  max-width: 640px;
  margin: 0 0 32px;
}
.hero-ctas { display: flex; align-items: center; gap: 14px; margin-bottom: 32px; }
.hero-meta {
  display: flex; align-items: center; gap: 22px;
  font-size: 13px; color: var(--fg-tertiary);
  font-weight: 600;
  flex-wrap: wrap;
}
.hero-meta .check {
  display: inline-flex; align-items: center; gap: 6px;
  /* Radial bg halo so each check item reads cleanly against the cloud
     duotone underneath. */
  text-shadow:
    0 0 8px var(--bg),
    0 0 18px var(--bg),
    0 0 30px var(--bg);
}
.hero-meta .check svg { width: 14px; height: 14px; color: var(--success); }

/* ---------- Product showcase ---------- */
.product-mock {
  /* Bumped from 56 → 80 so the mock sits a touch lower in the hero,
     covering more of the cloud duotone region underneath. */
  margin-top: 80px;
  border-radius: var(--radius-xl);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow:
    0 1px 2px oklch(0 0 0 / 0.04),
    0 12px 28px oklch(0 0 0 / 0.06),
    0 32px 64px oklch(0.18 0.02 250 / 0.08);
  overflow: hidden;
}
.product-mock-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-2);
}
.product-mock-bar i {
  width: 10px; height: 10px; border-radius: 50%; background: var(--border-strong);
  display: block;
}
.product-mock-bar .url {
  margin-left: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-tertiary);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 3px 10px;
}

/* ---------- Logo strip ---------- */
.logo-strip {
  padding: 36px 0;
  border-bottom: 1px solid var(--border-faint);
}
.logo-strip .label {
  font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  font-weight: 600; color: var(--fg-tertiary);
  margin-bottom: 18px; text-align: center;
}
.logo-strip ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; align-items: center; justify-content: space-between;
  gap: 28px; flex-wrap: wrap;
}
.logo-strip li {
  font-family: var(--font-sans);
  font-size: 16px; font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--fg-tertiary);
  opacity: 0.7;
}

/* ---------- Three-column features ---------- */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}
.feature-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: border-color 120ms var(--ease-out), background-color 120ms var(--ease-out);
}
.feature-card:hover { border-color: var(--border-strong); }
.feature-card .icon {
  width: 36px; height: 36px;
  border-radius: var(--radius-md);
  background: var(--primary-quiet);
  display: grid; place-items: center;
  color: var(--primary);
}
.feature-card .icon svg { width: 18px; height: 18px; stroke-width: 1.75; }
.feature-card h3 {
  font-size: 18px; font-weight: 600; letter-spacing: -0.02em;
  margin: 0;
}
.feature-card p {
  font-size: 14px; line-height: 22px; color: var(--fg-secondary);
  margin: 0;
}
.feature-card .more {
  margin-top: auto;
  font-size: 13px; font-weight: 600; color: var(--primary);
  display: inline-flex; align-items: center; gap: 4px;
}

/* ---------- Split — multi-practice ---------- */
.split {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 56px;
  align-items: center;
}
.split-left h2 {
  font-size: 40px; line-height: 46px;
  font-weight: 600; letter-spacing: -0.035em;
  margin: 0 0 16px;
}
.split-left p {
  font-size: 17px; line-height: 28px;
  color: var(--fg-secondary);
  margin: 0 0 20px;
}
.bullet-list { list-style: none; padding: 0; margin: 0; }
.bullet-list li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-faint);
  align-items: flex-start;
}
.bullet-list li:last-child { border-bottom: 0; }
.bullet-list .b-icon {
  width: 20px; height: 20px; border-radius: var(--radius-sm);
  background: var(--primary-quiet);
  display: grid; place-items: center; color: var(--primary);
  margin-top: 2px;
}
.bullet-list .b-icon svg { width: 12px; height: 12px; stroke-width: 2.5; }
.bullet-list .b-text {
  font-size: 14px; color: var(--fg); line-height: 21px;
  /* Heavy radial bg halo — 12 stops layered from tight (2px) to far
     (120px), with the inner few stops triple-stacked so the bg color is
     fully opaque at the letter edges. */
  text-shadow:
    0 0 2px var(--bg), 0 0 2px var(--bg), 0 0 2px var(--bg),
    0 0 6px var(--bg), 0 0 6px var(--bg),
    0 0 12px var(--bg),
    0 0 20px var(--bg),
    0 0 32px var(--bg),
    0 0 48px var(--bg),
    0 0 70px var(--bg),
    0 0 95px var(--bg),
    0 0 120px var(--bg);
}
.bullet-list .b-text b,
.bullet-list .b-text span {
  text-shadow: inherit;
}
.bullet-list .b-text b { color: var(--fg); font-weight: 600; }
.bullet-list .b-text span { color: var(--fg-tertiary); }

/* ---------- Compare card ---------- */
.compare-card {
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  /* Widen beyond the .container's max so the card spills out to cover
     more of the cloud duotone sky underneath. Negative margins
     keep the card centered without changing the container. */
  margin-left: -64px;
  margin-right: -64px;
  background: var(--surface);
  overflow: hidden;
}
.compare-head {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  padding: 0;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
}
.compare-head > div {
  padding: 22px 28px;
  font-size: 13px; font-weight: 600;
  border-right: 1px solid var(--border-faint);
}
.compare-head > div:last-child { border-right: 0; }
.compare-head .col-medi { color: var(--primary); }
.compare-head .col-medi b { color: var(--fg); }
.compare-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  border-bottom: 1px solid var(--border-faint);
}
.compare-row:last-child { border-bottom: 0; }
.compare-row > div {
  padding: 20px 28px;
  font-size: 14px;
  color: var(--fg);
  border-right: 1px solid var(--border-faint);
}
.compare-row > div:last-child { border-right: 0; }
.compare-row .label {
  font-weight: 500; color: var(--fg-secondary);
}
.compare-row .yes { display: inline-flex; align-items: center; gap: 6px; color: var(--success-fg); font-weight: 500; }
.compare-row .no  { display: inline-flex; align-items: center; gap: 6px; color: var(--fg-tertiary); }
.compare-row svg { width: 14px; height: 14px; }
.compare-foot {
  padding: 22px 28px;
  background: var(--surface-2);
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid var(--border);
  font-size: 13px;
  color: var(--fg-tertiary);
}

/* ---------- Migration ---------- */
.migration-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 40px;
}
.migration-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 22px;
  display: flex; flex-direction: column;
  gap: 12px;
  transition: border-color 120ms var(--ease-out);
}
.migration-card:hover { border-color: var(--border-strong); }
.migration-card .from-to {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--fg-tertiary);
}
.migration-card .from-to svg { width: 12px; height: 12px; color: var(--primary); }
.migration-card h3 {
  font-size: 18px; font-weight: 600; letter-spacing: -0.02em;
  margin: 0;
}
.migration-card p {
  font-size: 14px; line-height: 21px; color: var(--fg-secondary);
  margin: 0;
}
.migration-card .meta {
  margin-top: auto;
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12px; color: var(--fg-tertiary);
}
.migration-card .meta b { color: var(--fg-secondary); font-weight: 600; }

/* ---------- Docs teaser ---------- */
.docs-grid {
  display: grid;
  /* Equal-width columns so the two list tiles match the getting-started
     tile and the row reads as a balanced trio rather than a hero plus
     two sidekicks. */
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
  margin-top: 40px;
}
.docs-tile {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 24px;
  display: flex; flex-direction: column;
  gap: 14px;
  min-height: 220px;
}
.docs-tile .eyebrow {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--fg-tertiary);
}
.docs-tile h3 {
  font-size: 22px; font-weight: 600; letter-spacing: -0.025em;
  margin: 0;
}
.docs-tile p { font-size: 14px; line-height: 21px; color: var(--fg-secondary); margin: 0; }
.docs-tile .list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column;
  gap: 8px;
}
.docs-tile .list li { font-size: 13px; color: var(--fg-secondary); display: flex; gap: 8px; align-items: center; }
.docs-tile .list li::before {
  content: ""; width: 5px; height: 5px; background: var(--fg-tertiary); border-radius: 50%; flex-shrink: 0;
}
.docs-tile .list li:hover { color: var(--fg); }
.docs-tile .more {
  margin-top: auto;
  font-size: 13px; font-weight: 600; color: var(--primary);
  display: inline-flex; align-items: center; gap: 4px;
}

/* ---------- Trust strip ---------- */
.trust {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 40px;
  border-top: 1px solid var(--border);
  padding-top: 32px;
}
.trust-cell {
  font-size: 13px; line-height: 19px; color: var(--fg-secondary);
  /* Heavy radial bg halo — same 12-stop stack as the bullet list, so
     badge / h4 / body copy all sit on a thick pillow of bg. */
  text-shadow:
    0 0 2px var(--bg), 0 0 2px var(--bg), 0 0 2px var(--bg),
    0 0 6px var(--bg), 0 0 6px var(--bg),
    0 0 12px var(--bg),
    0 0 20px var(--bg),
    0 0 32px var(--bg),
    0 0 48px var(--bg),
    0 0 70px var(--bg),
    0 0 95px var(--bg),
    0 0 120px var(--bg);
}
.trust-cell h4,
.trust-cell .badge {
  text-shadow: inherit;
}
.trust-cell h4 {
  font-size: 14px; font-weight: 600; color: var(--fg);
  margin: 0 0 6px;
}
.trust-cell .badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 3px 7px;
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--fg-secondary);
  margin-bottom: 8px;
}

/* ---------- CTA band ---------- */
.cta-band {
  background: var(--primary); /* Medi blue — match .btn-primary */
  border-radius: var(--radius-xl);
  padding: 56px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
  position: relative;
  overflow: hidden;
}
.cta-band::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top right, rgba(255,255,255,0.08), transparent 60%);
  pointer-events: none;
}
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 {
  font-size: 42px; line-height: 48px;
  font-weight: 600; letter-spacing: -0.035em;
  color: oklch(0.99 0.003 85);
  max-width: 620px;
  margin: 0 0 12px;
}
.cta-band p {
  font-size: 17px; line-height: 26px;
  color: oklch(0.99 0.003 85 / 0.75);
  max-width: 540px;
  margin: 0;
}
.cta-band .ctas { display: flex; gap: 12px; }
.cta-band .btn-primary { background: oklch(0.99 0.003 85); color: var(--primary); }
.cta-band .btn-primary:hover { background: oklch(0.94 0.003 85); }
.cta-band .btn-secondary {
  background: transparent;
  color: oklch(0.99 0.003 85);
  border-color: oklch(0.99 0.003 85 / 0.3);
}
.cta-band .btn-secondary:hover {
  background: oklch(0.99 0.003 85 / 0.08);
  border-color: oklch(0.99 0.003 85 / 0.5);
}

/* ---------- Footer ---------- */
footer {
  padding: 64px 0 40px;
  border-top: 1px solid var(--border-faint);
  background: var(--surface);
}
.footer-top {
  display: grid;
  grid-template-columns: 1.3fr repeat(4, 1fr);
  gap: 32px;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--border-faint);
}
.footer-brand { display: flex; flex-direction: column; gap: 12px; max-width: 280px; }
.footer-brand p { font-size: 13px; line-height: 19px; color: var(--fg-tertiary); margin: 0; }
.footer-col h5 { font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-tertiary); margin: 0 0 14px; }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 9px; }
.footer-col a { font-size: 13px; color: var(--fg-secondary); }
.footer-col a:hover { color: var(--fg); }
.footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 24px;
  font-size: 12px; color: var(--fg-tertiary);
  flex-wrap: wrap; gap: 10px;
}
.footer-bottom .links { display: flex; gap: 18px; }
.footer-bottom .links a { color: var(--fg-tertiary); }

/* ---------- Inline product mock (work queue) ---------- */
.mock-app {
  display: grid;
  grid-template-columns: 200px 1fr;
  background: var(--surface);
  min-height: 540px;
  min-width: 920px;
}
.mock-app-scroll { overflow-x: auto; }
.mock-app .sb {
  background: var(--surface);
  border-right: 1px solid var(--border);
  padding: 16px 12px;
  display: flex; flex-direction: column; gap: 4px;
}
.mock-app .sb .brand-row { display: flex; align-items: center; gap: 8px; padding: 4px 8px 16px; font-weight: 600; font-size: 15px; }
.mock-app .sb .brand-row .m { width: 22px; height: 22px; background: var(--primary); color: white; border-radius: 5px; font-weight: 700; display: grid; place-items: center; font-size: 12px; }
.mock-app .sb .practice-switch {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 10px; border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 13px; font-weight: 500;
  margin-bottom: 8px;
}
.mock-app .sb .practice-switch svg { width: 12px; height: 12px; color: var(--fg-tertiary); }
.mock-app .sb .item {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px; border-radius: var(--radius-md);
  font-size: 13px; color: var(--fg-secondary);
}
.mock-app .sb .item.on { background: var(--primary-quiet); color: var(--primary); font-weight: 600;}
.mock-app .sb .item.on .count { background: var(--primary); color: white; }
.mock-app .sb .item svg { width: 14px; height: 14px; stroke-width: 1.75; }
.mock-app .sb .count { margin-left: auto; padding: 0 6px; height: 18px; line-height: 18px; font-size: 11px; font-weight: 600; border-radius: var(--radius-full); background: var(--surface-2); color: var(--fg-tertiary); font-variant-numeric: tabular-nums; }
.mock-app .sb .sub { padding-left: 24px; }
.mock-app .sb .sub .item { padding: 4px 10px; font-size: 13px; }
.mock-app .canvas { padding: 28px 28px 18px; }
.mock-app .canvas h3 {
  font-family: var(--font-serif);
  font-size: 30px; font-weight: 600; letter-spacing: -0.015em;
  margin: 0 0 12px;
  color: var(--primary); /* practice title in Medi blue serif */
}
.mock-app .canvas .stats {
  display: flex; gap: 10px; align-items: center;
  font-size: 13px; color: var(--fg-tertiary);
  padding: 4px 0 18px;
  border-bottom: 0;
}
.mock-app .canvas .stats .lead-dot { width: 7px; height: 7px; background: var(--primary); border-radius: 50%; opacity: .35; }
.mock-app .canvas .stats b { color: var(--fg); font-weight: 600; font-variant-numeric: tabular-nums; }
.mock-app .canvas .stats em {
  font-style: normal; color: oklch(0.42 0.10 60); font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.mock-app .canvas .stats .sep { color: var(--fg-quiet); }

.mock-app .canvas .panel {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 0 22px;
}
.mock-app .canvas .row {
  display: grid;
  grid-template-columns: 18px 1fr 116px 14px;
  align-items: center;
  gap: 12px;
  padding: 22px 0;
  border-bottom: 1px solid var(--border-faint);
}
.mock-app .canvas .row:last-child { border-bottom: 0; }
.mock-app .canvas .row .ic { color: var(--fg-tertiary); display: flex; align-items: center; justify-content: center; }
.mock-app .canvas .row .ic svg { width: 16px; height: 16px; stroke-width: 1.7; }
.mock-app .canvas .row .primary { font-size: 15px; font-weight: 600; color: var(--fg); display: flex; gap: 8px; align-items: center; }
.mock-app .canvas .row .secondary { font-size: 13px; color: var(--fg-tertiary); margin-top: 4px; line-height: 19px; }
.mock-app .canvas .row .amt { font-size: 16px; font-weight: 600; font-variant-numeric: tabular-nums; text-align: right; color: var(--fg); white-space: nowrap; padding-right: 4px; }
.mock-app .canvas .row .chev { color: var(--fg-tertiary); display: flex; }
.mock-app .canvas .row .chev svg { width: 14px; height: 14px; }

.mock-app .canvas .badge {
  font-size: 10.5px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 2px 7px; border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--fg-tertiary);
}
.mock-app .canvas .b-age   { background: var(--surface-2); color: var(--fg-secondary); }
.mock-app .canvas .b-era   { background: var(--surface);  color: var(--fg-secondary); }
.mock-app .canvas .b-ins   { background: var(--surface);  color: var(--fg-secondary); }

.mock-app .canvas .light-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 0 4px;
  font-size: 13px;
  color: var(--fg-quiet);
}
.mock-app .canvas .light-foot a { color: var(--primary); }
.mock-app .canvas .light-foot .count {
  display: inline-flex; align-items: center; gap: 6px;
  font-variant-numeric: tabular-nums;
  color: var(--fg-tertiary);
}
.mock-app .canvas .light-foot .count svg { width: 12px; height: 12px; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .hero h1 { font-size: 44px; line-height: 50px; }
  .feature-grid { grid-template-columns: 1fr; }
  .split { grid-template-columns: 1fr; }
  .migration-grid { grid-template-columns: 1fr; }
  .docs-grid { grid-template-columns: 1fr; }
  .trust { grid-template-columns: 1fr 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .compare-head, .compare-row { grid-template-columns: 1fr 1fr 1fr; font-size: 12px; }
  .topnav nav { display: none; }
}

/* Ladybug widget — sits at bottom-right of authenticated surfaces only,
   shown on marketing pages for brand continuity in the product mock. */
.ladybug-fab {
  position: fixed; right: 18px; bottom: 18px;
  width: 44px; height: 44px;
  background: var(--surface); border: 1px solid var(--border);
  box-shadow: var(--shadow-popover);
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--danger);
  z-index: 60;
}
.ladybug-fab img { width: 28px; height: 28px; }

.medi-cloud-sky-layer {
  position: fixed;
  inset: 64px 0 0;
  z-index: -2;
  pointer-events: none;
  background:
    linear-gradient(to bottom, oklch(0.99 0.003 85 / 0.88), oklch(0.99 0.003 85 / 0.42) 32%, var(--bg)),
    image-set(
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-1600.avif") type("image/avif") 1x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-3840.avif") type("image/avif") 2x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-1600.webp") type("image/webp") 1x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-3840.webp") type("image/webp") 2x
    ) top center / max(100vw, 1800px) auto repeat-y;
  opacity: 0.72;
}

.medi-mountain-picture img {
  width: 100%;
  height: auto;
  display: block;
}

.medi-mountain-home {
  position: relative;
  isolation: isolate;
  overflow-x: clip;
  background: var(--bg);
}

.medi-mountain-home > .topnav,
.medi-mountain-home > .hero,
.medi-mountain-home > .brand-statement,
.medi-mountain-home > .section,
.medi-mountain-home > .final-cta,
.medi-mountain-home > .footer {
  position: relative;
  z-index: 1;
}

.medi-static-cloud-layer {
  /* Fixed to viewport so cloud washes the page at every scroll position.
     No tiling = no seams, no fade-out = no "cut off" moment. The cloud
     just lives in the background of every section. */
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.85;
  background-image:
    linear-gradient(to bottom, oklch(0.99 0.003 85 / 0.85), oklch(0.99 0.003 85 / 0.35) 28%, oklch(0.99 0.003 85 / 0.55) 70%, var(--bg)),
    image-set(
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-1600.avif") type("image/avif") 1x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-3840.avif") type("image/avif") 2x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-1600.webp") type("image/webp") 1x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-3840.webp") type("image/webp") 2x
    );
  background-position: top center, center center;
  background-repeat: no-repeat, no-repeat;
  background-size: auto, cover;
  /* Promote the fixed cloud to its own GPU compositor layer so scrolling
     doesn't repaint the gradient + image-set stack on the main thread —
     that was the scroll-stutter complaint. */
  will-change: transform;
}

.hero-mountains--empty {
  /* Mountain treatment dropped — keep the slot collapsed so layout doesn't shift. */
  display: none;
}

/* ---------- Public V2 pages ---------- */
.medi-public-shell {
  min-height: 100vh;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
}

.medi-public-main {
  position: relative;
  padding: 72px 0 96px;
  overflow: clip;
}

.medi-public-main::before {
  content: "";
  position: fixed;
  inset: 64px 0 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(to bottom, oklch(0.99 0.003 85 / 0.88), var(--bg) 46%),
    image-set(
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-1600.avif") type("image/avif") 1x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-3840.avif") type("image/avif") 2x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-1600.webp") type("image/webp") 1x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-3840.webp") type("image/webp") 2x
    ) top center / max(100vw, 1800px) auto no-repeat;
  opacity: 0.58;
}

.medi-public-container {
  width: min(100% - 56px, 1320px);
  margin: 0 auto;
}

.medi-detail-page {
  display: grid;
  gap: 46px;
}

.medi-page-hero {
  max-width: 860px;
  margin-bottom: 44px;
}

.medi-page-hero h1 {
  font-size: clamp(42px, 5vw, 72px);
  line-height: 0.98;
  font-weight: 600;
  letter-spacing: 0;
  margin: 0 0 18px;
  color: var(--fg);
  text-shadow:
    0 0 10px var(--bg),
    0 0 24px var(--bg),
    0 0 44px var(--bg);
}

.medi-page-hero p:not(.section-eyebrow) {
  max-width: 740px;
  margin: 0;
  color: var(--fg-secondary);
  font-size: 18px;
  line-height: 29px;
}

.medi-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: -18px 0 36px;
}

.medi-index-page {
  display: grid;
  gap: 44px;
}

.medi-index-section {
  display: grid;
  gap: 18px;
}

.medi-section-heading-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
  gap: 32px;
  align-items: end;
}

.medi-section-heading-row p {
  margin: 0;
  color: var(--fg-secondary);
  font-size: 15px;
  line-height: 24px;
}

.medi-index-section h2 {
  font-size: 28px;
  line-height: 34px;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--fg);
  margin: 0;
  text-shadow:
    0 0 10px var(--bg),
    0 0 24px var(--bg),
    0 0 44px var(--bg);
}

.medi-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.medi-card-grid.is-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.medi-link-card {
  min-height: 150px;
  padding: 22px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: oklch(1 0 0 / 0.82);
  box-shadow: 0 1px 2px oklch(0 0 0 / 0.035);
  transition:
    transform 140ms var(--ease-out),
    border-color 140ms var(--ease-out),
    background-color 140ms var(--ease-out);
}

.medi-link-card:hover {
  transform: translateY(-1px);
  border-color: var(--border-strong);
  background: var(--surface);
}

.medi-link-card h2,
.medi-link-card h3 {
  margin: 0;
  color: var(--fg);
  font-size: 18px;
  line-height: 24px;
  font-weight: 600;
  letter-spacing: 0;
}

.medi-link-card p {
  margin: 8px 0 0;
  color: var(--fg-secondary);
  font-size: 14px;
  line-height: 22px;
}

.medi-proof-timeline,
.medi-estimate-grid,
.medi-proof-list {
  display: grid;
  gap: 14px;
}

.medi-proof-timeline {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.medi-estimate-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.medi-proof-step-card,
.medi-estimate-card,
.medi-proof-row {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: oklch(1 0 0 / 0.78);
  box-shadow: 0 1px 2px oklch(0 0 0 / 0.035);
}

.medi-proof-step-card {
  min-height: 210px;
  padding: 20px;
}

.medi-proof-step-card > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  margin-bottom: 18px;
  border-radius: var(--radius-md);
  background: var(--primary-quiet);
  color: var(--primary);
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
}

.medi-proof-step-card h3,
.medi-estimate-card h3,
.medi-proof-row h3 {
  margin: 0;
  color: var(--fg);
  font-size: 18px;
  line-height: 24px;
  font-weight: 600;
  letter-spacing: 0;
}

.medi-proof-step-card p,
.medi-estimate-card li,
.medi-proof-row p {
  color: var(--fg-secondary);
  font-size: 14px;
  line-height: 22px;
}

.medi-proof-step-card p,
.medi-proof-row p {
  margin: 10px 0 0;
}

.medi-estimate-card {
  display: grid;
  gap: 18px;
  padding: 22px;
}

.medi-estimate-card > div {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: baseline;
}

.medi-estimate-card strong {
  color: var(--primary);
  font-size: 22px;
  line-height: 28px;
  white-space: nowrap;
}

.medi-estimate-card ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
}

.medi-estimate-card li {
  margin: 0;
}

.medi-proof-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.medi-proof-row {
  padding: 20px;
}

.medi-pricing-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: 34px;
  align-items: center;
  padding: 30px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.medi-pricing-label {
  margin: 0 0 8px;
  color: var(--primary);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.medi-pricing-panel h2 {
  margin: 0 0 12px;
  color: var(--fg);
  font-size: 34px;
  line-height: 39px;
  font-weight: 600;
  letter-spacing: 0;
}

.medi-pricing-panel p:not(.medi-pricing-label) {
  margin: 0;
  color: var(--fg-secondary);
  font-size: 16px;
  line-height: 25px;
}

.medi-pricing-price {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin: 0 0 12px;
}

.medi-pricing-price span {
  color: var(--fg);
  font-size: clamp(56px, 8vw, 92px);
  line-height: 0.92;
  font-weight: 600;
  letter-spacing: 0;
}

.medi-pricing-price small {
  color: var(--fg-secondary);
  font-size: 16px;
  line-height: 24px;
}

.medi-pricing-proof {
  display: grid;
  gap: 10px;
}

.medi-pricing-proof span,
.medi-operations-row {
  display: flex;
  align-items: center;
  min-height: 44px;
  padding: 10px 0 10px 28px;
  border-bottom: 1px solid var(--border-faint);
  color: var(--fg);
  font-size: 14px;
  line-height: 20px;
  font-weight: 600;
  position: relative;
}

.medi-pricing-proof span::before,
.medi-operations-row::before {
  content: "";
  position: absolute;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--primary);
}

.medi-price-table {
  display: grid;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: oklch(1 0 0 / 0.58);
}

.medi-price-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(120px, 0.42fr) minmax(240px, 1.25fr);
  gap: 20px;
  padding: 15px 18px;
  border-bottom: 1px solid var(--border-faint);
  color: var(--fg-secondary);
  font-size: 14px;
  line-height: 21px;
}

.medi-price-row:last-child {
  border-bottom: 0;
}

.medi-price-row.is-head {
  color: var(--fg);
  font-size: 12px;
  line-height: 18px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.medi-price-row > div:nth-child(1),
.medi-price-row > div:nth-child(2) {
  color: var(--fg);
  font-weight: 600;
}

.medi-operations-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 34px;
}

.medi-detail-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding-top: 4px;
}

.medi-docs-shell {
  display: grid;
  grid-template-columns: minmax(220px, 286px) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}

.medi-docs-aside {
  position: sticky;
  top: 88px;
}

.medi-docs-nav {
  padding: 16px 0;
  border-top: 1px solid var(--border-faint);
  border-bottom: 1px solid var(--border-faint);
}

.medi-nav-label {
  margin: 0 0 12px;
  color: var(--fg-tertiary);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.medi-docs-nav-list {
  display: grid;
  gap: 3px;
}

.medi-docs-nav-link {
  display: block;
  border-radius: var(--radius-md);
  padding: 8px 10px;
  color: var(--fg-secondary);
  font-size: 14px;
  line-height: 19px;
  font-weight: 500;
}

.medi-docs-nav-link:hover,
.medi-docs-nav-link.is-active {
  background: var(--primary-quiet);
  color: var(--primary);
}

.medi-docs-content {
  min-width: 0;
}

.medi-content-page {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
  gap: 56px;
  align-items: start;
}

.medi-content-main {
  min-width: 0;
  max-width: 900px;
}

.medi-content-aside {
  position: sticky;
  top: 88px;
  display: grid;
  gap: 16px;
}

.medi-rich-text {
  color: var(--fg);
  font-size: 16px;
  line-height: 28px;
}

.medi-rich-text > * + * {
  margin-top: 18px;
}

.medi-rich-text h2 {
  margin-top: 40px;
  font-size: 28px;
  line-height: 34px;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--fg);
}

.medi-rich-text h3,
.medi-rich-text h2.is-h3 {
  margin-top: 30px;
  font-size: 20px;
  line-height: 27px;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--fg);
}

.medi-rich-text p {
  margin-bottom: 0;
  color: var(--fg-secondary);
}

.medi-rich-text a {
  color: var(--primary);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}

.medi-rich-text ul {
  padding-left: 20px;
  color: var(--fg-secondary);
}

.medi-rich-text li + li {
  margin-top: 8px;
}

.medi-rich-text blockquote {
  margin: 26px 0;
  padding: 14px 18px;
  border-left: 2px solid var(--primary);
  background: oklch(1 0 0 / 0.62);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  color: var(--fg-secondary);
}

.medi-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: oklch(1 0 0 / 0.8);
}

.medi-table-wrap table {
  width: 100%;
  min-width: 680px;
  border-collapse: collapse;
  text-align: left;
  font-size: 14px;
  line-height: 21px;
}

.medi-table-wrap th,
.medi-table-wrap td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border-faint);
  vertical-align: top;
}

.medi-table-wrap th {
  color: var(--fg);
  font-weight: 600;
}

.medi-table-wrap td {
  color: var(--fg-secondary);
}

.medi-table-wrap tr:last-child td {
  border-bottom: 0;
}

.medi-aside-panel,
.medi-reference-section {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: oklch(1 0 0 / 0.82);
  box-shadow: 0 1px 2px oklch(0 0 0 / 0.035);
}

.medi-aside-panel {
  padding: 18px;
}

.medi-aside-panel h2 {
  margin: 0;
  font-size: 15px;
  line-height: 22px;
  color: var(--fg);
  font-weight: 600;
}

.medi-next-step p {
  margin: 8px 0 14px;
  color: var(--fg-secondary);
  font-size: 13px;
  line-height: 20px;
}

.medi-aside-actions,
.medi-related-list {
  display: grid;
  gap: 8px;
}

.medi-aside-actions .btn {
  justify-content: center;
}

.medi-related-link {
  display: block;
  border-radius: var(--radius-md);
  padding: 9px 10px;
  color: var(--fg-secondary);
  font-size: 13px;
  line-height: 18px;
  font-weight: 600;
  background: var(--bg-subtle);
}

.medi-related-link:hover {
  color: var(--primary);
  background: var(--primary-quiet);
}

.medi-reference-section {
  margin-top: 44px;
  padding: 22px;
}

.medi-reference-section h2 {
  margin: 0;
  font-size: 22px;
  line-height: 28px;
  font-weight: 600;
  letter-spacing: 0;
}

.medi-reference-section p {
  margin: 8px 0 18px;
  color: var(--fg-secondary);
  font-size: 14px;
  line-height: 22px;
}

.medi-reference-section ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.medi-reference-section li {
  display: grid;
  gap: 2px;
}

.medi-reference-section a {
  color: var(--primary);
  font-size: 14px;
  line-height: 20px;
  font-weight: 600;
}

.medi-reference-section span {
  color: var(--fg-tertiary);
  font-size: 12px;
  line-height: 18px;
}

.medi-public-footer-top {
  grid-template-columns: 1.4fr repeat(4, 1fr);
}

.footer-brand .brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  letter-spacing: 0;
  font-size: 18px;
}

.footer-brand .brand .mark {
  width: 32px;
  height: 32px;
}

.medi-auth-shell {
  min-height: 100vh;
  background:
    linear-gradient(to bottom, oklch(0.99 0.003 85 / 0.9), var(--bg)),
    image-set(
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-1600.avif") type("image/avif") 1x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-3840.avif") type("image/avif") 2x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-1600.webp") type("image/webp") 1x,
      url("/medi-design/ui_kits/marketing/generated/cloud-duotone-3840.webp") type("image/webp") 2x
    ) top center / max(100vw, 1700px) auto no-repeat;
  color: var(--fg);
  font-family: var(--font-sans);
  display: grid;
  place-items: center;
  padding: 48px 20px;
}

.medi-auth-public-main {
  padding: 0;
}

.medi-auth-public-main .medi-auth-shell {
  min-height: auto;
  background: transparent;
  padding: 72px 20px;
}

.medi-auth-card {
  width: min(100%, 430px);
  padding: 28px;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: oklch(1 0 0 / 0.86);
  box-shadow: var(--shadow-overlay);
}

.medi-auth-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--fg);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0;
}

.medi-auth-brand img {
  width: 34px;
  height: 34px;
}

.medi-auth-card h1 {
  margin: 24px 0 22px;
  font-size: 30px;
  line-height: 36px;
  font-weight: 600;
  letter-spacing: 0;
}

.medi-demo-panel {
  display: grid;
  gap: 18px;
}

.medi-demo-main {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 251, 252, 0.96)),
    var(--page-bg);
}

.medi-demo-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(420px, 1.22fr);
  gap: 44px;
  width: min(1180px, calc(100vw - 48px));
  margin: 0 auto;
  padding: 72px 0 88px;
  align-items: start;
}

.medi-demo-copy {
  color: var(--fg-secondary);
  font-size: 18px;
  line-height: 28px;
}

.medi-demo-copy p {
  margin: 0;
}

.medi-demo-copy p + p {
  margin-top: 10px;
}

.medi-demo-copy h1 {
  margin: 10px 0 18px;
  color: var(--fg);
  font-size: clamp(44px, 6vw, 72px);
  line-height: 0.96;
  font-weight: 650;
  letter-spacing: 0;
}

.medi-demo-points {
  display: grid;
  gap: 10px;
  margin-top: 28px;
  color: var(--fg);
  font-size: 14px;
  line-height: 20px;
}

.medi-demo-points span {
  display: flex;
  align-items: center;
  gap: 10px;
}

.medi-demo-points span::before {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--brand);
  content: "";
}

.medi-demo-agenda {
  margin-top: 30px;
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: oklch(1 0 0 / 0.74);
}

.medi-demo-agenda h2 {
  margin: 0 0 12px;
  color: var(--fg);
  font-size: 20px;
  line-height: 26px;
  font-weight: 650;
  letter-spacing: 0;
}

.medi-demo-agenda ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding-left: 18px;
  color: var(--fg-secondary);
  font-size: 14px;
  line-height: 22px;
}

.medi-demo-note {
  margin-top: 30px !important;
  font-size: 14px;
  line-height: 22px;
}

.medi-demo-note a {
  color: var(--brand);
  font-weight: 650;
}

.medi-calendly-frame {
  min-width: 320px;
  height: 760px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface);
}

.medi-calendly-fallback {
  display: grid;
  min-height: 100%;
  place-items: center;
  gap: 16px;
  padding: 28px;
  text-align: center;
  color: var(--fg-secondary);
}

.medi-calendly-fallback p {
  margin: 0;
}

.medi-calendly-fallback a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: var(--radius-sm);
  background: var(--brand);
  color: white;
  font-weight: 650;
  text-decoration: none;
}

@media (max-width: 1100px) {
  .medi-card-grid,
  .medi-card-grid.is-two,
  .medi-proof-timeline,
  .medi-estimate-grid,
  .medi-proof-list {
    grid-template-columns: 1fr 1fr;
  }

  .medi-pricing-panel,
  .medi-section-heading-row {
    grid-template-columns: 1fr;
  }

  .medi-docs-shell,
  .medi-content-page {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .medi-docs-aside,
  .medi-content-aside {
    position: static;
  }

  .medi-docs-nav-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .medi-content-main {
    max-width: none;
  }

  .medi-demo-hero {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .medi-public-shell .topnav nav {
    display: flex;
  }
}

@media (max-width: 760px) {
  .topnav-inner {
    height: auto;
    min-height: 64px;
    flex-wrap: wrap;
    gap: 12px;
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .topnav nav {
    order: 3;
    width: 100%;
    display: flex;
    overflow-x: auto;
    gap: 18px;
    padding-bottom: 2px;
  }

  .medi-demo-hero {
    width: min(100% - 28px, 1180px);
    padding: 42px 0 58px;
  }

  .medi-demo-copy {
    font-size: 16px;
    line-height: 25px;
  }

  .medi-calendly-frame {
    min-width: 0;
    height: 690px;
  }

  .topnav .right {
    gap: 10px;
  }

  .signin {
    display: none;
  }

  .medi-public-main {
    padding: 48px 0 72px;
  }

  .medi-public-container {
    width: min(100% - 32px, 1320px);
  }

  .medi-page-hero h1 {
    font-size: 40px;
    line-height: 44px;
  }

  .medi-page-hero p:not(.section-eyebrow) {
    font-size: 16px;
    line-height: 25px;
  }

  .medi-card-grid,
  .medi-card-grid.is-two,
  .medi-proof-timeline,
  .medi-estimate-grid,
  .medi-proof-list,
  .medi-operations-list,
  .medi-docs-nav-list {
    grid-template-columns: 1fr;
  }

  .medi-pricing-panel {
    gap: 24px;
  }

  .medi-pricing-panel h2 {
    font-size: 28px;
    line-height: 34px;
  }

  .medi-price-table {
    overflow-x: auto;
  }

  .medi-price-row {
    min-width: 680px;
  }

  .medi-link-card {
    min-height: auto;
  }

  .medi-public-footer-top,
  .footer-top {
    grid-template-columns: 1fr;
  }

  .medi-auth-card {
    padding: 22px;
  }
}

/* ============================================================
   Content byline + TOC (docs/compare/migration content)
   ============================================================ */
.medi-content-byline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin: 0 0 24px;
  padding: 12px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  color: var(--fg-secondary);
  font-size: 13px;
  line-height: 20px;
}

.medi-byline-author {
  color: var(--fg);
  font-weight: 600;
}

.medi-byline-label {
  color: var(--fg-secondary);
  font-weight: 500;
}

.medi-byline-name {
  color: var(--fg);
}

.medi-byline-role {
  color: var(--fg-secondary);
  font-weight: 500;
}

.medi-byline-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.medi-byline-sep {
  color: var(--fg-tertiary, var(--fg-secondary));
}

.medi-aside-toc h2 {
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-secondary);
  margin: 0 0 10px;
}

.medi-toc-list {
  list-style: none;
  counter-reset: toc;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.medi-toc-list li {
  counter-increment: toc;
  position: relative;
  padding-left: 24px;
  font-size: 13px;
  line-height: 19px;
}

.medi-toc-list li::before {
  content: counter(toc) ".";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--fg-tertiary, var(--fg-secondary));
  font-variant-numeric: tabular-nums;
}

.medi-toc-list a {
  color: var(--fg);
  text-decoration: none;
  transition: color 120ms ease;
}

.medi-toc-list a:hover {
  color: var(--primary);
  text-decoration: underline;
}

/* ============================================================
   Pricing calculator (/tools/pricing-calculator)
   ============================================================ */
.medi-pricing-calculator {
  display: grid;
  grid-template-columns: minmax(320px, 1fr) minmax(0, 1.4fr);
  gap: 28px;
  margin-top: 32px;
}

.medi-pricing-calculator-inputs,
.medi-pricing-calculator-output {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: oklch(1 0 0 / 0.78);
  box-shadow: 0 1px 2px oklch(0 0 0 / 0.035);
  padding: 24px;
}

.medi-pricing-calculator-inputs h2,
.medi-pricing-calculator-output h2 {
  margin: 0 0 6px;
  font-size: 18px;
  line-height: 24px;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--fg);
}

.medi-pricing-calculator-hint {
  margin: 0;
  color: var(--fg-secondary);
  font-size: 14px;
  line-height: 21px;
}

.medi-pricing-calculator-hint-small {
  font-size: 12px;
  line-height: 17px;
  color: var(--fg-tertiary, var(--fg-secondary));
}

.medi-pricing-calculator-field-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 18px;
}

.medi-pricing-calculator-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.medi-pricing-calculator-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--fg);
}

.medi-pricing-calculator-field input[type="number"] {
  font: inherit;
  padding: 9px 11px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: oklch(1 0 0);
  color: var(--fg);
  font-size: 15px;
}

.medi-pricing-calculator-field input[type="number"]:focus {
  outline: 2px solid var(--primary);
  outline-offset: -1px;
}

.medi-pricing-calculator-table {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  margin-top: 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.medi-pricing-calculator-row {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: 14px;
  padding: 14px 16px;
  border-top: 1px solid var(--border);
  font-size: 14px;
  line-height: 20px;
}

.medi-pricing-calculator-row.is-four-col {
  grid-template-columns: minmax(0, 2.1fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1.1fr);
}

.medi-pricing-calculator-amount-strong {
  font-weight: 700;
  color: var(--fg);
}

.medi-pricing-calculator-copy {
  margin-top: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: oklch(1 0 0);
  color: var(--fg);
  font: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 120ms ease, border-color 120ms ease;
}

.medi-pricing-calculator-copy:hover {
  background: oklch(0.96 0.01 250);
  border-color: var(--primary);
}

.medi-pricing-calculator-copy:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.medi-pricing-calculator-row:first-child {
  border-top: 0;
}

.medi-pricing-calculator-row.is-head {
  background: oklch(0.97 0.005 250);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-secondary);
}

.medi-pricing-calculator-row.is-medi {
  background: oklch(0.97 0.03 240);
}

.medi-pricing-calculator-row strong {
  display: block;
  color: var(--fg);
  font-weight: 600;
}

.medi-pricing-calculator-vendor-desc {
  display: block;
  margin-top: 3px;
  font-size: 12px;
  color: var(--fg-secondary);
}

.medi-pricing-calculator-amount {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--fg);
}

.medi-pricing-calculator-details {
  margin-top: 16px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  background: oklch(0.98 0 0);
}

.medi-pricing-calculator-details summary {
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
}

.medi-pricing-calculator-details ul {
  margin: 10px 0 0;
  padding-left: 18px;
  font-size: 13px;
  line-height: 20px;
  color: var(--fg-secondary);
}

.medi-pricing-calculator-details li {
  margin-bottom: 4px;
}

.medi-pricing-calculator-methodology {
  margin: 16px 0 0;
  font-size: 12px;
  line-height: 18px;
  color: var(--fg-secondary);
}

@media (max-width: 1024px) {
  .medi-pricing-calculator {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .medi-pricing-calculator-field-grid {
    grid-template-columns: 1fr;
  }
  .medi-pricing-calculator-row {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, 1fr);
    font-size: 13px;
  }
  .medi-pricing-calculator-row.is-four-col {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1.1fr);
    font-size: 12px;
  }
}
