/* Compare pages — Swiss/minimal, token-driven. */
.compare-narrow { max-width: 940px; }
.compare-header { padding: 2.5rem 0 1rem; }
.compare-eyebrow { font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted-color); margin: 0 0 .5rem; }
.compare-header h1 { margin: 0 0 .5rem; line-height: 1.1; }
.compare-lede { color: var(--muted-color); font-size: 1.1rem; max-width: 60ch; margin: 0 0 1.25rem; }
.compare-h2 { margin: 2.75rem 0 1rem; font-size: 1.4rem; }
.compare-note { color: var(--muted-color); font-size: .9rem; margin: 0 0 .75rem; }
.compare-content { margin: 1.5rem 0; }

/* --- Capability bars (at-a-glance) --- */
.capability-bars { margin: 1rem 0 1rem; }
.cap-row { display: grid; grid-template-columns: 8.5rem 1fr 3rem; align-items: center; gap: .75rem; padding: .3rem 0; }
.cap-name { font-size: .92rem; font-weight: 500; }
.cap-track { height: 10px; background: var(--gray-100); border-radius: 999px; overflow: hidden; }
.cap-fill { display: block; height: 100%; background: var(--gray-400); border-radius: 999px; transition: width .6s ease; }
.cap-fill-fynman { background: var(--primary); }
.cap-row-fynman .cap-name { font-weight: 700; color: var(--primary); }
.cap-num { font-size: .85rem; color: var(--muted-color); text-align: right; font-variant-numeric: tabular-nums; }

/* --- Feature matrix --- */
.compare-matrix-tools { display: flex; justify-content: flex-end; margin: 0 0 .5rem; }
.cm-toggle { font-size: .85rem; color: var(--muted-color); cursor: pointer; user-select: none; }
.compare-matrix { width: 100%; border-collapse: collapse; font-size: .92rem; }
.compare-matrix th, .compare-matrix td { padding: .7rem .85rem; border-bottom: 1px solid var(--border-color); text-align: center; }
.compare-matrix thead th { background: var(--surface); font-weight: 600; color: var(--color); border-bottom: 2px solid var(--border-color); }
.cm-feature-head, .cm-feature { text-align: left; font-weight: 500; }
.cm-feature { color: var(--color); }
.cm-col-fynman { background: var(--primary-light); }
.compare-matrix thead .cm-col-fynman { color: var(--primary-dark); font-weight: 700; }
.cm-row:hover td, .cm-row:hover th { background: color-mix(in srgb, var(--surface) 70%, transparent); }
.cm-row:hover .cm-col-fynman { background: var(--primary-light); }
.cm-yes span { color: var(--success); font-weight: 700; }
.cm-no span  { color: var(--danger); }
.cm-partial span { color: var(--warning); font-size: .8rem; font-weight: 600; }
.cm-na span  { color: var(--gray-300); }
.cm-text { font-size: .85rem; color: var(--muted-color); }

/* --- Tool cards --- */
.tool-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1rem; margin: 1rem 0; }
.tool-card { border: 1px solid var(--border-color); border-radius: 12px; padding: 1.25rem; background: var(--background-color); }
.tool-card-fynman { border-color: var(--primary); background: var(--primary-light); }
.tool-card-head { display: flex; justify-content: space-between; align-items: baseline; gap: .5rem; margin-bottom: .75rem; }
.tool-card-name { margin: 0; font-size: 1.1rem; }
.tool-card-price { font-size: .8rem; color: var(--muted-color); white-space: nowrap; }
.tool-card-best, .tool-card-gap { margin: .4rem 0; font-size: .9rem; line-height: 1.5; }
.tc-label { display: inline-block; font-size: .68rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: .1rem .4rem; border-radius: 4px; margin-right: .35rem; }
.tc-good { background: color-mix(in srgb, var(--success) 15%, transparent); color: var(--success); }
.tc-bad { background: color-mix(in srgb, var(--danger) 12%, transparent); color: var(--danger); }
.tc-src { font-size: .78rem; color: var(--muted-color); text-decoration: underline; }
.tool-card-cta { display: inline-block; margin-top: .5rem; font-weight: 600; color: var(--primary); text-decoration: none; }

/* --- CTA (button) --- */
.compare-cta { display: inline-block; margin-top: 1rem; padding: .75rem 1.5rem; background: var(--primary); color: #fff; text-decoration: none; border-radius: var(--border-radius); font-weight: 600; transition: background .2s ease; }
.compare-cta:hover { background: var(--primary-dark); }

/* --- Disclosure --- */
.compare-disclosure { margin: .75rem 0 0; font-size: .8rem; color: var(--muted-color); }

/* --- Differentiation (gap -> Fynman answer) --- */
.compare-diff { margin: 1rem 0; }
.diff-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem; }
.diff-card { border: 1px solid var(--border-color); border-left: 3px solid var(--primary); border-radius: 10px; padding: 1.1rem 1.25rem; background: var(--surface); }
.diff-gap { margin: 0 0 .5rem; font-size: .9rem; color: var(--muted-color); }
.diff-answer { margin: 0; font-size: .95rem; line-height: 1.5; }
.diff-mark { font-weight: 700; color: var(--primary); }

/* --- Switching close --- */
.compare-switch { margin: 3rem 0 1rem; padding: 2rem 1.5rem; text-align: center; background: var(--primary-light); border-radius: 14px; }
.compare-switch-title { margin: 0 0 .5rem; font-size: 1.35rem; }
.compare-switch-copy { max-width: 52ch; margin: 0 auto 1.25rem; color: var(--color); }
.compare-switch-trust { margin: .75rem 0 0; font-size: .8rem; color: var(--muted-color); }
