/* compare.css — shared styles for /compare/ hub + pair detail pages.
   Builds on /css/design-system.css for tokens; do not redefine palette.
   Mobile-first: base = single column, breakpoints at 640 / 1024. */

/* ── Brand wordmarks ─────────────────────────────────────────────── */
.prov-wordmark {
  font-family: var(--font-display, "Manrope", system-ui, sans-serif);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: 0.02em;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  color: var(--color-text-primary);
}
.prov-wordmark--polar    { color: #d31835; letter-spacing: 0.08em; }
.prov-wordmark--fitbit   { color: #00B0B9; text-transform: lowercase; font-weight: 700; letter-spacing: 0; }
.prov-wordmark--withings { color: #169CBE; text-transform: lowercase; font-weight: 600; letter-spacing: -0.01em; }
.prov-wordmark--strava   { color: #FC4C02; letter-spacing: 0.08em; }
.prov-wordmark--garmin   { color: var(--color-text-primary); letter-spacing: 0.04em; }
.prov-wordmark--oura     { letter-spacing: 0.18em; font-weight: 700; }
.prov-wordmark--whoop    { letter-spacing: 0.1em; font-weight: 800; }
.prov-wordmark--suunto   { letter-spacing: 0.06em; font-weight: 700; }
.prov-wordmark--coros    { letter-spacing: 0.1em; }
.prov-wordmark--amazfit  { letter-spacing: 0.01em; text-transform: none; font-weight: 700; }
html.dark .prov-wordmark--garmin,
html.dark .prov-wordmark--oura,
html.dark .prov-wordmark--whoop,
html.dark .prov-wordmark--suunto,
html.dark .prov-wordmark--coros,
html.dark .prov-wordmark--amazfit { color: #f5f7fa; }

/* Smaller variant used inside table headers and vs cards */
.prov-th { font-size: 13px; font-weight: 700; letter-spacing: 0.04em; }
.prov-th--polar    { color: #d31835; }
.prov-th--fitbit   { color: #00B0B9; text-transform: lowercase; }
.prov-th--withings { color: #169CBE; text-transform: lowercase; }
.prov-th--strava   { color: #FC4C02; }
.prov-th--garmin   { color: var(--color-text-primary); }
.prov-th--oura     { letter-spacing: 0.16em; }
.prov-th--whoop    { letter-spacing: 0.08em; }
.prov-th--suunto   { letter-spacing: 0.06em; }
.prov-th--coros    { letter-spacing: 0.08em; }
.prov-th--amazfit  { letter-spacing: 0.01em; text-transform: none; }

/* ── Shared utilities ───────────────────────────────────────────── */
.cmp-label {
  display: inline-block;
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--primary, #00f0ff);
  margin-bottom: 12px;
}
.cmp-h1 {
  font-family: var(--font-display, "Manrope", system-ui, sans-serif);
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
  margin: 0 0 18px;
}
.cmp-h2 {
  font-family: var(--font-display, "Manrope", system-ui, sans-serif);
  font-size: clamp(26px, 3.5vw, 42px);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -0.015em;
  color: var(--color-text-primary);
  margin: 0 0 10px;
}
.cmp-sub {
  font-size: 16px;
  line-height: 1.65;
  color: var(--text-secondary);
  max-width: 70ch;
  margin: 0 0 32px;
}
.cmp-note {
  font-size: 12px;
  color: var(--text-muted);
  margin: 16px 0 0;
  font-style: italic;
}

/* ── Hero ────────────────────────────────────────────────────────── */
.cmp-hero {
  padding: 120px 0 64px;
  background: var(--color-bg-deep);
  position: relative;
  overflow: hidden;
}
.cmp-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(0,240,255,0.07), transparent 55%),
    radial-gradient(ellipse at 80% 50%, rgba(123,47,247,0.05), transparent 55%);
  pointer-events: none;
}
.cmp-hero-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
  position: relative;
  z-index: 1;
}
.cmp-eyebrow {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--primary, #00f0ff);
  margin-bottom: 16px;
}
.cmp-lede {
  font-size: clamp(16px, 2vw, 19px);
  line-height: 1.6;
  color: var(--text-secondary);
  max-width: 64ch;
  margin: 0 0 32px;
}
.cmp-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 48px;
}
.cmp-hero-actions .btn { font-size: 15px; padding: 12px 24px; }
.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 24px;
  border-radius: 50px;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid var(--color-border-medium);
  color: var(--color-text-primary);
  background: transparent;
  transition: background 0.2s, border-color 0.2s;
}
.btn-ghost:hover { background: var(--color-bg-card); border-color: var(--primary); }
.cmp-hero-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding-top: 32px;
  border-top: 1px solid var(--color-border-subtle);
}
.cmp-stat { display: flex; flex-direction: column; gap: 2px; }
.cmp-stat-n {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 800;
  color: var(--primary, #00f0ff);
  line-height: 1;
}
.cmp-stat-l {
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ── Provider grid ──────────────────────────────────────────────── */
.cmp-providers { padding: 80px 0; background: var(--color-bg-primary); }
.cmp-providers-inner { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.prov-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 40px;
}
.prov-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 24px;
  border-radius: 18px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.prov-card:hover {
  transform: translateY(-3px);
  border-color: var(--primary, #00f0ff);
  box-shadow: 0 16px 40px rgba(0,240,255,0.06);
}
.prov-card.prov-pending { border-style: dashed; }
.prov-card.prov-await   { opacity: 0.92; }

.prov-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  min-height: 40px;
}
.prov-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 50px;
  border: 1px solid;
  white-space: nowrap;
}
.prov-status--live     { color: var(--success, #00ff88); background: rgba(0,255,136,0.08); border-color: rgba(0,255,136,0.3); }
.prov-status--manual   { color: #04853a; background: rgba(4,133,58,0.08); border-color: rgba(4,133,58,0.3); }
.prov-status--pending  { color: #f7b500; background: rgba(247,181,0,0.08); border-color: rgba(247,181,0,0.3); }
.prov-status--await    { color: var(--text-muted); background: rgba(71,85,105,0.08); border-color: rgba(71,85,105,0.25); border-style: dashed; }

.prov-cat { font-size: 13px; color: var(--text-secondary); margin: 0; line-height: 1.5; }
.prov-pills {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.prov-pill {
  font-size: 11px;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: 50px;
  background: rgba(0,255,136,0.1);
  color: var(--success, #00ff88);
  border: 1px solid rgba(0,255,136,0.2);
}
.prov-pill--via {
  background: rgba(252,76,2,0.08);
  color: #FC4C02;
  border-color: rgba(252,76,2,0.25);
}
.prov-pill--no {
  background: rgba(71,85,105,0.08);
  color: var(--text-muted);
  border-color: rgba(71,85,105,0.2);
}
.prov-best {
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-muted);
  margin: auto 0 0;
  padding-top: 10px;
}
.prov-best strong { color: var(--color-text-primary); }
.prov-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  padding-top: 6px;
}
.prov-btn {
  flex: 1 1 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 50px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid;
  transition: background 0.2s, transform 0.15s;
  white-space: nowrap;
}
.prov-btn--connect {
  color: var(--primary, #00f0ff);
  background: rgba(0,240,255,0.08);
  border-color: rgba(0,240,255,0.3);
}
.prov-btn--connect:hover { background: rgba(0,240,255,0.16); }
.prov-btn--waitlist {
  color: #f7b500;
  background: rgba(247,181,0,0.08);
  border-color: rgba(247,181,0,0.3);
}
.prov-btn--waitlist:hover { background: rgba(247,181,0,0.16); }
.prov-btn--buy {
  color: var(--color-text-primary);
  background: var(--color-bg-surface);
  border-color: var(--color-border-medium);
}
.prov-btn--buy:hover {
  background: var(--color-bg-card);
  border-color: var(--primary);
  transform: translateY(-1px);
}

/* ── Signal matrix table ────────────────────────────────────────── */
.cmp-matrix { padding: 56px 0 64px; background: var(--color-bg-deep); }
.cmp-matrix-inner { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.cmp-table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-top: 24px;
  border-radius: 12px;
  border: 1px solid var(--color-border-subtle);
}
.cmp-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 820px;
  font-family: var(--font-body, "Manrope");
  font-size: 12px;
  background: var(--color-bg-card);
}
.cmp-table thead th {
  position: sticky;
  top: 0;
  background: var(--color-bg-card);
  font-weight: 700;
  font-size: 11px;
  color: var(--color-text-primary);
  padding: 9px 6px;
  text-align: center;
  border-bottom: 2px solid var(--color-border-medium);
  z-index: 2;
  white-space: nowrap;
}
.cmp-table thead th:first-child { text-align: left; padding-left: 14px; }
.cmp-table tbody td {
  padding: 5px 6px;
  text-align: center;
  border-bottom: 1px solid var(--color-border-subtle);
  color: var(--text-secondary);
  line-height: 1.3;
}
.cmp-table tbody td:first-child {
  position: sticky;
  left: 0;
  background: var(--color-bg-card);
  text-align: left;
  font-weight: 500;
  color: var(--color-text-primary);
  padding-left: 14px;
  z-index: 1;
}
.cmp-table .cmp-cat td {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--primary, #00f0ff);
  padding: 9px 14px 3px;
  border-bottom: 1px solid rgba(0,240,255,0.18);
  background: var(--color-bg-card);
  position: sticky;
  left: 0;
  text-align: left;
}
.cmp-table .y { color: var(--success, #00ff88); font-weight: 700; font-size: 13px; }
.cmp-table .n { color: var(--text-muted); font-size: 12px; }
.cmp-table tfoot td {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 12px;
  color: var(--color-text-primary);
  padding: 10px 6px;
  border-top: 2px solid var(--color-border-medium);
  background: var(--color-bg-deep);
  text-align: center;
}
.cmp-table tfoot td:first-child { text-align: left; padding-left: 14px; position: sticky; left: 0; background: var(--color-bg-deep); }
.cmp-table tfoot .tot { color: var(--primary, #00f0ff); }

/* ── Decision guide ─────────────────────────────────────────────── */
.cmp-decision { padding: 80px 0; background: var(--color-bg-primary); }
.cmp-decision-inner { max-width: 980px; margin: 0 auto; padding: 0 24px; }
.cmp-persona-grid {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 32px;
}
.cmp-persona {
  border-radius: 14px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
  overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.cmp-persona[open] {
  border-color: var(--primary, #00f0ff);
  box-shadow: 0 10px 32px rgba(0,240,255,0.06);
}
.cmp-persona summary {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 16px;
  color: var(--color-text-primary);
  transition: background 0.2s;
}
.cmp-persona summary::-webkit-details-marker { display: none; }
.cmp-persona summary::after {
  content: '+';
  margin-left: auto;
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 20px;
  color: var(--text-muted);
  transition: transform 0.2s;
}
.cmp-persona[open] summary::after { content: '−'; }
.cmp-persona summary:hover { background: rgba(0,240,255,0.04); }
.cmp-persona-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(0,240,255,0.08);
  color: var(--primary, #00f0ff);
  flex-shrink: 0;
}
.cmp-persona-body {
  padding: 0 22px 22px 68px;
  font-size: 14px;
  line-height: 1.65;
  color: var(--text-secondary);
}
.cmp-persona-body p { margin: 0 0 12px; }
.cmp-persona-link {
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  color: var(--primary, #00f0ff);
  text-decoration: none;
  margin-top: 4px;
}
.cmp-persona-link:hover { text-decoration: underline; }

/* ── Pair grid ──────────────────────────────────────────────────── */
.cmp-pairs { padding: 80px 0; background: var(--color-bg-deep); }
.cmp-pairs-inner { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.cmp-pair-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 32px;
}
.cmp-pair-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 22px;
  border-radius: 14px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: transform 0.2s, border-color 0.2s, box-shadow 0.2s;
}
.cmp-pair-card:hover {
  transform: translateY(-2px);
  border-color: var(--primary, #00f0ff);
  box-shadow: 0 12px 28px rgba(0,240,255,0.05);
}
.cmp-pair-card--new::before {
  content: 'NEW';
  position: absolute;
  top: 12px;
  right: 12px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.12em;
  padding: 2px 7px;
  background: rgba(247,181,0,0.12);
  color: #f7b500;
  border: 1px solid rgba(247,181,0,0.3);
  border-radius: 50px;
}
.cmp-pair-vs {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 800;
  color: var(--color-text-primary);
}
.cmp-vs {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}
.cmp-pair-desc {
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-secondary);
  margin: 0;
}
.cmp-pair-cta {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--primary, #00f0ff);
  margin-top: auto;
}

/* ── FAQ ────────────────────────────────────────────────────────── */
.cmp-faq { padding: 80px 0; background: var(--color-bg-primary); }
.cmp-faq-inner { max-width: 820px; margin: 0 auto; padding: 0 24px; }
.cmp-faq-card {
  border-radius: 12px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
  margin-top: 10px;
  overflow: hidden;
}
.cmp-faq-card summary {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 22px;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  color: var(--color-text-primary);
}
.cmp-faq-card summary::-webkit-details-marker { display: none; }
.cmp-faq-card summary::after {
  content: '+';
  margin-left: auto;
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 20px;
  color: var(--text-muted);
}
.cmp-faq-card[open] summary::after { content: '−'; }
.cmp-faq-card[open] { border-color: var(--primary, #00f0ff); }
.cmp-faq-card p {
  padding: 0 22px 20px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
  margin: 0;
}

/* ── Affiliate disclosure ───────────────────────────────────────── */
.cmp-disclosure {
  padding: 32px 0;
  background: var(--color-bg-deep);
  border-top: 1px solid var(--color-border-subtle);
  border-bottom: 1px solid var(--color-border-subtle);
}
.cmp-disclosure-inner {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 24px;
  font-size: 12px;
  line-height: 1.7;
  color: var(--text-muted);
  text-align: center;
}
.cmp-disclosure-inner strong { color: var(--text-secondary); }

/* ── CTA + footer ───────────────────────────────────────────────── */
.cmp-cta {
  padding: 80px 0 90px;
  background: var(--color-bg-primary);
  text-align: center;
}
.cmp-cta-inner { max-width: 720px; margin: 0 auto; padding: 0 24px; }
.cmp-cta-btn { font-size: 17px; padding: 14px 36px; }

.cmp-footer {
  background: var(--color-bg-deep);
  border-top: 1px solid var(--color-border-subtle);
  padding: 36px 0 28px;
}
.cmp-footer-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
}
.cmp-footer-left { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.cmp-footer-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  font-weight: 700;
  color: var(--color-text-primary);
}
.cmp-footer-tag {
  font-size: 12px;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.15s;
}
.cmp-footer-tag:hover { color: var(--color-cyan, #00f0ff); }
.cmp-footer-links { display: flex; gap: 18px; flex-wrap: wrap; }
.cmp-footer-links a {
  font-size: 13px;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.2s;
}
.cmp-footer-links a:hover { color: var(--primary, #00f0ff); }

/* ── Pair detail page ───────────────────────────────────────────── */
.pair-hero {
  padding: 110px 0 50px;
  background: var(--color-bg-deep);
  position: relative;
  overflow: hidden;
}
.pair-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 15% 0%, rgba(0,240,255,0.06), transparent 50%),
    radial-gradient(ellipse at 85% 0%, rgba(123,47,247,0.05), transparent 50%);
  pointer-events: none;
}
.pair-hero-inner { max-width: 1100px; margin: 0 auto; padding: 0 24px; position: relative; z-index: 1; }
.pair-crumbs {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  margin-bottom: 16px;
}
.pair-crumbs a { color: var(--text-muted); text-decoration: none; }
.pair-crumbs a:hover { color: var(--primary); }
.pair-versus {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: center;
  margin: 16px 0 30px;
}
.pair-versus-side {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
  padding: 20px;
  border-radius: 16px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
}
.pair-versus-side .prov-wordmark { font-size: clamp(24px, 4vw, 36px); }
.pair-versus-score {
  font-family: var(--font-display);
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 800;
  color: var(--primary);
}
.pair-versus-score small { display: block; font-size: 11px; font-weight: 500; color: var(--text-muted); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 4px; }
.pair-versus-vs {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--text-muted);
  text-transform: uppercase;
}
.pair-h1 {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--color-text-primary);
  margin: 0 0 14px;
}
.pair-lede {
  font-size: clamp(15px, 1.8vw, 18px);
  line-height: 1.6;
  color: var(--text-secondary);
  max-width: 70ch;
  margin: 0;
}

/* Coverage bar chart */
.pair-chart { padding: 60px 0; background: var(--color-bg-primary); }
.pair-chart-inner { max-width: 980px; margin: 0 auto; padding: 0 24px; }
.pair-chart-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 28px;
}
.pair-bar-row {
  display: grid;
  grid-template-columns: minmax(110px, 1.2fr) 3fr;
  gap: 14px;
  align-items: center;
}
.pair-bar-label {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 700;
  color: var(--color-text-primary);
}
.pair-bar-track {
  position: relative;
  height: 28px;
  background: var(--color-bg-card);
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--color-border-subtle);
}
.pair-bar-fill-a, .pair-bar-fill-b {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 18px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  padding: 0 10px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  color: #061018;
}
.pair-bar-fill-a {
  left: 4px;
  background: linear-gradient(90deg, #00f0ff, #00b8d9);
  box-shadow: 0 0 12px rgba(0,240,255,0.4);
}
.pair-bar-fill-b {
  right: 4px;
  background: linear-gradient(90deg, #f59e0b, #f7b500);
  box-shadow: 0 0 12px rgba(247,181,0,0.3);
  color: #1a1100;
  flex-direction: row-reverse;
}

/* Pick-X-if cards */
.pair-picks { padding: 60px 0; background: var(--color-bg-deep); }
.pair-picks-inner { max-width: 1180px; margin: 0 auto; padding: 0 24px; }
.pair-picks-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 28px;
}
.pair-pick {
  padding: 28px;
  border-radius: 18px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.pair-pick-head {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 800;
  color: var(--color-text-primary);
}
.pair-pick ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pair-pick li {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-secondary);
  padding-left: 22px;
  position: relative;
}
.pair-pick li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 12px;
  height: 2px;
  border-radius: 1px;
  background: var(--primary);
}
.pair-pick--both li::before { background: #f7b500; }

/* Where-to-buy affiliate */
.pair-buy { padding: 60px 0; background: var(--color-bg-primary); }
.pair-buy-inner { max-width: 980px; margin: 0 auto; padding: 0 24px; }
.pair-buy-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 28px;
}
.pair-buy-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px;
  border-radius: 16px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
}
.pair-buy-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.pair-buy-head .prov-wordmark { font-size: 24px; }
.pair-buy-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.pair-buy-card p { margin: 0; font-size: 13px; line-height: 1.6; color: var(--text-secondary); }
.pair-buy-card .prov-actions { padding-top: 0; }

/* Pair detail table reuse cmp-table */
.pair-table-section { padding: 60px 0; background: var(--color-bg-deep); }
.pair-table-inner { max-width: 980px; margin: 0 auto; padding: 0 24px; }

/* ── Responsive breakpoints ─────────────────────────────────────── */
@media (min-width: 640px) {
  .prov-grid { grid-template-columns: 1fr 1fr; }
  .cmp-pair-grid { grid-template-columns: 1fr 1fr; }
  .pair-buy-grid { grid-template-columns: 1fr 1fr; }
  .pair-picks-grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1024px) {
  .prov-grid { grid-template-columns: 1fr 1fr 1fr; }
  .cmp-pair-grid { grid-template-columns: 1fr 1fr 1fr; }
  .pair-picks-grid { grid-template-columns: 1fr 1fr 1fr; }
}
@media (max-width: 640px) {
  .cmp-hero-stats { grid-template-columns: 1fr 1fr; gap: 12px; }
  .cmp-hero { padding: 92px 0 48px; }
  .cmp-providers, .cmp-matrix, .cmp-decision, .cmp-pairs, .cmp-faq { padding: 40px 0; }
  .cmp-persona-body { padding-left: 22px; }
  .pair-versus { grid-template-columns: 1fr; gap: 12px; text-align: center; }
  .pair-versus-vs { font-size: 12px; }
  /* H2 sizes drop another notch on small phones */
  .cmp-h2 { font-size: clamp(22px, 5vw, 32px); }
  .cmp-h1 { font-size: clamp(28px, 7vw, 44px); }
  .cmp-sub { margin-bottom: 24px; }
  /* Decision-guide personas tighter */
  .cmp-persona summary { padding: 14px 16px; font-size: 14px; }
  .cmp-persona-body { padding: 0 16px 18px 50px; font-size: 13px; }
  .cmp-persona-icon { width: 28px; height: 28px; }
  /* FAQ tighter */
  .cmp-faq-card summary { padding: 14px 16px; font-size: 14px; }
  .cmp-faq-card p { padding: 0 16px 16px; font-size: 13px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* Light-mode overrides */
html.light .cmp-hero { background: var(--color-bg-deep); }
html.light .cmp-providers { background: var(--color-bg-primary); }
html.light .cmp-matrix { background: var(--color-bg-deep); }
html.light .cmp-decision { background: var(--color-bg-primary); }
html.light .cmp-pairs { background: var(--color-bg-deep); }
html.light .cmp-faq { background: var(--color-bg-primary); }
html.light .pair-hero { background: var(--color-bg-deep); }
html.light .pair-chart { background: var(--color-bg-primary); }
html.light .pair-picks { background: var(--color-bg-deep); }
html.light .pair-buy { background: var(--color-bg-primary); }
html.light .pair-table-section { background: var(--color-bg-deep); }
html.light .prov-card, html.light .cmp-pair-card, html.light .pair-versus-side,
html.light .pair-pick, html.light .pair-buy-card, html.light .cmp-persona,
html.light .cmp-faq-card, html.light .cmp-table {
  border-color: rgba(0,0,0,0.08);
}
html.light .cmp-table thead th { background: var(--color-bg-card); border-bottom-color: rgba(0,0,0,0.12); }
html.light .cmp-table tbody td:first-child { background: var(--color-bg-card); }
html.light .cmp-table tbody td { border-bottom-color: rgba(0,0,0,0.05); }
html.light .cmp-table tfoot td { background: var(--color-bg-deep); border-top-color: rgba(0,0,0,0.12); }
html.light .cmp-table tfoot td:first-child { background: var(--color-bg-deep); }
html.light .prov-pill { background: rgba(3,104,48,0.08); color: #036830; border-color: rgba(3,104,48,0.2); }
html.light .prov-pill--via { background: rgba(252,76,2,0.07); border-color: rgba(252,76,2,0.2); }
html.light .prov-status--live { background: rgba(3,104,48,0.08); color: #036830; border-color: rgba(3,104,48,0.25); }
html.light .prov-status--pending { background: rgba(180,120,0,0.08); color: #b47800; border-color: rgba(180,120,0,0.25); }
html.light .cmp-table .y { color: #036830; }
html.light .pair-bar-fill-a { color: #f5f7fa; }

/* ── v2: hero meta + jump nav (objective tone) ─────────────────── */
.cmp-hero--objective { padding: 100px 0 36px; }
.cmp-hero-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 22px;
}
.cmp-hero-meta .cmp-eyebrow { margin: 0; }
.cmp-hero-meta .cmp-hero-dot { opacity: 0.4; }
.cmp-hero-jump {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 18px;
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid var(--color-border-subtle);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
}
.cmp-hero-jump a {
  color: var(--text-muted);
  text-decoration: none;
  border-bottom: 1px dashed transparent;
  transition: color 0.2s, border-color 0.2s;
}
.cmp-hero-jump a:hover { color: var(--primary); border-bottom-color: var(--primary); }

/* ── v2: Top Picks (5 verdict cards at top of page) ────────────── */
.cmp-picks-hero {
  padding: 56px 0 72px;
  background: var(--color-bg-primary);
  border-top: 1px solid var(--color-border-subtle);
}
.cmp-picks-hero-inner { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.cmp-picks-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 28px;
}
.cmp-pick {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 22px;
  border-radius: 16px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
  transition: transform 0.2s, border-color 0.2s, box-shadow 0.2s;
}
.cmp-pick:hover {
  transform: translateY(-3px);
  border-color: var(--primary);
  box-shadow: 0 14px 32px rgba(0,240,255,0.05);
}
.cmp-pick-cat {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--primary);
  text-transform: uppercase;
}
.cmp-pick-brand .prov-wordmark { font-size: 26px; }
.cmp-pick-why {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
  margin: 4px 0 0;
}
.cmp-pick-link {
  margin-top: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--primary);
  text-decoration: none;
  border-bottom: 1px dashed transparent;
  transition: border-color 0.2s;
  align-self: flex-start;
}
.cmp-pick-link:hover { border-bottom-color: var(--primary); }

/* ── v2: Methodology box ───────────────────────────────────────── */
.cmp-method { padding: 72px 0; background: var(--color-bg-deep); }
.cmp-method-inner { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
.cmp-method-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 28px;
}
.cmp-method-card {
  padding: 22px;
  border-radius: 14px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
}
.cmp-method-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(0,240,255,0.08);
  color: var(--primary);
  margin-bottom: 14px;
}
.cmp-method-card h3 {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 800;
  color: var(--color-text-primary);
  margin: 0 0 8px;
}
.cmp-method-card p {
  font-size: 13px;
  line-height: 1.65;
  color: var(--text-secondary);
  margin: 0;
}

/* ── v2: Brand cards — compact card grid, stacked label-over-value ─ */
.prov-grid--v2 {
  grid-template-columns: 1fr;
  gap: 14px;
}
.prov-card--v2 {
  padding: 20px;
  gap: 10px;
}
.prov-card--v2 .prov-cat {
  font-size: 12.5px;
  line-height: 1.5;
}
.prov-card--v2 .prov-meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 6px 0 0;
  padding-top: 6px;
  border-top: 1px solid var(--color-border-subtle);
  font-size: 12.5px;
  line-height: 1.55;
}
.prov-card--v2 .prov-meta dt {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0;
}
.prov-card--v2 .prov-meta dd {
  color: var(--text-secondary);
  margin: 2px 0 0;
}
.prov-card--v2 .prov-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid var(--color-border-subtle);
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.prov-card--v2 .prov-links a {
  color: var(--primary);
  text-decoration: none;
  border-bottom: 1px dashed transparent;
  transition: border-color 0.2s;
}
.prov-card--v2 .prov-links a:hover { border-bottom-color: var(--primary); }

/* Inline glossary/topic links inside brand-card text */
.cmp-inline-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dashed rgba(0,240,255,0.45);
  transition: color 0.15s, border-color 0.15s;
}
.cmp-inline-link:hover {
  color: var(--primary);
  border-bottom-color: var(--primary);
}
html.light .cmp-inline-link { border-bottom-color: rgba(8,95,109,0.5); }
html.light .cmp-inline-link:hover { color: #085f6d; border-bottom-color: #085f6d; }

/* Brand-card responsive grid: 1 → 2 → 3 columns */
@media (min-width: 640px) {
  .prov-grid--v2 { grid-template-columns: 1fr 1fr; gap: 14px; }
}
@media (min-width: 1024px) {
  .prov-grid--v2 { grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
}

/* ── v2: Where-to-buy consolidated list ────────────────────────── */
.cmp-buy { padding: 72px 0; background: var(--color-bg-primary); }
.cmp-buy-inner { max-width: 980px; margin: 0 auto; padding: 0 24px; }
.cmp-buy-list {
  list-style: none;
  margin: 28px 0 18px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cmp-buy-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) minmax(120px, 1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  border-radius: 12px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-subtle);
  transition: border-color 0.2s, transform 0.15s;
}
.cmp-buy-row:hover { border-color: var(--color-border-medium); transform: translateX(2px); }
.cmp-buy-row .prov-wordmark { font-size: 18px; }
.cmp-buy-row .cmp-buy-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
}
.cmp-buy-row a {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--primary);
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 1px dashed transparent;
  transition: border-color 0.2s;
}
.cmp-buy-row a:hover { border-bottom-color: var(--primary); }
.cmp-buy-disclosure {
  font-size: 12px;
  line-height: 1.65;
  color: var(--text-muted);
  font-style: italic;
  margin: 12px 0 0;
}

/* ── v2: Soft MyBodyAI mention (no big button hero) ────────────── */
.cmp-soft-cta {
  padding: 64px 0 80px;
  background: var(--color-bg-deep);
  text-align: center;
}
.cmp-soft-cta-inner { max-width: 720px; margin: 0 auto; padding: 0 24px; }
.cmp-soft-cta-link {
  display: inline-block;
  margin-top: 22px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--primary);
  text-decoration: none;
  padding-bottom: 3px;
  border-bottom: 1px solid var(--primary);
  transition: opacity 0.2s;
}
.cmp-soft-cta-link:hover { opacity: 0.8; }

/* ── v2: pair page Quick Verdict box ───────────────────────────── */
.pair-verdict {
  padding: 40px 0 60px;
  background: var(--color-bg-primary);
}
.pair-verdict-inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 24px;
}
.pair-verdict-text {
  font-family: var(--font-display);
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 500;
  line-height: 1.5;
  color: var(--color-text-primary);
  margin: 14px 0 0;
}

/* ── v2 responsive ─────────────────────────────────────────────── */
@media (min-width: 640px) {
  .cmp-picks-grid { grid-template-columns: 1fr 1fr; }
  .cmp-method-grid { grid-template-columns: 1fr 1fr 1fr; }
}
@media (min-width: 1024px) {
  .cmp-picks-grid { grid-template-columns: repeat(5, 1fr); }
}
@media (max-width: 640px) {
  .cmp-buy-row { grid-template-columns: 1fr; gap: 4px; padding: 12px 14px; }
  .cmp-buy-row .cmp-buy-tag { font-size: 10px; }
  .cmp-hero--objective { padding: 78px 0 24px; }
  .cmp-method { padding: 36px 0 40px; }
  .cmp-buy { padding: 36px 0 40px; }
  .cmp-soft-cta { padding: 40px 0 56px; }
  .cmp-picks-hero { padding: 32px 0 40px; }
  /* Tighter brand cards on small phones */
  .prov-card--v2 { padding: 16px; gap: 8px; }
  .prov-card--v2 .prov-meta { font-size: 12px; gap: 6px; }
  .prov-card--v2 .prov-meta dt { font-size: 9px; }
  .prov-card--v2 .prov-cat { font-size: 12px; }
  .prov-pills { gap: 5px; }
  .prov-pill { font-size: 10.5px; padding: 2px 8px; }
  /* Hub jump-nav wraps tighter */
  .cmp-hero-jump { gap: 4px 14px; font-size: 11px; }
  .cmp-hero-meta { gap: 6px; font-size: 10px; }
  /* Pair grid wider on small phones (480px breakpoint) is impractical; keep 1-col but tighter */
  .cmp-pair-card { padding: 16px; }
  /* Top picks tighter */
  .cmp-pick { padding: 16px; gap: 8px; }
  .cmp-pick-brand .prov-wordmark { font-size: 22px; }
  /* Methodology cards tighter */
  .cmp-method-card { padding: 18px; }
}

/* light-mode v2 overrides */
html.light .cmp-picks-hero { background: var(--color-bg-primary); }
html.light .cmp-method { background: var(--color-bg-deep); }
html.light .cmp-buy { background: var(--color-bg-primary); }
html.light .cmp-soft-cta { background: var(--color-bg-deep); }
html.light .cmp-pick,
html.light .cmp-method-card,
html.light .cmp-buy-row { border-color: rgba(0,0,0,0.08); }
html.light .pair-verdict { background: var(--color-bg-primary); }

/* ── Share component (hub + pair detail) ───────────────────────── */
.cmp-share {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 18px 24px;
  margin: 0 auto;
  max-width: 720px;
  position: relative;
}
.cmp-share--inline { padding-top: 0; padding-bottom: 28px; }
.cmp-share--cta {
  background: var(--color-bg-card);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 18px;
  padding: 26px 28px;
}
.cmp-share-label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.cmp-share--cta .cmp-share-label {
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: none;
  color: var(--color-text-primary);
  font-family: var(--font-display);
  font-weight: 500;
}
.cmp-share-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
}
.cmp-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 999px;
  background: var(--color-bg-card);
  color: var(--text-secondary);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.cmp-share-btn:hover {
  color: var(--color-text-primary);
  border-color: rgba(255,255,255,0.2);
  background: var(--color-bg-surface);
}
.cmp-share-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.cmp-share-btn svg { flex-shrink: 0; }
.cmp-share-btn--native { background: var(--primary); color: var(--color-bg-deep); border-color: var(--primary); }
.cmp-share-btn--native:hover { background: var(--primary); color: var(--color-bg-deep); opacity: 0.85; }
.cmp-share-btn--x:hover       { color: var(--color-text-primary); border-color: var(--color-text-primary); }
.cmp-share-btn--fb:hover      { color: #1877F2; border-color: #1877F2; }
.cmp-share-btn--li:hover      { color: #0A66C2; border-color: #0A66C2; }
.cmp-share-btn--wa:hover      { color: #25D366; border-color: #25D366; }
.cmp-share-btn--em:hover      { color: var(--primary); border-color: var(--primary); }
.cmp-share-btn--copy:hover    { color: var(--primary); border-color: var(--primary); }
.cmp-share-toast {
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translate(-50%, 100%);
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--color-bg-surface);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--color-text-primary);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.18s ease;
  pointer-events: none;
  z-index: 5;
}
.cmp-share-toast.is-visible { opacity: 1; }
@media (max-width: 640px) {
  .cmp-share { padding: 14px 20px; gap: 10px; }
  .cmp-share-btn { padding: 8px 12px; font-size: 11.5px; }
  /* Hide platform labels on tight screens — icon + native button speak for themselves. */
  .cmp-share-btn:not(.cmp-share-btn--native) .cmp-share-btn-label { display: none; }
}
html.light .cmp-share-btn { border-color: rgba(0,0,0,0.1); }
html.light .cmp-share-btn:hover { border-color: rgba(0,0,0,0.25); }
html.light .cmp-share--cta { border-color: rgba(0,0,0,0.08); }
html.light .cmp-share-toast { border-color: rgba(0,0,0,0.12); }

/* Brand sprite logos use currentColor → theme-driven via .brand-mark--* rules. */
.brand-mark--suunto { color: var(--color-text-primary); }
