/* ═══════════════════════════════════════════════════════════════════════
   crashgames.guide — /compare/ catalog hub bespoke styles
   ═══════════════════════════════════════════════════════════════════════ */
.page--compare .main { padding-top: 0; }
.page--compare main > .hero-compare:first-child,
.page--compare main > section:first-child { margin-top: 0; }


.page--compare main > .hero-compare:first-child { margin-top: 0; }

/* ── HERO with VS-symbol ribbon ──────────────────────────────────── */
.hero-compare {
    position: relative;
    overflow: hidden;
    padding: clamp(32px, 5vw, 64px) 0 clamp(28px, 4vw, 48px);
    background:
        radial-gradient(70% 80% at 50% 0%, rgba(249, 115, 22, 0.10), transparent 70%),
        radial-gradient(50% 60% at 85% 100%, rgba(79, 70, 229, 0.06), transparent 70%),
        var(--bg);
    border-bottom: 1px solid var(--border);
}
.hero-compare__vs-ribbon {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    gap: clamp(28px, 4vw, 60px);
    padding: 0 var(--sp-4);
    pointer-events: none;
    user-select: none;
    font-family: 'Geist Mono', 'JetBrains Mono', ui-monospace, monospace;
    font-size: clamp(2.25rem, 5.5vw, 4.75rem);
    font-weight: 800;
    color: rgba(249, 115, 22, 0.06);
    letter-spacing: -0.02em;
    overflow: hidden;
    white-space: nowrap;
    z-index: 0;
}
.hero-compare__vs-ribbon span {
    flex-shrink: 0;
    transform: rotate(-6deg);
}
.hero-compare__vs-ribbon-tied { color: rgba(79, 70, 229, 0.06); }

.hero-compare__inner {
    position: relative;
    z-index: 1;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-4);
}
.hero-compare__eyebrow {
    display: inline-block;
    padding: 6px 14px;
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--alert);
    background: var(--bg-alt);
    border: 1px solid var(--border);
    border-radius: var(--r-full);
    margin-bottom: var(--sp-2);
}
.hero-compare__title {
    margin: 0;
    font-size: clamp(1.875rem, 4.5vw + 0.5rem, 3.5rem);
    font-weight: var(--fw-black);
    line-height: 1.05;
    letter-spacing: -0.025em;
    color: var(--text);
    max-width: 920px;
}
.hero-compare__lead {
    margin: 0;
    max-width: 720px;
    font-size: var(--fs-md);
    color: var(--text-muted);
    line-height: var(--lh-relaxed);
}
.hero-compare__topline {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(16px, 3vw, 32px);
    padding: var(--sp-4) clamp(16px, 3vw, 32px);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    box-shadow: var(--shadow-sm);
    margin-top: var(--sp-2);
}
.hero-compare__topline-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    min-width: 72px;
}
.hero-compare__topline-value {
    font-family: var(--font-mono);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: var(--fw-black);
    line-height: 1;
    color: var(--alert);
    letter-spacing: -0.02em;
}
.hero-compare__topline-label {
    font-size: var(--fs-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    font-weight: var(--fw-medium);
}
.hero-compare__topline-sep { width: 1px; height: 32px; background: var(--border); }
@media (max-width: 540px) {
    .hero-compare__topline-sep { display: none; }
    .hero-compare__topline { gap: var(--sp-3); }
    .hero-compare__topline-stat { flex-direction: row; align-items: baseline; gap: 6px; }
    .hero-compare__topline-value { font-size: 1.5rem; }
    .hero-compare__vs-ribbon { font-size: 2rem; }
}
.hero-compare__filters { display: flex; flex-direction: column; align-items: center; gap: var(--sp-2); width: 100%; }
.hero-compare__filters-label {
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted);
}
.filter-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--sp-2); max-width: 720px; }
.filter-chip {
    display: inline-flex; align-items: center; gap: var(--sp-2);
    padding: 8px 14px; background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-full); color: var(--text);
    font-size: var(--fs-sm); font-weight: var(--fw-medium); text-decoration: none;
    transition: border-color var(--t-fast), background var(--t-fast), transform var(--t-fast);
}
.filter-chip:hover {
    border-color: var(--alert); background: var(--alert-50); color: var(--alert); transform: translateY(-1px);
}
.filter-chip__label { white-space: nowrap; }
.filter-chip__count {
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    color: var(--text-muted); background: var(--bg-alt);
    padding: 2px 7px; border-radius: var(--r-sm); line-height: 1.4;
}
.hero-compare__meta {
    display: inline-flex; align-items: center; flex-wrap: wrap; justify-content: center;
    gap: var(--sp-2); padding: 6px 14px;
    font-size: var(--fs-xs); color: var(--text-muted);
    background: var(--bg-alt); border: 1px solid var(--border); border-radius: var(--r-full);
    margin-top: var(--sp-2);
}
.hero-compare__meta-sep { opacity: 0.5; }

/* ── COMMON ────────────────────────────────────────────────────── */
.block-eyebrow {
    display: inline-block; font-family: var(--font-mono);
    font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--alert); background: var(--alert-50);
    border: 1px solid color-mix(in srgb, var(--alert) 22%, transparent);
    padding: 4px 10px; border-radius: var(--r-full); margin-bottom: var(--sp-3);
}
.block-eyebrow--accent {
    color: var(--accent-dark); background: var(--accent-50);
    border-color: color-mix(in srgb, var(--accent) 22%, transparent);
}
.section-head--centered { text-align: center; margin-bottom: var(--section-head-mb); }
.section-head--centered .section-head__title {
    margin: 0 0 var(--sp-2);
    font-size: clamp(1.25rem, 2vw + 0.5rem, 1.875rem);
}
.section-head--centered .section-head__subtitle {
    margin: 0 auto; font-size: var(--fs-sm);
    color: var(--text-muted); line-height: var(--lh-relaxed); max-width: 720px;
}

/* ── 3. BRACKET (10 matchup cards 2-col) ──────────────────────── */
.bracket-section { background: var(--bg); }
.bracket-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-4);
}
@media (min-width: 768px) {
    .bracket-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-5); }
}
.bracket-card {
    position: relative;
    display: flex; flex-direction: column;
    gap: var(--sp-3);
    padding: var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--shadow-xs);
    text-decoration: none;
    transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
    overflow: hidden;
}
.bracket-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--grad-crash);
    opacity: 0.6;
    transition: opacity var(--t-fast);
}
.bracket-card--tied::before { background: var(--grad-primary); }
.bracket-card:hover {
    border-color: var(--alert);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.bracket-card:hover::before { opacity: 1; }
.bracket-card__matchup {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    padding-bottom: var(--sp-2);
    border-bottom: 1px dashed var(--border);
}
.bracket-card__title {
    font-size: var(--fs-md);
    font-weight: var(--fw-bold);
    color: var(--text);
    flex: 1;
    line-height: var(--lh-snug);
}
.bracket-card__title:last-child { text-align: right; }
.bracket-card__vs {
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    font-weight: var(--fw-black);
    color: var(--alert);
    background: var(--alert-50);
    padding: 4px 8px;
    border-radius: var(--r-sm);
    flex-shrink: 0;
}
.bracket-card--tied .bracket-card__vs { color: var(--primary); background: var(--primary-50); }
.bracket-card__verdict-row {
    display: flex; align-items: center;
    gap: var(--sp-3);
    padding: var(--sp-2) var(--sp-3);
    background: var(--bg-alt);
    border-radius: var(--r-sm);
}
.bracket-card__verdict-score {
    font-family: var(--font-mono);
    font-size: var(--fs-xl);
    font-weight: var(--fw-black);
    color: var(--alert);
    line-height: 1;
}
.bracket-card--tied .bracket-card__verdict-score { color: var(--primary); }
.bracket-card__verdict-label {
    font-size: var(--fs-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-family: var(--font-mono);
}
.bracket-card__verdict-label strong {
    color: var(--text);
    font-weight: var(--fw-bold);
    text-transform: none;
    letter-spacing: 0;
}
.bracket-card__lead {
    margin: 0;
    font-size: var(--fs-sm);
    color: var(--text-muted);
    line-height: var(--lh-relaxed);
    flex: 1;
}
.bracket-card__cta {
    margin-top: auto;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--alert);
    transition: transform var(--t-fast);
}
.bracket-card--tied .bracket-card__cta { color: var(--primary); }
.bracket-card:hover .bracket-card__cta { transform: translateX(3px); }

/* ── 4. VERDICT DISTRIBUTION CHART ─────────────────────────────── */
.verdict-distribution-section { background: var(--bg-alt); }
.verdict-chart {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    padding: clamp(20px, 3vw, 32px);
    box-shadow: var(--shadow-sm);
}
.verdict-row {
    display: grid;
    grid-template-columns: 130px 1fr 80px;
    gap: var(--sp-4);
    align-items: center;
}
@media (max-width: 640px) {
    .verdict-row { grid-template-columns: 90px 1fr 60px; gap: var(--sp-2); }
}
.verdict-row__name {
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    color: var(--text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.verdict-row__bars {
    display: flex;
    background: var(--bg-alt);
    border-radius: var(--r-sm);
    height: 22px;
    overflow: hidden;
}
.verdict-row__bar {
    height: 100%;
    transition: width 600ms cubic-bezier(0.16, 1, 0.3, 1);
}
.verdict-row__bar--wins { background: var(--grad-primary); }
.verdict-row__bar--ties { background: linear-gradient(90deg, var(--accent), var(--accent-light)); }
.verdict-row--accent .verdict-row__bar--wins  { background: linear-gradient(90deg, var(--accent-dark), var(--accent)); }
.verdict-row--success .verdict-row__bar--wins { background: linear-gradient(90deg, var(--success), #06B6D4); }
.verdict-row--alert .verdict-row__bar--wins   { background: var(--grad-crash); }
.verdict-row--neutral .verdict-row__bar--wins { background: var(--text-dim); }
.verdict-row__count {
    font-family: var(--font-mono);
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    color: var(--text);
    text-align: right;
}

/* ── 5. CROSSOVER TABLE ────────────────────────────────────────── */
.crossover-section { background: var(--bg); }
.crossover-table-wrap {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    padding: clamp(16px, 2.5vw, 28px);
    box-shadow: var(--shadow-sm);
    overflow-x: auto;
}
.crossover-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--fs-sm);
}
.crossover-table th, .crossover-table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border-subtle);
}
.crossover-table thead th {
    background: var(--bg-alt);
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    font-weight: var(--fw-semibold);
}
.crossover-table__from {
    font-weight: var(--fw-bold);
    color: var(--text);
    background: var(--bg);
}
.crossover-table tbody tr:hover { background: var(--bg-alt); }
.crossover-table tbody tr:last-child td,
.crossover-table tbody tr:last-child th { border-bottom: 0; }
.crossover-table a {
    color: var(--alert);
    font-weight: var(--fw-semibold);
    text-decoration: underline;
    text-decoration-color: rgba(249, 115, 22, 0.3);
    text-underline-offset: 3px;
}
.crossover-table a:hover { text-decoration-color: var(--alert); }

/* ── 6. DECISION FRAMEWORK 3-STEP ─────────────────────────────── */
.decision-framework-section { background: var(--bg-alt); }
.decision-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sp-4);
    position: relative;
}
.decision-steps::before {
    content: '';
    position: absolute;
    left: 28px;
    top: 32px;
    bottom: 32px;
    width: 2px;
    background: var(--grad-crash);
    opacity: 0.25;
    z-index: 0;
}
.decision-step {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: var(--sp-4);
    align-items: flex-start;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: var(--sp-4) var(--sp-5);
    box-shadow: var(--shadow-xs);
}
.decision-step__num {
    width: 56px; height: 56px;
    border-radius: var(--r-full);
    background: var(--grad-crash);
    color: #FFFFFF;
    font-family: var(--font-mono);
    font-size: var(--fs-md);
    font-weight: var(--fw-black);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-sm);
}
.decision-step__body { padding: var(--sp-2) 0; }
.decision-step__title {
    margin: 0 0 var(--sp-2);
    font-size: var(--fs-md);
    font-weight: var(--fw-bold);
    color: var(--text);
    line-height: var(--lh-snug);
}
.decision-step__text {
    margin: 0;
    font-size: var(--fs-sm);
    color: var(--text-muted);
    line-height: var(--lh-relaxed);
}

/* ── 7. BODY ──────────────────────────────────────────────────── */
.catalog-body-section { background: var(--bg); }
.hub-body h2 {
    margin-top: var(--sp-10);
    margin-bottom: var(--sp-4);
    padding-top: var(--sp-4);
    border-top: 1px solid var(--border-subtle);
}
.hub-body h2:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
.hub-body p { margin-bottom: var(--sp-4); line-height: var(--lh-relaxed); }
.hub-body .answer-box {
    background: var(--alert-50);
    border-left: 3px solid var(--alert);
    border-radius: var(--r-md);
    padding: var(--sp-4) var(--sp-5);
    margin: var(--sp-5) 0;
}
.hub-body .answer-box__label {
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--alert);
    margin-bottom: 6px;
}
.hub-body .answer-box__text { margin: 0; font-size: var(--fs-md); line-height: var(--lh-relaxed); }
.hub-body .review-pullquote {
    margin: var(--sp-8) 0;
    padding: var(--sp-5) var(--sp-6);
    background: var(--surface);
    border: 1px solid var(--border);
    border-left: 4px solid var(--alert);
    border-radius: var(--r-lg);
}
.hub-body .review-pullquote blockquote {
    margin: 0 0 var(--sp-3);
    font-size: var(--fs-lg);
    font-weight: var(--fw-medium);
    line-height: var(--lh-snug);
    color: var(--text);
    font-style: italic;
}
.hub-body .review-pullquote figcaption {
    font-size: var(--fs-sm);
    color: var(--text-muted);
}
.hub-body .body-aside {
    display: flex;
    gap: var(--sp-4);
    align-items: flex-start;
    margin: var(--sp-6) 0;
    padding: var(--sp-4) var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-left: 4px solid var(--alert);
    border-radius: var(--r-md);
    box-shadow: var(--shadow-xs);
}
.hub-body .body-aside--exclude { border-left-color: var(--alert); }
.hub-body .body-aside--stats   { border-left-color: var(--accent); }
.hub-body .body-aside--ethics  { border-left-color: var(--success); }
.hub-body .body-aside__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: var(--r-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    line-height: 1;
}
.hub-body .body-aside--exclude .body-aside__icon { background: var(--alert-50);   color: var(--alert); }
.hub-body .body-aside--stats   .body-aside__icon { background: var(--accent-50);  color: var(--accent-dark); }
.hub-body .body-aside--ethics  .body-aside__icon { background: var(--success-50); color: var(--success); }
.hub-body .body-aside__body { flex: 1; min-width: 0; }
.hub-body .body-aside__title {
    margin: 0 0 var(--sp-2);
    font-size: var(--fs-md);
    font-weight: var(--fw-bold);
    color: var(--text);
}
.hub-body .body-aside p { margin: 0; font-size: var(--fs-sm); line-height: var(--lh-relaxed); }
@media (max-width: 540px) {
    .hub-body .body-aside { flex-direction: column; gap: var(--sp-3); }
}

/* ── 8. METHODOLOGY 2×2 ──────────────────────────────────────── */
.methodology-section { background: var(--bg-alt); }
.methodology-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-4);
}
@media (min-width: 640px) {
    .methodology-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-5); }
}
.meth-card {
    padding: var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--shadow-xs);
    transition: border-color var(--t-fast), transform var(--t-fast);
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
}
.meth-card:hover { border-color: var(--alert); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.meth-card__icon {
    width: 44px; height: 44px;
    border-radius: var(--r-md);
    background: var(--alert-50);
    color: var(--alert);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
}
.meth-card:nth-child(2) .meth-card__icon { background: var(--accent-50); color: var(--accent-dark); }
.meth-card:nth-child(3) .meth-card__icon { background: var(--success-50); color: var(--success); }
.meth-card:nth-child(4) .meth-card__icon { background: var(--primary-50); color: var(--primary); }
.meth-card__title {
    margin: 0;
    font-size: var(--fs-md);
    font-weight: var(--fw-bold);
    color: var(--text);
    line-height: var(--lh-snug);
}
.meth-card__body {
    margin: 0;
    font-size: var(--fs-sm);
    color: var(--text-muted);
    line-height: var(--lh-relaxed);
}

/* ── 9. FEATURED PICKS (3 verdict cards) ────────────────────── */
.featured-picks-section { background: var(--bg); }
.featured-picks-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-4);
}
@media (min-width: 768px) {
    .featured-picks-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); }
}
.featured-pick {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    padding: var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    text-decoration: none;
    box-shadow: var(--shadow-xs);
    transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
    overflow: hidden;
}
.featured-pick::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: var(--grad-crash);
}
.featured-pick:hover {
    border-color: var(--alert);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}
.featured-pick__badge {
    align-self: flex-start;
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #FFFFFF;
    background: var(--grad-crash);
    padding: 4px 10px;
    border-radius: var(--r-full);
}
.featured-pick__matchup {
    margin: 0;
    font-size: 1.4rem;
    font-weight: var(--fw-black);
    color: var(--text);
    line-height: 1.05;
    letter-spacing: -0.02em;
}
.featured-pick__verdict {
    display: flex;
    align-items: baseline;
    gap: var(--sp-3);
    padding: var(--sp-3);
    background: var(--alert-50);
    border-radius: var(--r-md);
}
.featured-pick__score {
    font-family: var(--font-mono);
    font-size: 1.5rem;
    font-weight: var(--fw-black);
    color: var(--alert);
    line-height: 1;
}
.featured-pick__winner {
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--alert);
}
.featured-pick__winner::before {
    content: 'Winner: ';
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    font-weight: var(--fw-medium);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.featured-pick__summary {
    margin: 0;
    font-size: var(--fs-sm);
    color: var(--text);
    line-height: var(--lh-relaxed);
    flex: 1;
}
.featured-pick__cta {
    margin-top: auto;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--alert);
    transition: transform var(--t-fast);
}
.featured-pick:hover .featured-pick__cta { transform: translateX(4px); }

/* ── 10. GLOSSARY ─────────────────────────────────────────────── */
.glossary-section { background: var(--bg); }
.glossary-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-3);
}
@media (min-width: 640px) {
    .glossary-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
}
@media (min-width: 1024px) {
    .glossary-grid { grid-template-columns: repeat(3, 1fr); }
    .glossary-grid .glossary-tile:nth-child(4) { grid-column: 1 / 3; }
    .glossary-grid .glossary-tile:nth-child(5) { grid-column: 3 / 4; }
}
.glossary-tile {
    display: flex;
    gap: var(--sp-3);
    padding: var(--sp-4) var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border-subtle);
    border-radius: var(--r-md);
    transition: border-color var(--t-fast), background var(--t-fast);
}
.glossary-tile:hover { border-color: var(--alert); background: var(--alert-50); }
.glossary-tile__icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: var(--r-sm);
    background: var(--alert-50);
    color: var(--alert);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-mono);
    font-size: var(--fs-md);
    font-weight: var(--fw-black);
}
.glossary-tile__body { flex: 1; min-width: 0; }
.glossary-tile__term {
    margin: 0 0 4px;
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    color: var(--text);
}
.glossary-tile__def {
    margin: 0;
    font-size: var(--fs-xs);
    color: var(--text-muted);
    line-height: var(--lh-relaxed);
}

/* ── 12. COMPARE FAQ ──────────────────────────────────────────── */
.compare-faq-section { background: var(--bg-alt); }
.compare-faq-section .faq-head { text-align: center; margin-bottom: var(--sp-6); }
.compare-faq-section .faq-head__eyebrow {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--alert);
    background: var(--alert-50);
    padding: 4px 10px;
    border-radius: var(--r-full);
    margin-bottom: var(--sp-2);
}
.compare-faq-section .faq-head__title { margin: 0 0 var(--sp-2); }
.compare-faq-section .faq-head__lead {
    margin: 0 auto;
    font-size: var(--fs-sm);
    color: var(--text-muted);
    max-width: 640px;
}
.compare-faq-section .faq-list--home {
    display: flex; flex-direction: column; gap: var(--sp-2);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    padding: var(--sp-3);
    box-shadow: var(--shadow-sm);
}
.compare-faq-section .faq-item {
    border-radius: var(--r-md);
    background: var(--bg);
    border: 1px solid var(--border-subtle);
    transition: border-color var(--t-fast);
}
.compare-faq-section .faq-item[open] { border-color: var(--alert); }
.compare-faq-section .faq-item__q {
    cursor: pointer;
    list-style: none;
    padding: var(--sp-3) var(--sp-4);
    font-weight: var(--fw-semibold);
    font-size: var(--fs-md);
    color: var(--text);
    display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
}
.compare-faq-section .faq-item__q::-webkit-details-marker { display: none; }
.compare-faq-section .faq-item__q::after {
    content: '+';
    font-family: var(--font-mono);
    font-size: var(--fs-lg);
    color: var(--alert);
}
.compare-faq-section .faq-item[open] .faq-item__q::after { content: '−'; }
.compare-faq-section .faq-item__a {
    padding: 0 var(--sp-4) var(--sp-4);
    font-size: var(--fs-sm);
    color: var(--text);
    line-height: var(--lh-relaxed);
}
.compare-faq-section .faq-item__a p { margin: 0 0 var(--sp-3); }
.compare-faq-section .faq-item__a p:last-child { margin: 0; }

/* ── 13. CROSS-HUBS (5 SVG cards) ────────────────────────────── */
.cross-hubs-section { background: var(--bg); }
.cross-hubs {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-3);
}
@media (min-width: 640px) {
    .cross-hubs { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
}
@media (min-width: 1024px) {
    .cross-hubs { grid-template-columns: repeat(5, 1fr); }
}
.cross-hub {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    padding: var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    text-decoration: none;
    transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
    box-shadow: var(--shadow-xs);
    overflow: hidden;
}
.cross-hub::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--grad-primary);
    opacity: 0.6;
    transition: opacity var(--t-fast), height var(--t-fast);
}
.cross-hub:hover {
    border-color: var(--alert);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}
.cross-hub:hover::before { opacity: 1; height: 4px; }
.cross-hub__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: var(--r-lg);
    background: var(--primary-50);
    color: var(--primary);
    transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.cross-hub__icon svg { width: 32px; height: 32px; }
.cross-hub:hover .cross-hub__icon { transform: scale(1.05) rotate(-3deg); }
.cross-hub--home    .cross-hub__icon { background: var(--primary-50); color: var(--primary-dark); }
.cross-hub--home::before              { background: linear-gradient(135deg, var(--primary), var(--primary-light)); }
.cross-hub--games   .cross-hub__icon { background: var(--accent-50);  color: var(--accent-dark); }
.cross-hub--games::before             { background: linear-gradient(135deg, var(--accent-dark), var(--accent)); }
.cross-hub--studios .cross-hub__icon { background: var(--accent-50);  color: var(--accent-dark); }
.cross-hub--studios::before           { background: linear-gradient(135deg, var(--accent-dark), var(--accent)); }
.cross-hub--tools   .cross-hub__icon { background: var(--success-50); color: var(--success); }
.cross-hub--tools::before             { background: linear-gradient(135deg, #10B981, #06B6D4); }
.cross-hub--blog    .cross-hub__icon { background: var(--alert-50);   color: var(--alert); }
.cross-hub--blog::before              { background: var(--grad-crash); }
.cross-hub__title { font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--text); line-height: var(--lh-snug); }
.cross-hub__lead {
    flex: 1;
    font-size: var(--fs-sm);
    color: var(--text-muted);
    line-height: var(--lh-relaxed);
    margin: 0;
}
.cross-hub__arrow {
    align-self: flex-end;
    font-family: var(--font-mono);
    font-size: var(--fs-xl);
    color: var(--alert);
    line-height: 1;
    transition: transform var(--t-fast);
}
.cross-hub:hover .cross-hub__arrow { transform: translateX(4px); }

/* ── AUTHOR BYLINE ─────────────────────────────────────────────── */
.author-byline {
    display: flex;
    justify-content: center;
    padding-top: var(--sp-5);
    border-top: 1px solid var(--border-subtle);
}
.author-byline__inner {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: var(--fs-sm);
    color: var(--text-muted);
    flex-wrap: wrap;
    justify-content: center;
}
.author-byline__label { font-weight: var(--fw-medium); }
.author-byline__name { color: var(--alert); font-weight: var(--fw-semibold); }
.author-byline__sep { opacity: 0.4; }
.author-byline__date { font-family: var(--font-mono); font-size: var(--fs-xs); }
