/* Competitor vs QAlity comparison pages - premium SaaS comparison (Vercel / Apple inspired) */

body.compare-page {
  --compare-bg: #f7f8fa;
  --compare-surface: #ffffff;
  --compare-ink: #0f172a;
  --compare-ink-soft: #334155;
  --compare-ink-muted: #475569;
  --compare-brand: #162d5d;
  --compare-brand-mid: #4a6ba0;
  --compare-competitor: #64748b;
  --compare-competitor-soft: rgba(100, 116, 139, 0.1);
  --compare-border: rgba(15, 23, 42, 0.08);
  --compare-border-strong: rgba(15, 23, 42, 0.12);
  --compare-radius-lg: 20px;
  --compare-radius-md: 14px;
  --compare-radius-sm: 10px;
  --compare-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 8px 32px rgba(22, 45, 93, 0.06);
  --compare-shadow-hover: 0 4px 8px rgba(15, 23, 42, 0.04), 0 20px 48px rgba(22, 45, 93, 0.1);
  --compare-qality-pill-bg: color-mix(in srgb, var(--compare-brand) 14%, #ffffff);
  --compare-qality-pill-ink: color-mix(in srgb, var(--compare-brand) 62%, #475569);
  --compare-qality-pill-border: color-mix(in srgb, var(--compare-brand) 18%, #e2e8f0);
  --compare-max: 1280px;
  --compare-gutter: clamp(14px, 2.5vw, 24px);
  --compare-matrix-cols: minmax(140px, 0.95fr) minmax(0, 1.35fr) minmax(0, 1.35fr);
  --compare-matrix-gap: 12px;
  --compare-matrix-pad-x: 0;
  --compare-cell-pad-y: 14px;
  --compare-cell-pad-x: 16px;
  --compare-text-sm: 0.9375rem;
  --compare-text-base: 1rem;
  --compare-text-detail: 0.875rem;

  background: var(--compare-bg);
  color: var(--compare-ink-soft);
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  scroll-padding-top: calc(var(--landing-fixed-nav-height, 68px) + 20px);
}

body.compare-page .bg-layer {
  display: none;
}

.compare-page__glow {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 90% 55% at 50% -8%, rgba(74, 107, 160, 0.14), transparent 58%),
    radial-gradient(ellipse 50% 40% at 100% 0%, rgba(22, 45, 93, 0.06), transparent 50%),
    radial-gradient(ellipse 40% 35% at 0% 20%, rgba(22, 45, 93, 0.05), transparent 45%);
}

.compare-main {
  position: relative;
  z-index: 1;
  padding-top: calc(
    env(safe-area-inset-top, 0px) + var(--landing-fixed-nav-height, 68px) + clamp(28px, 5vw, 56px)
  );
  overflow-x: clip;
}

.compare-shell {
  width: min(var(--compare-max), 100%);
  margin: 0 auto;
  padding: 0 var(--compare-gutter) clamp(64px, 10vw, 120px);
  box-sizing: border-box;
}

/* -- Hero -- */
.compare-hero {
  text-align: center;
  max-width: 720px;
  margin: 0 auto clamp(40px, 6vw, 64px);
}

.compare-eyebrow {
  display: inline-block;
  margin: 0 0 20px;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--compare-brand);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--compare-border);
  backdrop-filter: blur(8px);
}


.compare-hero__title {
  margin: 0 0 16px;
  font-size: clamp(2.25rem, 7vw, 3.5rem);
  font-weight: 700;
  letter-spacing: -0.045em;
  line-height: 1.05;
  color: var(--compare-ink);
}

.compare-hero__name {
  display: inline;
}

.compare-hero__name--accent {
  background: linear-gradient(90deg, var(--compare-brand), var(--compare-brand-mid));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.compare-hero__vs {
  display: inline-block;
  margin: 0 0.2em;
  font-size: 0.55em;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--compare-ink-muted);
  vertical-align: middle;
}

.compare-hero__lead {
  margin: 0 auto 28px;
  max-width: 520px;
  font-size: clamp(1rem, 2.4vw, 1.125rem);
  line-height: 1.65;
  color: var(--compare-ink-muted);
}

.compare-hero__lead a {
  color: var(--compare-brand);
  font-weight: 600;
  text-decoration: none;
}

.compare-hero__lead a:hover {
  text-decoration: underline;
}

.compare-hero__duel {
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: stretch;
  justify-content: center;
  gap: 0;
  margin-top: 4px;
  padding: 5px;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border: 1px solid var(--compare-border-strong);
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 12px 32px rgba(15, 23, 42, 0.07);
}

.compare-duel-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 22px;
  border-radius: 12px;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.2;
  white-space: nowrap;
  color: var(--compare-ink);
  background: #fff;
  border: 1px solid transparent;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.compare-duel-chip--accent {
  padding: 10px 26px;
  color: #fff;
  font-weight: 700;
  border-color: transparent;
  background: linear-gradient(135deg, var(--compare-brand) 0%, var(--compare-brand-mid) 100%);
  box-shadow:
    0 2px 8px rgba(22, 45, 93, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.compare-duel-divider {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  min-width: 44px;
  padding: 0 6px;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--compare-ink-muted);
}

.compare-duel-divider::before,
.compare-duel-divider::after {
  content: "";
  display: block;
  width: 1px;
  height: 20px;
  background: var(--compare-border-strong);
}

.compare-duel-divider::before {
  margin-right: 10px;
}

.compare-duel-divider::after {
  margin-left: 10px;
}

/* -- Verdict -- */
.compare-verdict-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: 1fr;
  align-items: stretch;
  gap: 20px;
  margin-bottom: clamp(36px, 5vw, 52px);
}

.compare-verdict-card {
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-height: 100%;
  height: 100%;
  box-sizing: border-box;
  padding: clamp(24px, 3.5vw, 32px);
  border-radius: var(--compare-radius-md);
  background: var(--compare-surface);
  border: 1px solid var(--compare-border);
  box-shadow: var(--compare-shadow);
  transition: box-shadow 0.35s ease, transform 0.35s ease;
}

.compare-verdict-card:hover {
  box-shadow: var(--compare-shadow-hover);
  transform: translateY(-2px);
}

.compare-verdict-card--qality {
  border-top: none;
  box-shadow:
    var(--compare-shadow),
    inset 0 3px 0 0 var(--compare-brand-mid);
  background: linear-gradient(180deg, rgba(22, 45, 93, 0.04) 0%, var(--compare-surface) 42%);
}

.compare-verdict-card:not(.compare-verdict-card--qality) {
  border-top: none;
  box-shadow:
    var(--compare-shadow),
    inset 0 3px 0 0 var(--compare-competitor);
}

.compare-verdict-card__label {
  margin: 0 0 12px;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--compare-brand);
}

.compare-verdict-card:not(.compare-verdict-card--qality) .compare-verdict-card__label {
  color: var(--compare-competitor-ink, var(--compare-competitor));
  background: none;
  border: none;
  padding: 0;
  border-radius: 0;
  box-shadow: none;
}

.compare-verdict-card__text {
  margin: 0;
  font-size: var(--compare-text-base);
  line-height: 1.65;
  color: var(--compare-ink-soft);
}

/* -- Comparison blocks -- */
.compare-sections {
  display: flex;
  flex-direction: column;
  gap: clamp(28px, 4vw, 36px);
}

.compare-block {
  border-radius: var(--compare-radius-lg);
  background: var(--compare-surface);
  border: 1px solid var(--compare-border);
  box-shadow: var(--compare-shadow);
  overflow: hidden;
  transition: box-shadow 0.25s ease;
}

.compare-block:hover {
  box-shadow: var(--compare-shadow-hover);
}

.compare-block__head {
  padding: clamp(20px, 3vw, 28px) var(--compare-cell-pad-x) clamp(14px, 2vw, 18px);
  border-bottom: 1px solid var(--compare-border);
  background: linear-gradient(180deg, rgba(22, 45, 93, 0.04) 0%, transparent 100%);
}

.compare-block__title {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0;
  font-size: clamp(1.25rem, 3vw, 1.5rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--compare-ink);
}

.compare-block__title::before {
  content: "";
  flex-shrink: 0;
  width: 4px;
  height: 1.15em;
  border-radius: 3px;
  background: linear-gradient(180deg, var(--compare-brand), var(--compare-brand-mid));
}

.compare-block__lead {
  margin: 10px 0 0;
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--compare-ink-muted);
}

.compare-block__prose {
  margin: 0;
  padding: clamp(20px, 3vw, 28px) var(--compare-cell-pad-x);
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--compare-ink);
}

.compare-seo-mount {
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 4vw, 36px);
  margin-bottom: clamp(36px, 5vw, 52px);
}

.compare-seo-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  margin: 0;
  padding: clamp(16px, 2.5vw, 24px) var(--compare-cell-pad-x) clamp(20px, 3vw, 28px);
  list-style: none;
}

.compare-seo-links__link {
  display: inline-block;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--compare-brand);
  background: color-mix(in srgb, var(--compare-brand) 6%, #ffffff);
  border: 1px solid color-mix(in srgb, var(--compare-brand) 14%, #e2e8f0);
  text-decoration: none;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.compare-seo-links__link:hover {
  background: color-mix(in srgb, var(--compare-brand) 10%, #ffffff);
  border-color: color-mix(in srgb, var(--compare-brand) 22%, #e2e8f0);
}

.compare-matrix--summary .compare-matrix__row--summary .compare-matrix__detail {
  margin-top: 4px;
}

/* -- Matrix (desktop table / mobile stack) -- */
.compare-matrix {
  padding: 0 0 clamp(16px, 2.5vw, 24px);
}

.compare-matrix__header {
  display: grid;
  grid-template-columns: var(--compare-matrix-cols);
  column-gap: var(--compare-matrix-gap);
  padding: 0;
  margin-bottom: 0;
  border-radius: 0;
  background: linear-gradient(180deg, #eef2f7 0%, #f1f5f9 100%);
  border-bottom: 1px solid var(--compare-border-strong);
  box-shadow: none;
}

.compare-matrix__col {
  padding: 13px var(--compare-cell-pad-x);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  text-align: left;
}

.compare-matrix__col--feature {
  color: var(--compare-ink-muted);
  padding-left: var(--compare-cell-pad-x);
}

.compare-matrix__col--ts,
.compare-matrix__col--pw,
.compare-matrix__col--se,
.compare-matrix__col--cy,
.compare-matrix__col--pp,
.compare-matrix__col--bs,
.compare-matrix__col--kt,
.compare-matrix__col--lt,
.compare-matrix__col--lw,
.compare-matrix__col--bb {
  color: color-mix(in srgb, var(--compare-competitor) 40%, #94a3b8);
}

.compare-matrix__col--qa {
  color: var(--compare-brand);
  padding-right: var(--compare-cell-pad-x);
}

.compare-matrix__row {
  display: grid;
  grid-template-columns: var(--compare-matrix-cols);
  column-gap: var(--compare-matrix-gap);
  align-items: start;
  padding: 0;
  border-bottom: 1px solid var(--compare-border);
  transition: background-color 0.15s ease;
}

.compare-matrix__row:last-child {
  border-bottom: none;
}

.compare-matrix__row:nth-of-type(even) {
  background: rgba(248, 250, 255, 0.65);
}

.compare-matrix__feature {
  margin: 0;
  padding: var(--compare-cell-pad-y) var(--compare-cell-pad-x);
  padding-right: 8px;
  font-size: var(--compare-text-base);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--compare-ink);
  line-height: 1.45;
  align-self: center;
}

.compare-matrix__value {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
  padding: var(--compare-cell-pad-y) var(--compare-cell-pad-x);
  box-sizing: border-box;
}

.compare-matrix__vendor {
  display: none;
  margin: 0;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.compare-matrix__value:not(.compare-matrix__value--qality) .compare-matrix__vendor {
  color: color-mix(in srgb, var(--compare-competitor) 40%, #94a3b8);
}

.compare-matrix__value--qality .compare-matrix__vendor {
  color: var(--compare-brand);
}

.compare-pill,
.compare-status {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  border-radius: 6px;
  padding: 5px 11px;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.4;
  white-space: normal;
  text-align: left;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.compare-pill--checked,
.compare-status--checked {
  background: #e6f4ec;
  color: #1a7a3f;
  border: 1px solid #b7dfca;
}

.compare-pill--warning,
.compare-status--warning {
  background: #fff8e6;
  color: #a65f00;
  border: 1px solid #f5dfa0;
}

.compare-pill--unchecked,
.compare-status--unchecked {
  background: #fdecea;
  color: #b71c1c;
  border: 1px solid #f5c0bc;
}

.compare-pill--unknown,
.compare-status--unknown {
  background: #f0f0f0;
  color: #555555;
  border: 1px solid #d0d0d0;
}

/* Competitor pills: ultra-light tint so QAlity column stands out */
.compare-matrix__value:not(.compare-matrix__value--qality) .compare-pill--checked,
.compare-matrix__value:not(.compare-matrix__value--qality) .compare-pill--warning,
.compare-matrix__value:not(.compare-matrix__value--qality) .compare-pill--unchecked,
.compare-matrix__value:not(.compare-matrix__value--qality) .compare-pill--unknown,
.compare-matrix__value:not(.compare-matrix__value--qality) .compare-status--checked,
.compare-matrix__value:not(.compare-matrix__value--qality) .compare-status--warning,
.compare-matrix__value:not(.compare-matrix__value--qality) .compare-status--unchecked,
.compare-matrix__value:not(.compare-matrix__value--qality) .compare-status--unknown {
  background: color-mix(in srgb, var(--compare-competitor) 5%, #ffffff);
  color: color-mix(in srgb, var(--compare-competitor) 32%, #94a3b8);
  border: 1px solid color-mix(in srgb, var(--compare-competitor) 7%, #f1f5f9);
  box-shadow: none;
  font-weight: 500;
}

/* QAlity column: slightly deeper tint than competitors, still soft */
.compare-matrix__value--qality .compare-pill--checked,
.compare-matrix__value--qality .compare-pill--warning,
.compare-matrix__value--qality .compare-pill--unchecked,
.compare-matrix__value--qality .compare-pill--unknown,
.compare-matrix__value--qality .compare-status--checked,
.compare-matrix__value--qality .compare-status--warning,
.compare-matrix__value--qality .compare-status--unchecked,
.compare-matrix__value--qality .compare-status--unknown {
  background: var(--compare-qality-pill-bg);
  color: var(--compare-qality-pill-ink);
  border: 1px solid var(--compare-qality-pill-border);
  box-shadow: 0 1px 2px color-mix(in srgb, var(--compare-brand) 10%, transparent);
  font-weight: 600;
}

.compare-matrix__detail {
  width: 100%;
  margin: 0;
  font-size: var(--compare-text-detail);
  line-height: 1.55;
  color: var(--compare-ink-soft);
  overflow-wrap: break-word;
  word-break: normal;
}

/* Desktop: row hover */
@media (min-width: 1024px) {
  .compare-matrix__row:hover {
    background: rgba(22, 45, 93, 0.035);
  }

  .compare-matrix__row:nth-of-type(even):hover {
    background: rgba(22, 45, 93, 0.05);
  }
}

/* -- Bento highlights -- */
.compare-bento {
  margin-top: clamp(48px, 8vw, 72px);
}

.compare-bento__head {
  text-align: center;
  max-width: 520px;
  margin: 0 auto clamp(28px, 4vw, 40px);
}

.compare-bento__title {
  margin: 0 0 10px;
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  color: var(--compare-ink);
}

.compare-bento__lead {
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--compare-ink-muted);
}

.compare-bento__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 1fr;
  align-items: stretch;
  gap: 20px;
}

.compare-bento-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-height: 100%;
  height: 100%;
  box-sizing: border-box;
  padding: clamp(24px, 3.5vw, 32px);
  border-radius: var(--compare-radius-md);
  background: var(--compare-surface);
  border: 1px solid var(--compare-border);
  box-shadow: var(--compare-shadow);
  overflow: hidden;
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.35s ease;
}

.compare-bento-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--compare-brand), var(--compare-brand-mid));
}

.compare-bento-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--compare-shadow-hover);
}

.compare-bento-card__title {
  margin: 0 0 10px;
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--compare-ink);
}

.compare-bento-card__desc {
  flex: 1 1 auto;
  margin: 0;
  font-size: var(--compare-text-sm);
  line-height: 1.65;
  color: var(--compare-ink-soft);
}

/* -- CTA -- */
.compare-cta {
  margin-top: clamp(40px, 6vw, 56px);
}

.compare-cta__inner {
  text-align: center;
  padding: clamp(40px, 6vw, 56px) clamp(24px, 4vw, 40px);
  border-radius: var(--compare-radius-lg);
  background: linear-gradient(145deg, #0f172a 0%, #162d5d 48%, #1e3a6e 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 24px 64px rgba(22, 45, 93, 0.28);
}

.compare-cta__title {
  margin: 0 0 10px;
  font-size: clamp(1.5rem, 4vw, 2.125rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  color: #fff;
}

.compare-cta__lead {
  margin: 0 auto 28px;
  max-width: 400px;
  font-size: 1rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.72);
}

.compare-cta__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.compare-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 24px;
  border-radius: 999px;
  font-size: 0.9375rem;
  font-weight: 600;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.compare-btn:hover {
  transform: translateY(-1px);
}

.compare-btn--primary {
  color: var(--compare-brand);
  background: #fff;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.compare-btn--primary:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.2);
}

.compare-btn--ghost {
  color: #fff;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.35);
}

.compare-btn--ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.5);
}

/* Compare pages: no scroll or hero reveal - content visible immediately */
body.compare-page .landing-reveal {
  opacity: 1;
  transform: none;
  transition: none;
}

body.compare-page .compare-hero--enter .compare-eyebrow,
body.compare-page .compare-hero--enter .compare-hero__title,
body.compare-page .compare-hero--enter .compare-hero__lead,
body.compare-page .compare-hero--enter .compare-hero__duel {
  opacity: 1;
  animation: none;
}

@media (min-width: 1024px) {
  body.compare-page {
    --compare-cell-pad-y: 15px;
    --compare-cell-pad-x: 14px;
  }
}

/* -- Responsive: feature row + two-column compare -- */
@media (max-width: 1023px) {
  .compare-main {
    padding-top: calc(
      env(safe-area-inset-top, 0px) + var(--landing-fixed-nav-height, 68px) + 20px
    );
  }

  .compare-hero__title {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
  }

  .compare-hero__vs {
    margin: 4px 0;
    font-size: 0.875rem;
  }

  .compare-verdict-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  body.compare-page {
    --compare-cell-pad-y: 12px;
    --compare-cell-pad-x: 14px;
  }

  .compare-matrix {
    padding: 0 0 16px;
  }

  .compare-matrix__header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: var(--compare-matrix-gap);
    padding: 0;
    margin-bottom: 0;
    background: linear-gradient(180deg, #eef2f7 0%, #f1f5f9 100%);
    border-bottom: 1px solid var(--compare-border-strong);
  }

  .compare-matrix__col--feature {
    display: none;
  }

  .compare-matrix__col {
    padding: 10px var(--compare-cell-pad-x);
    font-size: 0.6875rem;
    text-align: center;
    background: transparent;
  }

  .compare-matrix__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: var(--compare-matrix-gap);
    padding: 0;
    margin-bottom: 0;
    background: transparent;
    border: none;
    border-radius: 0;
    border-bottom: 1px solid var(--compare-border);
    overflow: visible;
  }

  .compare-matrix__row:nth-of-type(even) {
    background: rgba(248, 250, 255, 0.65);
  }

  .compare-matrix__feature {
    grid-column: 1 / -1;
    padding: 11px var(--compare-cell-pad-x) 8px;
    font-size: 0.9375rem;
    background: transparent;
    border-bottom: none;
    align-self: stretch;
  }

  .compare-matrix__value {
    padding: var(--compare-cell-pad-y) var(--compare-cell-pad-x);
    gap: 8px;
    border: none;
  }

  .compare-matrix__detail {
    font-size: 0.8125rem;
    line-height: 1.5;
  }

  .compare-pill,
  .compare-status {
    font-size: 0.6875rem;
    padding: 4px 9px;
    line-height: 1.35;
    border-radius: 5px;
  }

  .compare-matrix__vendor {
    display: block;
    margin-bottom: 2px;
    font-size: 0.625rem;
  }

  .compare-block__head {
    padding-left: var(--compare-cell-pad-x);
    padding-right: var(--compare-cell-pad-x);
  }

  .compare-bento__grid {
    grid-template-columns: 1fr;
  }

  .compare-cta__actions {
    flex-direction: column;
    width: 100%;
  }

  .compare-btn {
    width: 100%;
    max-width: 320px;
  }
}

@media (max-width: 380px) {
  .compare-matrix__row {
    grid-template-columns: 1fr;
  }

  .compare-matrix__value + .compare-matrix__value {
    padding-top: 0;
  }
}

@media (max-width: 420px) {
  .compare-hero__duel {
    width: 100%;
    max-width: 320px;
    flex-direction: column;
    gap: 6px;
    padding: 8px;
    border-radius: 14px;
  }

  .compare-duel-chip {
    width: 100%;
    min-height: 42px;
    box-sizing: border-box;
  }

  .compare-duel-divider {
    min-width: 0;
    padding: 2px 0;
  }

  .compare-duel-divider::before,
  .compare-duel-divider::after {
    display: none;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .compare-bento__grid {
    grid-template-columns: 1fr 1fr;
  }

  .compare-bento__grid .compare-bento-card:last-child {
    grid-column: 1 / -1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .compare-verdict-card:hover,
  .compare-bento-card:hover,
  .compare-btn:hover {
    transform: none;
  }
}

/* -- Competitor brand tokens (per compare page; body + modifier beats body.compare-page defaults) -- */
body.compare-page.compare-page--testsigma,
body.compare-page:not([class*="compare-page--"]) {
  --compare-competitor: #2563eb;
  --compare-competitor-ink: #1d4ed8;
}

body.compare-page.compare-page--playwright {
  --compare-competitor: #45ba63;
  --compare-competitor-ink: #2d8a47;
}

body.compare-page.compare-page--selenium {
  --compare-competitor: #43b02a;
  --compare-competitor-ink: #2f7d1e;
}

body.compare-page.compare-page--cypress {
  --compare-competitor: #17202c;
  --compare-competitor-ink: #17202c;
}

body.compare-page.compare-page--puppeteer {
  --compare-competitor: #40b5a4;
  --compare-competitor-ink: #1a6b62;
}

body.compare-page.compare-page--browserstack {
  --compare-competitor: #654ff0;
  --compare-competitor-accent: #ffb229;
  --compare-competitor-ink: #4f3dd4;
}

body.compare-page.compare-page--katalon {
  --compare-competitor: #00e09e;
  --compare-competitor-ink: #007a62;
}

body.compare-page.compare-page--lambdatest {
  --compare-competitor: #7a5af8;
  --compare-competitor-ink: #5c42c9;
}

body.compare-page.compare-page--leapwork {
  --compare-competitor: #5b3df5;
  --compare-competitor-ink: #4529c4;
}

body.compare-page.compare-page--bugbug {
  --compare-competitor: #7b61ff;
  --compare-competitor-ink: #5a45c9;
}

body.compare-page.compare-page--manual-testing {
  --compare-competitor: #0d9488;
  --compare-competitor-ink: #0f766e;
}

/* Eyebrow: subtle brand tint */
body.compare-page[class*="compare-page--"] .compare-eyebrow {
  background: color-mix(in srgb, var(--compare-competitor) 5%, #ffffff);
  color: color-mix(in srgb, var(--compare-competitor) 32%, #94a3b8);
  border-color: color-mix(in srgb, var(--compare-competitor) 7%, #f1f5f9);
  box-shadow: none;
}

/* Hero duel: competitor chip (readable) + QAlity emphasis */
body.compare-page[class*="compare-page--"] .compare-hero__duel .compare-duel-chip:not(.compare-duel-chip--accent),
body.compare-page:not([class*="compare-page--"]) .compare-hero__duel .compare-duel-chip--testsigma {
  color: var(--compare-competitor-ink, var(--compare-competitor));
  background: color-mix(in srgb, var(--compare-competitor) 9%, #ffffff);
  border: 1px solid color-mix(in srgb, var(--compare-competitor) 16%, #e2e8f0);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

body.compare-page.compare-page--browserstack .compare-hero__duel .compare-duel-chip:not(.compare-duel-chip--accent) {
  border-color: color-mix(in srgb, var(--compare-competitor-accent) 35%, #e2e8f0);
}

/* Shared competitor UI (hero, chips, matrix) */
body.compare-page[class*="compare-page--"] .compare-hero__title .compare-hero__name:not(.compare-hero__name--accent),
body.compare-page:not([class*="compare-page--"]) .compare-hero__name--testsigma {
  color: var(--compare-competitor);
  background: none;
  -webkit-text-fill-color: currentColor;
  background-clip: border-box;
}

body.compare-page.compare-page--browserstack .compare-verdict-card:not(.compare-verdict-card--qality) {
  box-shadow:
    var(--compare-shadow),
    inset 0 3px 0 0 var(--compare-competitor-accent);
}

/* FAQ (visible copy matches FAQPage JSON-LD) */
body.compare-page .compare-faq {
  margin-top: clamp(40px, 6vw, 64px);
}

body.compare-page .compare-faq__head {
  margin-bottom: 20px;
}

body.compare-page .compare-faq__title {
  margin: 0;
  font-size: clamp(1.35rem, 2.5vw, 1.65rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--compare-ink);
}

body.compare-page .compare-page__faq {
  max-width: 720px;
}

body.compare-page .compare-page__faq-item {
  margin-bottom: 10px;
  border: none;
}

body.compare-page .compare-page__faq-item summary {
  padding: 16px 18px;
  font-size: 15px;
  font-weight: 600;
  color: var(--compare-ink);
  cursor: pointer;
  list-style: none;
  border: 1px solid var(--compare-border);
  border-radius: 12px;
  background: var(--compare-surface);
}

body.compare-page .compare-page__faq-item[open] summary {
  border-radius: 12px 12px 4px 4px;
  border-bottom-color: transparent;
}

body.compare-page .compare-page__faq-item summary:hover {
  border-color: var(--compare-border-strong);
}

body.compare-page .compare-page__faq-item summary::-webkit-details-marker {
  display: none;
}

body.compare-page .compare-page__faq-item summary::after {
  content: "+";
  float: right;
  font-weight: 500;
  color: var(--compare-ink-muted);
}

body.compare-page .compare-page__faq-item[open] summary::after {
  content: "−";
}

body.compare-page .compare-page__faq-answer {
  margin: 0;
  padding: 14px 18px 18px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--compare-ink-soft);
  border: 1px solid var(--compare-border);
  border-top: none;
  border-radius: 0 0 12px 12px;
  background: color-mix(in srgb, var(--compare-brand) 4%, #ffffff);
}

