/* =======================================================
   Riftgrind design system — dark + light themes
   ======================================================= */
:root,
:root[data-theme="dark"]{
  --bg:#0a0e1a; --bg-2:#0f1527; --surface:#111a2e; --surface-2:#162138;
  --text:#e7ecf5; --muted:#9aa6bd; --border:#1f2a44;
  --accent:#22c3ff; --accent-2:#7ce3ff; --accent-ink:#001018;
  --danger:#ff4d6d; --danger-bg:rgba(255,77,109,.14); --danger-border:rgba(255,77,109,.38);
  --hero-overlay: radial-gradient(1200px 500px at 50% -10%, rgba(34,195,255,.18), transparent 60%);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius:8px;
}
:root[data-theme="light"]{
  --bg:#f7f9fc; --bg-2:#ffffff; --surface:#ffffff; --surface-2:#f1f4fa;
  --text:#0c1222; --muted:#55607a; --border:#dde3ee;
  --accent:#0a8ccc; --accent-2:#0b6fa6; --accent-ink:#ffffff;
  --danger:#d4345a; --danger-bg:rgba(212,52,90,.08); --danger-border:rgba(212,52,90,.32);
  --hero-overlay: radial-gradient(1200px 500px at 50% -10%, rgba(10,140,204,.15), transparent 60%);
  --shadow: 0 8px 24px rgba(12,18,34,.08);
  --radius:8px;
}
@media (prefers-reduced-motion: reduce){*{animation:none !important;transition:none !important}}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  margin:0; background:var(--bg); color:var(--text);
  font:1.0625rem/1.65 system-ui,-apple-system,"Segoe UI",Inter,Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;
  transition:background .2s ease,color .2s ease;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

.wrap{max-width:1180px;margin-inline:auto;padding:0 20px}
.narrow{max-width:760px}

.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:12px;top:12px;background:var(--accent);color:var(--accent-ink);padding:8px 12px;border-radius:8px;z-index:999}

/* -------- Header -------- */
.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-block:14px}
.brand{display:inline-flex;align-items:center;gap:10px;color:var(--text);font-weight:800;font-size:1.25rem;letter-spacing:-.01em}
.brand-mark{color:var(--accent);letter-spacing:-.1em}
.accent{color:var(--accent)}
.site-nav{display:flex;gap:16px 18px;flex-wrap:wrap;align-items:center}
.site-nav a{color:var(--muted);font-weight:600;font-size:.95rem}
.site-nav a:hover,.site-nav a[aria-current="page"]{color:var(--text);text-decoration:none}
.site-nav a[aria-current="page"]{font-weight:700}
.header-tools{display:flex;align-items:center;gap:8px}

/* -------- Theme toggle -------- */
.theme-toggle{
  width:40px;height:40px;border-radius:var(--radius);border:1px solid var(--border);
  background:var(--surface);color:var(--text);cursor:pointer;display:grid;place-items:center;
  position:relative;overflow:hidden;transition:background .2s ease,border-color .2s ease;
}
.theme-toggle:hover{border-color:var(--accent)}
.theme-icon{position:absolute;font-size:18px;transition:transform .25s ease, opacity .25s ease}
:root[data-theme="dark"] .theme-icon-sun{opacity:0;transform:rotate(-90deg) scale(.6)}
:root[data-theme="dark"] .theme-icon-moon{opacity:1;transform:rotate(0) scale(1)}
:root[data-theme="light"] .theme-icon-sun{opacity:1;transform:rotate(0) scale(1)}
:root[data-theme="light"] .theme-icon-moon{opacity:0;transform:rotate(90deg) scale(.6)}

/* -------- Mobile nav toggle -------- */
.nav-toggle{display:none;width:40px;height:40px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--text);border-radius:2px}
.mobile-nav{display:none;flex-direction:column;gap:0;border-top:1px solid var(--border);background:var(--bg-2)}
.mobile-nav a{padding:14px 20px;color:var(--text);border-bottom:1px solid var(--border)}
.mobile-nav[aria-hidden="false"],.mobile-nav:not([hidden]){display:flex}

@media(max-width:780px){
  .site-nav{display:none}
  .nav-toggle{display:flex}
}

/* -------- Hero -------- */
.hero{
  position:relative;padding:96px 0 72px;
  background:
    var(--hero-overlay),
    url("/bg-hero.jpg") center/cover no-repeat,
    var(--bg);
}
:root[data-theme="light"] .hero{background:var(--hero-overlay),linear-gradient(180deg,#eef3fb,#f7f9fc)}
.hero-inner{text-align:center;max-width:820px;margin-inline:auto}
.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;font-weight:700;border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);padding:6px 14px;border-radius:999px;background:color-mix(in srgb,var(--accent) 8%,transparent)}
.eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--accent)}

h1{font-size:clamp(2rem,4vw + 1rem,3.5rem);line-height:1.08;letter-spacing:-.02em;margin:.6em 0 .3em;font-weight:800}
h2{font-size:clamp(1.5rem,2vw + 1rem,2.25rem);line-height:1.15;letter-spacing:-.01em;margin:0 0 .4em;font-weight:800}
h3{font-size:1.175rem;margin:0 0 .3em;font-weight:700}
.lede{font-size:1.15rem;color:var(--muted);max-width:58ch;margin:0 auto .8em}
.stat{color:var(--muted)} .stat strong{color:var(--text)}
.muted{color:var(--muted)}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:22px}

/* -------- Buttons -------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:var(--radius);font-weight:600;border:1px solid transparent;min-height:44px;transition:transform .15s ease,background .15s ease,border-color .15s ease;cursor:pointer}
.btn-primary{background:var(--accent);color:var(--accent-ink)}
.btn-primary:hover{background:var(--accent-2);text-decoration:none;transform:translateY(-1px);color:var(--accent-ink)}
.btn-ghost{color:var(--text);border-color:var(--border);background:transparent}
.btn-ghost:hover{background:var(--surface);text-decoration:none}

/* -------- Sections -------- */
section{padding:72px 0}
.publications .muted{margin-bottom:28px}

/* -------- Card grid (FIXED: 18+ no longer overflows) -------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.card{
  background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius);padding:22px;
  display:flex;flex-direction:column;gap:10px;
  box-shadow:var(--shadow);
  transition:transform .2s ease,border-color .2s ease;
  min-width:0; /* prevents children from forcing overflow */
}
:root[data-theme="dark"] .card{background:linear-gradient(180deg,var(--surface),var(--surface-2))}
.card:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--accent) 50%,transparent)}
.card header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-width:0;
  min-height:44px;
}
.card header h3{
  margin:0;
  min-width:0;
  word-break:break-word;
  flex:1 1 auto;
}
.card header .badge{flex:0 0 auto}
.card h3 a{color:var(--text)}
.card h3 a:hover{color:var(--accent)}
.card p{color:var(--muted);margin:0;flex:0 0 auto}
.card-cta{color:var(--accent);font-weight:600;margin-top:auto}
.external-note{display:inline-flex;align-items:center;gap:4px;color:var(--muted);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.external-note::after{content:"↗";font-size:.8rem;color:var(--accent)}
.btn .external-note,.btn .external-note::after{color:currentColor}
.mobile-nav a[aria-current="page"]{font-weight:700;color:var(--accent)}

/* -------- Category paths and trust cues -------- */
.trust-strip{padding:32px 0;background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.trust-item{display:flex;flex-direction:column;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.trust-item strong{font-size:1.4rem;line-height:1.1;color:var(--text)}
.trust-item span{color:var(--muted);font-size:.92rem}
.category-paths{background:var(--bg-2)}
.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:24px}
.category-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:12px}
.category-card h3{margin:0}
.category-card p{margin:0;color:var(--muted)}
.mini-list{list-style:none;margin:2px 0 0;padding:0;color:var(--muted);font-size:.93rem}
.mini-list li{padding:5px 0;border-top:1px solid color-mix(in srgb,var(--border) 70%,transparent)}
.mini-list li:first-child{border-top:0}
.workflow-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:22px}
.workflow-step{border:1px solid var(--border);border-radius:var(--radius);padding:18px;background:var(--surface)}
.workflow-step span{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);font-weight:800;margin-bottom:10px}
.workflow-step h3{margin:0 0 4px;font-size:1rem}
.workflow-step p{margin:0;color:var(--muted);font-size:.95rem}

/* -------- Badges (FIXED: whitespace + shrink-safe) -------- */
.badge{
  display:inline-flex;align-items:center;
  padding:3px 9px;border-radius:999px;
  background:color-mix(in srgb,var(--accent) 14%,transparent);
  color:var(--accent);font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);
  white-space:nowrap; flex-shrink:0; line-height:1.4;
}
.badge-age{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}
.badge-group{display:inline-flex;gap:6px;flex-wrap:nowrap;flex-shrink:0}

/* -------- Standards grid -------- */
.standards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin-top:18px}
.std{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.std-icon{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:var(--radius);background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);margin-bottom:10px;font-weight:800}

/* -------- About brief -------- */
.two-col{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:800px){.two-col{grid-template-columns:1.2fr .8fr}}

/* -------- Page (legal/about/contact) -------- */
.page{padding:40px 0 80px}
.page-header{padding:20px 0 8px}
.breadcrumb{color:var(--muted);font-size:.9rem;margin:8px 0 8px}
.toc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;margin:18px 0 26px}
.toc h2{font-size:.9rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 8px}
.toc ol{margin:0;padding-left:20px;color:var(--muted)}
.toc a{color:var(--text)}

.contact-list{list-style:none;padding:0}
.contact-list li{padding:10px 0;border-bottom:1px solid var(--border)}
.page-cta{margin-top:36px;text-align:center}

/* -------- FAQ -------- */
.faq details{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;margin-bottom:10px}
.faq summary{cursor:pointer;font-weight:600;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;font-weight:800;color:var(--accent);transition:transform .2s ease}
.faq details[open] summary::after{content:"–"}
.faq details p{margin:.8em 0 .2em;color:var(--muted)}

/* -------- Contact page specifics -------- */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:24px}
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.contact-card h3{margin-top:0}
.contact-card a{word-break:break-all}

/* -------- Footer -------- */
.site-footer{border-top:1px solid var(--border);background:var(--bg-2);padding:48px 0 18px;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:28px}
.site-footer h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:4px 0 10px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{padding:4px 0;display:flex;align-items:center;gap:8px}
.site-footer li a{display:inline-flex;align-items:center;gap:8px;white-space:normal}
.site-footer .external-note{display:none}
.footer-bottom{margin-top:28px;color:var(--muted);border-top:1px solid var(--border);padding-top:18px}

/* -------- Small screens -------- */
@media(max-width:640px){
  .site-header .wrap{gap:10px}
  .hero{padding:72px 0 56px}
  section{padding:56px 0}
}


/* =======================================================
   Sub-page typography rhythm v7 — unified vertical scale
   Goal: a single, predictable gap between every section.
   ======================================================= */

/* Reset generic section padding inside sub-pages */
.page section{ padding: 0; margin: 0; }

/* Consistent gap: every block-level child of the narrow column
   sits on the same 48px rhythm */
.page .wrap.narrow > * + *{ margin-top: 48px; }

/* Section-to-section on sub-pages with <section> wrappers:
   tighter gap + a visible divider so sections feel separated rather than floating */
.page .wrap.narrow > section + section{
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid var(--border);
}

/* Keep the header-to-TOC gap slightly tighter than inter-section */
.page .wrap.narrow > .page-header + .toc,
.page .wrap.narrow > .page-header + section{ margin-top: 32px; }
.page .wrap.narrow > .page-header + section,
.page .wrap.narrow > .toc + section{
  padding-top:28px;
  border-top:1px solid var(--border);
}

/* Breadcrumb -> page-header is tight; they read as one unit */
.page .wrap.narrow > .breadcrumb + .page-header{ margin-top: 12px; }

/* TOC -> first section: tighter, as TOC is a navigation aid */
.page .wrap.narrow > .toc + section{ margin-top: 32px; }

/* Headings inside sections */
.page section > :first-child{ margin-top: 0; }
.page section > :last-child{ margin-bottom: 0; }
.page h2{ margin: 0 0 .6em; line-height: 1.2; }
.page h3{ margin: 1.4em 0 .35em; line-height: 1.3; }
.page p{ margin: 0 0 1em; max-width: 70ch; }
.page .contact-grid p,
.page .standards-grid p,
.page .card p,
.page .tool-card p,
.page .related-card p{ max-width: none; }
.page ul, .page ol{ margin: .4em 0 1.2em; padding-left: 1.25em; max-width: 70ch; }
.page li{ margin: .3em 0; }
.page li::marker{ color: var(--accent); }
.page :is(h2,h3)[id], .page section[id]{ scroll-margin-top: 96px; }

/* Page header: tight internal rhythm, explicitly left-aligned */
.page .page-header{ padding: 0; text-align: left; }
.page .page-header .eyebrow{ margin: 0 0 10px; }
.page .page-header h1{ margin: 0 0 14px; text-align: left; }
.page .page-header .lede{ margin: 0 0 14px; max-width: 62ch; text-align: left; margin-left: 0; margin-right: 0; }

/* "Last updated" pill */
.page .page-header .muted{
  display: inline-block;
  margin: 0;
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 4px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
}
.page .page-header .muted time{ color: inherit; }

/* Breadcrumb */
.page .breadcrumb{ margin: 0; font-size: .85rem; color: var(--muted); }
.page .breadcrumb a{ color: var(--muted); }
.page .breadcrumb a:hover{ color: var(--text); }

/* TOC card */
.page .toc{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin: 0;
}
.page .toc h2{ margin: 0 0 10px; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); font-weight: 700; }
.page .toc ol{ margin: 0; padding-left: 22px; max-width: none; }
.page .toc li{ margin: 5px 0; }
.page .toc a{ color: var(--text); }
.page .toc a:hover{ color: var(--accent); text-decoration: none; }

/* Standards / rubric cards: equal-height flex, consistent padding */
.standards-grid{ margin-top: 14px; }
.standards-grid .std{
  display: flex; flex-direction: column; gap: 6px;
  padding: 22px;
}
.standards-grid .std h3{ margin: 0; }
.standards-grid .std p{ margin: 0; color: var(--muted); max-width: none; }
.standards-grid .std-icon{ margin: 0 0 6px; }

/* Contact grid */
.contact-grid{ margin-top: 8px; gap: 16px; }
.contact-card{
  display: flex; flex-direction: column; gap: 10px;
  padding: 22px;
}
.contact-card h3{ margin: 0; }
.contact-card p{ margin: 0; color: var(--muted); max-width: none; }
.contact-card .btn{ align-self: flex-start; word-break: normal; margin-top: auto; }
.contact-card a:not(.btn){ word-break: break-word; }

/* Company details section on /contact */
.page .contact-section-divider{
  margin: 16px 0 0;
  border: 0;
  border-top: 1px solid var(--border);
}

/* Contact-list rows */
.contact-list{ list-style: none; padding: 0; margin: 14px 0 0; max-width: 62ch; }
.contact-list li{
  display: flex; gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  margin: 0;
}
.contact-list li:last-child{ border-bottom: 0; }
.contact-list li strong{ min-width: 140px; color: var(--text); }
.contact-list li::marker{ content: ""; }

/* Page CTA row */
.page-cta{
  display: flex; gap: 12px;
  justify-content: flex-start; flex-wrap: wrap;
  margin: 0;
  padding-top: 32px;
  border-top: 1px solid var(--border);
}

/* Legal pages get chapter-feel dividers between major sections */
.page--legal .wrap.narrow > section{ padding-top: 8px; }

/* -------- Cookie consent banner -------- */
#cookie-banner{
  position:fixed; left:16px; right:16px; bottom:16px; z-index:100;
  background:var(--surface); color:var(--text);
  border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px 18px;
  max-width:980px; margin-inline:auto;
  animation: cookie-in .25s ease-out;
}
@keyframes cookie-in{ from{ opacity:0; transform:translateY(12px);} to{ opacity:1; transform:none;} }
.cookie-banner-inner{
  display:flex; flex-wrap:wrap; gap:14px 20px;
  align-items:center; justify-content:space-between;
}
.cookie-banner-text{ flex:1 1 340px; font-size:.95rem; color:var(--text); line-height:1.5; }
.cookie-banner-text a{ color:var(--accent); }
.cookie-banner-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.cookie-banner-actions .btn{ min-height:40px; padding:10px 16px; }
@media(max-width:520px){
  #cookie-banner{ left:10px; right:10px; bottom:10px; padding:14px 16px; }
  .cookie-banner-actions{ width:100%; }
  .cookie-banner-actions .btn{ flex:1 1 auto; justify-content:center; }
}

/* Mobile refinements */
@media(max-width:640px){
  .page{ padding: 24px 0 56px; }
  .page .wrap.narrow > * + *{ margin-top: 36px; }
  .page .wrap.narrow > section + section{ margin-top: 22px; padding-top: 22px; }
  .page .wrap.narrow > .breadcrumb + .page-header{ margin-top: 8px; }
  .page .wrap.narrow > .page-header + .toc,
  .page .wrap.narrow > .page-header + section{ margin-top: 24px; }
  .page .wrap.narrow > .toc + section{ margin-top: 24px; }
  .page .wrap.narrow > .page-header + section,
  .page .wrap.narrow > .toc + section{ padding-top:22px; }
  .page .toc{ padding: 16px 18px; }
  .contact-card .btn{ align-self: stretch; justify-content: center; }
  .contact-list li{ flex-direction: column; gap: 2px; }
  .contact-list li strong{ min-width: 0; }
  .page-cta{ padding-top: 24px; }
  .page-cta .btn{ flex: 1 1 auto; justify-content: center; }
}

/* -------- Hub and comparison components -------- */
.section-intro{max-width:72ch;color:var(--muted);margin:0 0 24px}
.use-case-grid,.tool-grid,.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:22px}
.use-case-card,.tool-card,.related-card,.quick-answer,.disclosure-note,.methodology-summary,.content-warning,.data-note{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;
}
.use-case-card,.tool-card,.related-card{display:flex;flex-direction:column;gap:10px;min-width:0}
.use-case-card h3,.tool-card h3,.related-card h3{margin:0}
.use-case-card p,.tool-card p,.related-card p,.quick-answer p,.disclosure-note p,.methodology-summary p,.content-warning p,.data-note p{margin:0;color:var(--muted)}
.quick-answer{border-left:4px solid var(--accent)}
.disclosure-note{border-color:color-mix(in srgb,var(--accent) 38%,var(--border));background:color-mix(in srgb,var(--accent) 7%,var(--surface))}
.content-warning{border-color:var(--danger-border);background:var(--danger-bg)}
.data-note{border-style:dashed}
.component-kicker{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:800}
.badge-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.rating-badge,.price-badge,.content-rating-badge,.last-updated{
  display:inline-flex;align-items:center;gap:4px;border:1px solid var(--border);border-radius:999px;
  padding:4px 10px;font-size:.75rem;font-weight:800;line-height:1.35;white-space:nowrap;
}
.rating-badge{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 34%,var(--border));background:color-mix(in srgb,var(--accent) 10%,transparent)}
.price-badge{color:var(--text);background:var(--surface-2)}
.content-rating-badge{color:var(--danger);border-color:var(--danger-border);background:var(--danger-bg)}
.last-updated{color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.link-cluster{display:flex;flex-wrap:wrap;gap:10px;margin-top:auto}
.table-wrap{width:100%;overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}
.comparison-table{width:100%;border-collapse:collapse;min-width:760px}
.comparison-table th,.comparison-table td{padding:14px 16px;text-align:left;vertical-align:top;border-bottom:1px solid var(--border)}
.comparison-table th{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--surface-2)}
.comparison-table tr:last-child td{border-bottom:0}
.comparison-table td p{margin:.25em 0 0;color:var(--muted);max-width:44ch}
.filter-bar{display:flex;flex-wrap:wrap;gap:12px;margin:0 0 16px}
.filter-bar label{display:flex;flex-direction:column;gap:5px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:800}
.filter-bar select{min-width:170px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:10px 12px;font:inherit}
.faq-list{display:grid;gap:10px}
.empty-state{border-style:dashed;background:color-mix(in srgb,var(--surface) 80%,var(--bg-2))}
.page .comparison-table ul{margin:.2em 0 0;padding-left:1.1em;max-width:none}
.page .comparison-table li{margin:.15em 0}
@media(max-width:720px){
  .filter-bar label,.filter-bar select{width:100%}
  .comparison-table{min-width:680px}
  .use-case-grid,.tool-grid,.related-grid{grid-template-columns:1fr}
}

/* Category comparison sections should read in-place, not as sideways tables. */
.page #compare .table-wrap{
  overflow:visible;
  border:0;
  background:transparent;
}
.page #compare .comparison-table{
  display:block;
  min-width:0;
  width:100%;
  border-collapse:separate;
}
.page #compare .comparison-table thead{
  position:absolute;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
}
.page #compare .comparison-table tbody{
  display:grid;
  gap:12px;
}
.page #compare .comparison-table tr{
  display:grid;
  gap:10px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
}
.page #compare .comparison-table td{
  display:grid;
  grid-template-columns:minmax(112px,.36fr) 1fr;
  gap:12px;
  align-items:start;
  border:0;
  padding:0;
  min-width:0;
}
.page #compare .comparison-table td::before{
  color:var(--muted);
  content:"Detail";
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.08em;
  line-height:1.45;
  text-transform:uppercase;
}
.page #compare .comparison-table td:nth-child(1)::before{content:"Focus"}
.page #compare .comparison-table td:nth-child(2)::before{content:"Compare"}
.page #compare .comparison-table td:nth-child(3)::before{content:"Best for"}
.page #compare .comparison-table td:nth-child(4)::before{content:"Pricing"}
.page #compare .comparison-table td:nth-child(5)::before{content:"Next step"}
.page #compare .comparison-table td:first-child{
  color:var(--text);
  font-weight:800;
}
.page #compare .comparison-table .btn{
  width:fit-content;
}
@media(max-width:520px){
  .page #compare .comparison-table td{
    grid-template-columns:1fr;
    gap:4px;
  }
}
.compare-list{
  display:grid;
  gap:12px;
}
.compare-row{
  display:grid;
  gap:14px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  min-width:0;
}
.compare-row h3{
  margin:0;
}
.compare-row dl{
  display:grid;
  gap:10px;
  margin:0;
}
.compare-row dl > div{
  display:grid;
  grid-template-columns:minmax(112px,.34fr) 1fr;
  gap:12px;
  min-width:0;
}
.compare-row dt{
  color:var(--muted);
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.08em;
  line-height:1.45;
  text-transform:uppercase;
}
.compare-row dd{
  margin:0;
  min-width:0;
}
.compare-row a{
  justify-self:start;
  font-weight:700;
}
@media(max-width:520px){
  .compare-row dl > div{
    grid-template-columns:1fr;
    gap:3px;
  }
}
