/* ============================================================
   ColdBoot — Game Page Styles
   ============================================================
   Add to your theme's stylesheet or enqueue separately.
   Uses BEM naming: .cb-{block}__{element}--{modifier}
   ============================================================ */

/* --- Design tokens --- */
:root {
    --cb-font-body: 'Source Serif 4', 'Georgia', serif;
    --cb-font-ui: 'DM Sans', 'Helvetica Neue', sans-serif;
    --cb-font-mono: 'JetBrains Mono', 'Courier New', monospace;

    --cb-black: #1a1a1a;
    --cb-white: #fafaf8;
    --cb-grey-100: #f3f2ef;
    --cb-grey-200: #e4e2dc;
    --cb-grey-300: #c8c5bc;
    --cb-grey-500: #8a8780;
    --cb-grey-700: #4a4843;

    --cb-green: #2a7d4f;
    --cb-green-bg: #e8f5ee;
    --cb-yellow: #b8860b;
    --cb-yellow-bg: #fdf6e3;
    --cb-red: #b33a3a;
    --cb-red-bg: #fbeaea;
    --cb-blue: #2d6a9f;
    --cb-blue-bg: #eaf2f8;

    --cb-max-width: 740px;
    --cb-max-width-wide: 960px;
    --cb-gap: 1.5rem;
    --cb-radius: 6px;
    --cb-border: 1px solid var(--cb-grey-200);
}

/* --- Base article --- */
.cb-game {
    max-width: var(--cb-max-width);
    margin: 0 auto;
    padding: 2rem var(--cb-gap);
    font-family: var(--cb-font-body);
    font-size: 1.0625rem;
    line-height: 1.65;
    color: var(--cb-black);
}

/* --- Header --- */
.cb-game__header {
    margin-bottom: 2.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 2px solid var(--cb-black);
}

.cb-game__title {
    font-family: var(--cb-font-ui);
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin: 0 0 0.75rem;
}

.cb-game__meta-line {
    font-family: var(--cb-font-ui);
    font-size: 0.9rem;
    color: var(--cb-grey-500);
    margin: 0 0 0.25rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
}

.cb-game__meta-line span:not(:last-child)::after {
    content: ' · ';
    color: var(--cb-grey-300);
}

.cb-game__check-date {
    font-family: var(--cb-font-ui);
    font-size: 0.8rem;
    color: var(--cb-grey-500);
    margin: 0.5rem 0 0;
}

/* --- Quick Verdict card --- */
.cb-verdict {
    background: var(--cb-grey-100);
    border: var(--cb-border);
    border-radius: var(--cb-radius);
    padding: 1.5rem;
    margin-bottom: 2.5rem;
}

.cb-verdict__title {
    font-family: var(--cb-font-ui);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--cb-grey-500);
    margin: 0 0 1rem;
}

.cb-verdict__status {
    display: inline-block;
    font-family: var(--cb-font-ui);
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0.35rem 0.85rem;
    border-radius: 3px;
    margin-bottom: 1.25rem;
}

.cb-verdict__status--strongly-recommended {
    background: var(--cb-green-bg);
    color: var(--cb-green);
}

.cb-verdict__status--recommended {
    background: var(--cb-green-bg);
    color: var(--cb-green);
}

.cb-verdict__status--mixed {
    background: var(--cb-yellow-bg);
    color: var(--cb-yellow);
}

.cb-verdict__status--not-recommended,
.cb-verdict__status--skip {
    background: var(--cb-red-bg);
    color: var(--cb-red);
}

.cb-verdict__grid {
    margin: 0;
}

.cb-verdict__row {
    display: flex;
    gap: 1rem;
    padding: 0.45rem 0;
    border-bottom: 1px solid var(--cb-grey-200);
    align-items: baseline;
}

.cb-verdict__row:last-child {
    border-bottom: none;
}

.cb-verdict__row dt {
    font-family: var(--cb-font-ui);
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--cb-grey-700);
    min-width: 180px;
    flex-shrink: 0;
}

.cb-verdict__row dd {
    font-size: 0.9rem;
    margin: 0;
}

.cb-verdict__barrier {
    font-family: var(--cb-font-ui);
    font-size: 0.85rem;
    margin: 1.25rem 0 0;
    padding-top: 1rem;
    border-top: 1px solid var(--cb-grey-200);
    color: var(--cb-grey-700);
}

/* --- Tags (friction levels, ratings) --- */
.cb-tag {
    display: inline-block;
    font-family: var(--cb-font-ui);
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.15rem 0.55rem;
    border-radius: 3px;
    white-space: nowrap;
}

.cb-tag--very-strong { background: var(--cb-green-bg); color: var(--cb-green); }
.cb-tag--strong      { background: var(--cb-green-bg); color: var(--cb-green); }
.cb-tag--mixed       { background: var(--cb-yellow-bg); color: var(--cb-yellow); }
.cb-tag--weak        { background: var(--cb-red-bg); color: var(--cb-red); }
.cb-tag--very-weak   { background: var(--cb-red-bg); color: var(--cb-red); }
.cb-tag--very-low    { background: var(--cb-green-bg); color: var(--cb-green); }
.cb-tag--low         { background: var(--cb-green-bg); color: var(--cb-green); }
.cb-tag--moderate    { background: var(--cb-yellow-bg); color: var(--cb-yellow); }
.cb-tag--high        { background: var(--cb-red-bg); color: var(--cb-red); }
.cb-tag--very-high   { background: var(--cb-red-bg); color: var(--cb-red); }

/* --- Prose sections --- */
.cb-prose {
    margin-bottom: 2.5rem;
}

.cb-prose h2 {
    font-family: var(--cb-font-ui);
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin: 0 0 1rem;
    padding-top: 0.5rem;
}

.cb-prose p {
    margin: 0 0 1rem;
}

.cb-prose ul,
.cb-prose ol {
    margin: 0 0 1rem;
    padding-left: 1.25rem;
}

.cb-prose li {
    margin-bottom: 0.35rem;
}

.cb-prose strong {
    font-weight: 600;
}

.cb-prose--note {
    font-size: 0.9rem;
    color: var(--cb-grey-500);
    border-top: var(--cb-border);
    padding-top: 1.5rem;
}

.cb-prose--note h2 {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--cb-grey-500);
}

/* --- FAQ --- */
.cb-prose--faq p {
    margin-bottom: 0.75rem;
}

.cb-prose--faq strong {
    display: block;
    font-family: var(--cb-font-ui);
    font-size: 0.95rem;
    margin-top: 1.25rem;
}

.cb-prose--faq strong:first-child {
    margin-top: 0;
}

/* --- Version Map cards --- */
.cb-versions {
    margin-bottom: 2.5rem;
}

.cb-versions h2 {
    font-family: var(--cb-font-ui);
    font-size: 1.35rem;
    font-weight: 700;
    margin: 0 0 1.25rem;
}

.cb-versions__grid {
    display: grid;
    gap: 1rem;
}

.cb-versions__card {
    background: var(--cb-white);
    border: var(--cb-border);
    border-radius: var(--cb-radius);
    padding: 1.25rem;
    transition: border-color 0.15s ease;
}

.cb-versions__card:hover {
    border-color: var(--cb-grey-300);
}

.cb-versions__card--yes {
    border-left: 3px solid var(--cb-green);
}

.cb-versions__card--selectively {
    border-left: 3px solid var(--cb-yellow);
}

.cb-versions__card--no {
    border-left: 3px solid var(--cb-grey-300);
    opacity: 0.75;
}

.cb-versions__card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.cb-versions__name {
    font-family: var(--cb-font-ui);
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
}

.cb-versions__badge {
    font-family: var(--cb-font-ui);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.15rem 0.5rem;
    border-radius: 3px;
    white-space: nowrap;
    flex-shrink: 0;
}

.cb-versions__badge--yes        { background: var(--cb-green-bg); color: var(--cb-green); }
.cb-versions__badge--selectively { background: var(--cb-yellow-bg); color: var(--cb-yellow); }
.cb-versions__badge--no          { background: var(--cb-grey-100); color: var(--cb-grey-500); }

.cb-versions__type {
    font-family: var(--cb-font-ui);
    font-size: 0.8rem;
    color: var(--cb-grey-500);
    margin: 0 0 0.15rem;
}

.cb-versions__platforms {
    font-family: var(--cb-font-ui);
    font-size: 0.8rem;
    color: var(--cb-grey-500);
    margin: 0 0 0.75rem;
}

.cb-versions__details {
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}

.cb-versions__pros,
.cb-versions__cons {
    margin: 0 0 0.25rem;
    padding-left: 1.1rem;
    position: relative;
}

.cb-versions__pros::before {
    content: '+';
    position: absolute;
    left: 0;
    color: var(--cb-green);
    font-weight: 700;
}

.cb-versions__cons::before {
    content: '−';
    position: absolute;
    left: 0;
    color: var(--cb-red);
    font-weight: 700;
}

.cb-versions__best-for {
    font-size: 0.85rem;
    color: var(--cb-grey-700);
    margin: 0.5rem 0 0;
}

/* --- Play Today Framework --- */
.cb-ptf {
    margin-bottom: 2.5rem;
}

.cb-ptf h2 {
    font-family: var(--cb-font-ui);
    font-size: 1.35rem;
    font-weight: 700;
    margin: 0 0 1.25rem;
}

.cb-ptf__grid {
    display: grid;
    gap: 0;
}

.cb-ptf__row {
    display: grid;
    grid-template-columns: 170px auto 1fr;
    gap: 0.75rem;
    padding: 0.65rem 0;
    border-bottom: 1px solid var(--cb-grey-200);
    align-items: baseline;
}

.cb-ptf__row:last-child {
    border-bottom: none;
}

.cb-ptf__label {
    font-family: var(--cb-font-ui);
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--cb-grey-700);
}

.cb-ptf__rating {
    min-width: 80px;
}

.cb-ptf__summary {
    font-size: 0.9rem;
    color: var(--cb-grey-700);
}

/* --- Before Starting --- */
.cb-before {
    background: var(--cb-blue-bg);
    border: 1px solid #c8d9e6;
    border-radius: var(--cb-radius);
    padding: 1.5rem;
    margin-bottom: 2.5rem;
}

.cb-before h2 {
    font-family: var(--cb-font-ui);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--cb-blue);
    margin: 0 0 1rem;
}

.cb-before__grid {
    margin: 0 0 1rem;
}

.cb-before__row {
    display: flex;
    gap: 1rem;
    padding: 0.35rem 0;
    border-bottom: 1px solid #c8d9e6;
    align-items: baseline;
}

.cb-before__row:last-child {
    border-bottom: none;
}

.cb-before__row dt {
    font-family: var(--cb-font-ui);
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--cb-grey-700);
    min-width: 160px;
    flex-shrink: 0;
}

.cb-before__row dd {
    font-size: 0.9rem;
    margin: 0;
}

.cb-before__prose {
    font-size: 0.9rem;
    border-top: 1px solid #c8d9e6;
    padding-top: 1rem;
    margin-top: 0.5rem;
}

.cb-before__prose p {
    margin: 0;
}

/* --- Related Games --- */
.cb-related {
    margin-bottom: 2.5rem;
    border-top: var(--cb-border);
    padding-top: 2rem;
}

.cb-related h2 {
    font-family: var(--cb-font-ui);
    font-size: 1.35rem;
    font-weight: 700;
    margin: 0 0 1.25rem;
}

.cb-related__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.cb-related__card {
    background: var(--cb-grey-100);
    border-radius: var(--cb-radius);
    padding: 1rem;
}

.cb-related__card h3 {
    font-family: var(--cb-font-ui);
    font-size: 0.95rem;
    font-weight: 600;
    margin: 0 0 0.35rem;
}

.cb-related__card h3 a {
    color: var(--cb-blue);
    text-decoration: none;
}

.cb-related__card h3 a:hover {
    text-decoration: underline;
}

.cb-related__context {
    font-family: var(--cb-font-ui);
    font-size: 0.8rem;
    color: var(--cb-grey-500);
    margin: 0;
}

/* --- Responsive --- */
@media (max-width: 768px) {
    .cb-game__title {
        font-size: 1.5rem;
    }

    .cb-verdict__row {
        flex-direction: column;
        gap: 0.15rem;
    }

    .cb-verdict__row dt {
        min-width: 0;
    }

    .cb-ptf__row {
        grid-template-columns: 1fr;
        gap: 0.25rem;
    }

    .cb-ptf__label {
        font-weight: 600;
    }

    .cb-before__row {
        flex-direction: column;
        gap: 0.15rem;
    }

    .cb-before__row dt {
        min-width: 0;
    }

    .cb-related__grid {
        grid-template-columns: 1fr;
    }
}