/* =========================================================================
   dexwatch — "X vs Y" static comparison landing pages
   Pairs with portal.css (which carries the .cmp-table styles).
   ========================================================================= */

.vs-main { padding: 32px 0 80px; max-width: 1000px; }

.vs-hero { max-width: 780px; margin-bottom: 26px; }
.vs-eyebrow { font-family: var(--font-mono); font-size: 12px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: color-mix(in oklch, var(--accent) 70%, var(--ink)); }
.vs-title { font-size: clamp(28px, 4.2vw, 46px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.04; margin: 12px 0 14px; }
.vs-title .vs-x { color: var(--ink-faint); font-weight: 500; font-size: 0.62em; vertical-align: 0.12em; margin: 0 0.18em; }
.vs-lead { color: var(--ink-2); font-size: clamp(15px, 1.7vw, 18px); line-height: 1.55; text-wrap: pretty; }

/* at-a-glance verdict cards */
.vs-section-h { font-size: clamp(19px, 2.2vw, 23px); letter-spacing: -0.02em; margin: 40px 0 16px; }
.vs-verdicts { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
.vs-verdict { padding: 15px 16px; background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-md); }
.vs-verdict .vl { font-family: var(--font-mono); font-size: 10.5px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-faint); }
.vs-verdict .vw { display: flex; align-items: center; gap: 8px; margin-top: 9px; font-weight: 750; font-size: 15.5px; letter-spacing: -0.01em; color: var(--ink); }
.vs-verdict .vw .mono-badge { width: 22px; height: 22px; font-size: 10px; border-radius: 6px; }
.vs-verdict .vv { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 12.5px; color: var(--ink-3); margin-top: 5px; }
.vs-verdict.tie .vw { color: var(--ink-3); }

/* table intro note */
.vs-tablenote { font-size: 13px; color: var(--ink-3); margin: 0 0 14px; }

/* CTA grid */
.vs-cta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 16px; }
@media (max-width: 620px){ .vs-cta-grid { grid-template-columns: 1fr; } }
.vs-cta-card { display: flex; flex-direction: column; gap: 12px; padding: 20px; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--bg-elev); }
.vs-cta-id { display: flex; align-items: center; gap: 12px; }
.vs-cta-id .nm { font-weight: 750; font-size: 17px; letter-spacing: -0.01em; }
.vs-cta-id .tk { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); margin-top: 2px; }
.vs-cta-card .btn { width: 100%; }
.vs-cta-card .vs-profile { font-size: 12.5px; color: var(--accent); font-weight: 600; text-align: center; }
.vs-disclosure { font-size: 11.5px; color: var(--ink-faint); line-height: 1.45; margin-top: 14px; }

/* customise strip */
.vs-customise { margin-top: 22px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 18px 22px; border-radius: var(--r-lg); background: var(--accent-wash); border: 1px solid var(--accent-line); }
.vs-customise h3 { font-size: 16px; }
.vs-customise p { font-size: 13px; color: var(--ink-2); margin-top: 2px; }

/* faq */
.vs-faq { display: flex; flex-direction: column; gap: 10px; }
.vs-faq details { background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-md); padding: 0 18px; }
.vs-faq summary { cursor: pointer; list-style: none; padding: 15px 0; font-weight: 650; font-size: 15px; color: var(--ink); display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.vs-faq summary::-webkit-details-marker { display: none; }
.vs-faq summary::after { content: "+"; font-family: var(--font-mono); font-size: 18px; color: var(--ink-faint); flex: none; }
.vs-faq details[open] summary::after { content: "\2212"; }
.vs-faq .vs-faq-a { padding: 0 0 16px; font-size: 14.5px; line-height: 1.6; color: var(--ink-2); text-wrap: pretty; }

/* related + learn chips */
.vs-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.vs-chip { display: inline-flex; align-items: center; gap: 7px; padding: 7px 13px; background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-pill); font-size: 13.5px; font-weight: 600; color: var(--ink-2); transition: border-color .14s, color .14s; }
.vs-chip:hover { border-color: var(--accent-line); color: var(--ink); }
.vs-chip-lesson { background: var(--accent-wash); border-color: var(--accent-line); color: color-mix(in oklch, var(--accent) 62%, var(--ink)); }
.vs-chip .mono-badge { width: 18px; height: 18px; font-size: 9px; border-radius: 5px; }
.vs-sub { display: block; font-family: var(--font-mono); font-size: 11.5px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); margin: 26px 0 11px; }