/* firm-comparison.css — programmatic funded-firm comparison / landing pages.
   Built by tools/build-firm-comparison-pages.mjs. Reuses style.css design tokens. */

.cmp-wrap { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-4); }
.cmp-narrow { max-width: var(--container-narrow); }

.cmp-hero { padding: var(--space-8) 0 var(--space-6); border-bottom: 1px solid var(--line); }
.cmp-breadcrumb { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--bone-3); margin: 0 0 var(--space-4); }
.cmp-breadcrumb a { color: var(--bone-3); text-decoration: none; }
.cmp-breadcrumb a:hover { color: var(--edge); }
.cmp-hero h1 { font-family: var(--font-display); font-size: var(--t-3xl); line-height: 1.06; margin: 0 0 var(--space-4); }
.cmp-lede { color: var(--bone-2); font-size: var(--t-md); max-width: 760px; margin: 0; }
.cmp-meta { margin-top: var(--space-5); font-family: var(--font-mono); font-size: var(--t-xs); color: var(--bone-3); display: flex; flex-wrap: wrap; gap: var(--space-4); }

.cmp-section { padding: var(--space-7) 0; border-bottom: 1px solid var(--line); }
.cmp-section > h2 { font-family: var(--font-display); font-size: var(--t-2xl); margin: 0 0 var(--space-2); }
.cmp-section__sub { color: var(--bone-3); font-size: var(--t-sm); margin: 0 0 var(--space-5); }
.cmp-body p { color: var(--bone-2); max-width: 760px; }
.cmp-body p + p { margin-top: var(--space-4); }

.cmp-verdict { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.cmp-verdict article { border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--space-5); background: var(--ink-2); }
.cmp-verdict h3 { font-family: var(--font-display); font-size: var(--t-lg); margin: 0 0 var(--space-3); color: var(--edge); }
.cmp-verdict p { color: var(--bone-2); font-size: var(--t-sm); margin: 0; }
.cmp-verdict p + p { margin-top: var(--space-3); }
.cmp-verdict dt,
.cmp-verdict .cmp-vk { font-family: var(--font-mono); font-size: var(--t-xs); text-transform: uppercase; color: var(--bone-3); margin: 0 0 var(--space-1); }
.cmp-verdict .cmp-vk + p { margin-top: 0; }

.cmp-glossary { display: grid; gap: var(--space-4); margin: 0; max-width: 760px; }
.cmp-glossary > div { display: grid; gap: var(--space-1); }
.cmp-glossary dt { font-family: var(--font-display); font-size: var(--t-base); color: var(--bone); }
.cmp-glossary dd { margin: 0; color: var(--bone-2); font-size: var(--t-sm); }

.cmp-table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--r-lg); }
.cmp-table { width: 100%; border-collapse: collapse; min-width: 640px; }
.cmp-table th, .cmp-table td { padding: var(--space-4); text-align: left; border-bottom: 1px solid var(--line); vertical-align: top; }
.cmp-table tr:last-child th, .cmp-table tr:last-child td { border-bottom: 0; }
.cmp-table thead th { font-family: var(--font-display); font-size: var(--t-base); background: var(--ink-3); }
.cmp-table tbody th[scope="row"] { font-family: var(--font-mono); font-size: var(--t-xs); text-transform: uppercase; color: var(--bone-3); width: 180px; }
.cmp-table td { color: var(--bone-2); font-size: var(--t-sm); }

.cmp-firm-list { display: grid; gap: var(--space-4); }
.cmp-firm-card { border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--space-5); background: var(--ink-2); }
.cmp-firm-card__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-3); }
.cmp-firm-card__head h3 { font-family: var(--font-display); font-size: var(--t-lg); margin: 0; }
.cmp-firm-card__head a { color: var(--bone); text-decoration: none; }
.cmp-firm-card__head a:hover { color: var(--edge); }
.cmp-rank { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--bone-3); white-space: nowrap; }
.cmp-metric { color: var(--bone); font-size: var(--t-sm); margin: 0 0 var(--space-4); padding: var(--space-3) var(--space-4); background: var(--ink-3); border-radius: var(--r-md); border-left: 2px solid var(--edge); }
.cmp-firm-card dl { display: grid; grid-template-columns: auto 1fr; gap: var(--space-2) var(--space-4); margin: 0; }
.cmp-firm-card dt { font-family: var(--font-mono); font-size: var(--t-xs); text-transform: uppercase; color: var(--bone-3); }
.cmp-firm-card dd { margin: 0; color: var(--bone-2); font-size: var(--t-sm); }

.cmp-cta { display: grid; gap: var(--space-4); background: var(--ink-2); border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--space-6); }
.cmp-cta h2 { margin: 0; font-size: var(--t-xl); }
.cmp-cta p { margin: 0; color: var(--bone-2); }
.cmp-cta__row { display: flex; flex-wrap: wrap; gap: var(--space-3); }

.cmp-faq { display: grid; gap: var(--space-3); }
.cmp-faq details { border: 1px solid var(--line); border-radius: var(--r-md); padding: var(--space-4) var(--space-5); background: var(--ink-2); }
.cmp-faq summary { font-family: var(--font-display); font-size: var(--t-md); cursor: pointer; color: var(--bone); }
.cmp-faq summary::marker { color: var(--edge); }
.cmp-faq p { color: var(--bone-2); margin: var(--space-3) 0 0; font-size: var(--t-sm); }

.cmp-sources { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.cmp-sources a { display: inline-flex; padding: var(--space-2) var(--space-3); border: 1px solid var(--line); border-radius: var(--r-sm); font-size: var(--t-xs); color: var(--bone-2); text-decoration: none; }
.cmp-sources a:hover { border-color: var(--edge); color: var(--bone); }

.cmp-disclaimer { color: var(--bone-3); font-size: var(--t-sm); border-left: 2px solid var(--edge); padding-left: var(--space-4); max-width: 760px; }

.cmp-related { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-4); }
.cmp-related a { display: block; border: 1px solid var(--line); border-radius: var(--r-md); padding: var(--space-4); color: var(--bone); text-decoration: none; background: var(--ink-2); }
.cmp-related a:hover { border-color: var(--edge); }
.cmp-related span { display: block; font-family: var(--font-mono); font-size: var(--t-xs); color: var(--bone-3); margin-top: var(--space-2); }

@media (max-width: 720px) {
  .cmp-verdict { grid-template-columns: 1fr; }
  .cmp-hero h1 { font-size: var(--t-2xl); }
  .cmp-firm-card__head { flex-direction: column; }
}
