/* =============================================================
   NextHire — Comparison & article pages
   Builds on tokens.css (palette, type, nh-* components, motion).
   Static, crawlable, editorial. Motion = progressive enhancement.
   ============================================================= */

/* ---------- Reveal (matches landing's IntersectionObserver pattern) ---------- */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity var(--t-long) var(--ease-standard), transform var(--t-long) var(--ease-standard); }
.reveal.in { opacity: 1; transform: none; }
.reveal-stagger > * { opacity: 0; transform: translateY(12px); transition: opacity var(--t-long) var(--ease-standard), transform var(--t-long) var(--ease-standard); }
.reveal-stagger.in > * { opacity: 1; transform: none; }
.reveal-stagger.in > *:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger.in > *:nth-child(2) { transition-delay: 60ms; }
.reveal-stagger.in > *:nth-child(3) { transition-delay: 120ms; }
.reveal-stagger.in > *:nth-child(4) { transition-delay: 180ms; }
.reveal-stagger.in > *:nth-child(5) { transition-delay: 240ms; }
.reveal-stagger.in > *:nth-child(6) { transition-delay: 300ms; }
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-stagger > * { opacity: 1 !important; transform: none !important; }
}

/* ---------- Nav (static) ---------- */
.cmp-nav { position: sticky; top: 0; z-index: 50; background: color-mix(in oklab, var(--bone-50) 86%, transparent); backdrop-filter: saturate(140%) blur(8px); border-bottom: 1px solid transparent; transition: border-color var(--t-med) var(--ease-snappy); }
.cmp-nav.is-scrolled { border-bottom-color: var(--ink-100); }
.cmp-nav__inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.cmp-nav__brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; }

/* ---------- Breadcrumb ---------- */
.cmp-crumbs { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin: 0; padding: 0; list-style: none; }
.cmp-crumbs li { display: inline-flex; align-items: center; gap: 8px; }
.cmp-crumbs li::after { content: '/'; color: var(--ink-300); }
.cmp-crumbs li:last-child::after { content: none; }
.cmp-crumbs a { color: var(--ink-500); text-decoration: none; }
.cmp-crumbs a:hover { color: var(--ember-600); }
.cmp-crumbs span[aria-current] { color: var(--ink-700); }

/* ---------- Hero ---------- */
.cmp-hero { padding: var(--s-16) 0 var(--s-12); }
.cmp-hero__vs { display: inline-flex; align-items: center; gap: var(--s-4); margin: var(--s-6) 0 var(--s-5); }
.cmp-hero__logo { display: inline-flex; align-items: center; gap: 10px; font-weight: 600; letter-spacing: -0.02em; color: var(--ink-900); }
.cmp-hero__logo img { height: 26px; width: auto; display: block; }
.cmp-hero__x { font-family: var(--font-display); font-size: 1.5rem; color: var(--ink-300); font-variation-settings: "opsz" 36; }
.cmp-h1 { max-width: 20ch; margin: 0 0 var(--s-6); font-size: var(--t-display-xl); line-height: 1.02; letter-spacing: -0.03em; font-variation-settings: "SOFT" 30, "opsz" 96; }
.cmp-lede { max-width: 60ch; margin: 0 0 var(--s-8); }
.cmp-hero__ctas { display: flex; gap: var(--s-3); flex-wrap: wrap; align-items: center; }
.cmp-updated { margin-top: var(--s-6); }

/* ---------- Verdict / answer-first box (AEO-critical, extractable) ---------- */
.cmp-verdict { background: var(--bone-100); border: 1px solid var(--ink-100); border-radius: var(--r-card); padding: var(--s-8); margin: var(--s-10) 0; }
.cmp-verdict__label { display: inline-flex; align-items: center; gap: var(--s-2); margin-bottom: var(--s-4); }
.cmp-verdict p { margin: 0 0 var(--s-4); max-width: 70ch; }
.cmp-verdict p:last-child { margin-bottom: 0; }
.cmp-verdict strong { color: var(--ink-900); font-weight: 600; }

/* ---------- Prose ---------- */
.cmp-section { padding: var(--s-16) 0; }
.cmp-section--alt { background: var(--bone-100); }
/* Section headings sit a step below the page H1 (match homepage rhythm). */
.cmp-section h2.display-xl, .cmp-cta h2.display-xl { font-size: var(--t-display-l); letter-spacing: -0.025em; font-variation-settings: "SOFT" 30, "opsz" 72; }
.cmp-prose { max-width: var(--measure); }
.cmp-prose h2 { margin: 0 0 var(--s-5); }
.cmp-prose h3 { font-family: var(--font-display); font-weight: 500; font-size: var(--t-display-m); letter-spacing: -0.02em; margin: var(--s-10) 0 var(--s-3); color: var(--ink-900); }
.cmp-prose p { color: var(--ink-700); font-size: var(--t-body-m); line-height: 1.65; margin: 0 0 var(--s-5); }
.cmp-prose p > strong { color: var(--ink-900); font-weight: 600; }
.cmp-prose ul { margin: 0 0 var(--s-6); padding: 0; list-style: none; }
.cmp-prose li { position: relative; padding-left: var(--s-6); margin-bottom: var(--s-3); color: var(--ink-700); font-size: var(--t-body-m); line-height: 1.6; }
.cmp-prose li::before { content: ''; position: absolute; left: 2px; top: 11px; width: 6px; height: 6px; border-radius: 50%; background: var(--ember-600); }

/* ---------- Comparison table ---------- */
.cmp-table-wrap { margin: var(--s-8) 0; }
.cmp-table { width: 100%; border-collapse: collapse; font-size: var(--t-body-m); }
.cmp-table caption { text-align: left; color: var(--ink-500); font-size: var(--t-body-s); margin-bottom: var(--s-4); }
.cmp-table thead th { text-align: left; padding: var(--s-4) var(--s-4); font-weight: 600; font-size: var(--t-body-s); vertical-align: bottom; border-bottom: 2px solid var(--ink-200); }
.cmp-table thead th:first-child { color: var(--ink-500); font-weight: 500; }
.cmp-table thead .cmp-col-nh { color: var(--ink-900); }
.cmp-table thead .cmp-col-nh .cmp-col-tag { display: inline-block; margin-top: 4px; }
.cmp-table tbody th { text-align: left; font-weight: 500; color: var(--ink-900); padding: var(--s-4); vertical-align: top; width: 26%; }
.cmp-table tbody td { padding: var(--s-4); vertical-align: top; color: var(--ink-700); border-top: 1px solid var(--ink-100); line-height: 1.5; }
.cmp-table tbody th { border-top: 1px solid var(--ink-100); }
.cmp-table .cmp-col-nh { background: color-mix(in oklab, var(--ember-100) 38%, transparent); color: var(--ink-900); }
.cmp-table tbody tr:hover td:not(.cmp-col-nh) { background: color-mix(in oklab, var(--bone-100) 60%, transparent); }
.cmp-ic { display: inline-block; vertical-align: -2px; margin-right: 6px; }
.cmp-ic--yes { color: var(--ok-600); }
.cmp-ic--no { color: var(--ink-300); }
.cmp-ic--mid { color: var(--ember-700); }
@media (max-width: 720px) {
  .cmp-table, .cmp-table thead, .cmp-table tbody, .cmp-table th, .cmp-table td, .cmp-table tr { display: block; }
  .cmp-table thead { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
  .cmp-table tbody tr { border: 1px solid var(--ink-100); border-radius: var(--r-card); margin-bottom: var(--s-4); padding: var(--s-3); }
  .cmp-table tbody th { width: auto; border: 0; padding-bottom: var(--s-1); font-size: var(--t-body-m); }
  .cmp-table tbody td { border: 0; padding: var(--s-2) var(--s-3); }
  .cmp-table tbody td::before { content: attr(data-label); display: block; font-size: var(--t-eyebrow); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-500); margin-bottom: 2px; }
  .cmp-table .cmp-col-nh { border-radius: var(--r-input); }
}

/* ---------- Two-column "best for" cards ---------- */
.cmp-split { display: grid; grid-template-columns: 1fr; gap: var(--s-5); margin: var(--s-8) 0; }
@media (min-width: 860px) { .cmp-split { grid-template-columns: 1fr 1fr; gap: var(--s-6); } }
.cmp-pick { border: 1px solid var(--ink-100); border-radius: var(--r-card); padding: var(--s-8); background: var(--bone-50); }
.cmp-pick--nh { border-color: color-mix(in oklab, var(--ember-600) 28%, var(--ink-100)); background: color-mix(in oklab, var(--ember-50) 50%, var(--bone-50)); }
.cmp-pick h3 { font-family: var(--font-display); font-weight: 500; font-size: var(--t-display-m); letter-spacing: -0.02em; margin: 0 0 var(--s-4); }
.cmp-pick ul { list-style: none; margin: 0; padding: 0; }
.cmp-pick li { position: relative; padding-left: var(--s-6); margin-bottom: var(--s-3); color: var(--ink-700); line-height: 1.5; }
.cmp-pick li::before { content: ''; position: absolute; left: 2px; top: 9px; width: 6px; height: 6px; border-radius: 50%; background: var(--ink-300); }
.cmp-pick--nh li::before { background: var(--ember-600); }

/* ---------- Feature deep-dive blocks ---------- */
.cmp-feature { display: grid; grid-template-columns: 1fr; gap: var(--s-4); padding: var(--s-10) 0; border-top: 1px solid var(--ink-100); }
.cmp-feature:first-of-type { border-top: 0; }
@media (min-width: 860px) { .cmp-feature { grid-template-columns: 0.85fr 1.15fr; gap: var(--s-12); } }
.cmp-feature__k { font-family: var(--font-mono); font-size: var(--t-mono-m); color: var(--ink-500); }
.cmp-feature h3 { font-family: var(--font-display); font-weight: 500; font-size: var(--t-display-m); letter-spacing: -0.02em; margin: var(--s-2) 0 var(--s-4); color: var(--ink-900); }
.cmp-feature p { color: var(--ink-700); font-size: var(--t-body-m); line-height: 1.65; margin: 0 0 var(--s-4); }

/* ---------- FAQ ---------- */
.cmp-faq { max-width: var(--measure); }
.cmp-faq details { border-top: 1px solid var(--ink-100); padding: var(--s-5) 0; }
.cmp-faq details[open] summary .cmp-faq__chev { transform: rotate(45deg); }
.cmp-faq summary { display: flex; justify-content: space-between; align-items: center; gap: var(--s-4); cursor: pointer; list-style: none; font-family: var(--font-display); font-weight: 500; font-size: var(--t-display-s); letter-spacing: -0.015em; color: var(--ink-900); }
.cmp-faq summary::-webkit-details-marker { display: none; }
.cmp-faq__chev { flex-shrink: 0; color: var(--ink-500); transition: transform var(--t-med) var(--ease-snappy); }
.cmp-faq__a { margin: var(--s-4) 0 0; color: var(--ink-700); font-size: var(--t-body-m); line-height: 1.65; max-width: 64ch; }

/* ---------- CTA band ---------- */
.cmp-cta { background: var(--ink-900); color: var(--bone-100); border-radius: var(--r-card); padding: var(--s-16) var(--s-10); text-align: center; margin: var(--s-16) 0 0; }
.cmp-cta h2 { color: var(--bone-50); margin: 0 auto var(--s-5); max-width: 20ch; }
.cmp-cta p { color: var(--ink-300); max-width: 52ch; margin: 0 auto var(--s-8); font-size: var(--t-body-l); }
.cmp-cta__ctas { display: flex; gap: var(--s-3); justify-content: center; flex-wrap: wrap; }
/* Ghost button on the dark CTA band: keep light text on a subtle dark hover (never light-on-light). */
.cmp-cta .nh-btn--ghost { color: var(--bone-100); border-color: var(--ink-700); background: transparent; }
.cmp-cta .nh-btn--ghost:hover { color: var(--bone-50); border-color: var(--bone-100); background: rgba(251, 249, 244, 0.10); }
.cmp-cta .nh-btn--ghost:active { background: rgba(251, 249, 244, 0.16); }
.cmp-cta .nh-btn--ghost:focus-visible { outline: 2px solid var(--ember-600); outline-offset: 2px; }

/* ---------- Footer (ported 1:1 from the homepage styles.css) ---------- */
.footer { background: var(--ink-900); color: var(--bone-100); padding: 72px 0 32px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 56px; }
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; } }
.footer-grid h4 { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-300); font-weight: 500; margin: 0 0 16px 0; }
.footer-grid ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer-grid a { color: var(--bone-100); font-size: 14px; text-decoration: none; transition: color var(--t-fast) var(--ease-snappy); }
.footer-grid a:hover { color: var(--ember-600); }
.footer__lockup { display: flex; align-items: center; gap: 12px; }
.footer__lockup .nh-wordmark { color: var(--bone-50); font-size: 22px; }
.footer__tag { color: var(--ink-300); font-size: 14px; max-width: 36ch; line-height: 1.55; margin: 16px 0 0 0; }
.footer-bottom { margin-top: 48px; padding-top: 22px; border-top: 1px solid rgba(216,213,205,0.15); display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 12px; color: var(--ink-300); letter-spacing: 0.04em; }
.footer-grid.footer-grid--2 { grid-template-columns: 1.6fr 1fr; gap: 56px; align-items: start; }
@media (max-width: 800px) { .footer-grid.footer-grid--2 { grid-template-columns: 1fr; gap: 36px; } }
.footer__ctas { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.footer__contact ul { display: flex; flex-direction: column; gap: 24px; }
.footer__contact li { display: flex; flex-wrap: wrap; align-items: center; gap: 10px 14px; }
.footer__contact-name { font-weight: 600; font-size: 15px; color: var(--bone-50); }
.footer__contact-cal { flex: 0 0 auto; border: 0; background: none; box-shadow: none; padding: 0; height: auto; gap: 6px; color: var(--bone-50); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; min-height: 0; }
.footer__contact-cal:hover { background: none; text-decoration-thickness: 2px; }
.footer__contact-email { flex-basis: 100%; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.02em; color: var(--ink-500); }
.footer__contact-email:hover { color: var(--bone-50); }
.footer__compare { margin-top: 24px; display: flex; gap: 18px; flex-wrap: wrap; }
.footer__compare a { color: var(--bone-200); font-size: 13px; text-decoration: none; transition: color var(--t-fast) var(--ease-snappy); }
.footer__compare a:hover { color: var(--ember-600); }

/* ---------- Sources note ---------- */
.cmp-sources { margin-top: var(--s-10); padding-top: var(--s-6); border-top: 1px solid var(--ink-100); }
.cmp-sources p { font-size: var(--t-mono-s); font-family: var(--font-mono); color: var(--ink-500); line-height: 1.6; max-width: 70ch; }
