/* Games index — polished Bootstrap look */
:root{
    --games-card-radius: 1rem;
    --games-shadow: 0 .5rem 1.5rem rgba(0,0,0,.12);
    --games-shadow-lg: 0 1rem 3rem rgba(0,0,0,.18);
    --games-scan: rgba(255,255,255,.065);
    --cover-img: none; /* added: default when no image provided */
}

/* Light mode (Bootstrap color modes) */
:root, [data-bs-theme="light"]{
    color-scheme: light dark; /* keep native control theming */

    /* your tokens (unchanged) */
    --games-card-radius: 1rem;
    --games-shadow: 0 .5rem 1.5rem rgba(0,0,0,.12);
    --games-shadow-lg: 0 1rem 3rem rgba(0,0,0,.18);

    /* theme-aware additions (unchanged) */
    --games-scan: rgba(255,255,255,.065);
    --cover-default: radial-gradient(120% 100% at 0% 0%, #eaf5ff, #beddff 65%, #6aa0f0);

    /* status/badge palette → your custom tokens (unchanged) */
    --dev:      var(--carrot-orange);
    --complete: var(--emerald);
    --demo:     var(--sunset);
    --mini:     var(--lime-green);
    --on-solid: #ffffff;
    --solid-border-contrast: black 22%;
}

/* Dark mode */
[data-bs-theme="dark"]{
    color-scheme: dark;

    /* dark tuning (unchanged) */
    --games-scan: rgba(255,255,255,.04);
    --cover-default: radial-gradient(120% 100% at 0% 0%, #0f172a, #0b2a4a 55%, #17406f);

    /* status/badge palette (unchanged) */
    --dev:      var(--carrot-orange);
    --complete: var(--emerald);
    --demo:     var(--sunset);
    --mini:     var(--lime-green);
    --on-solid: #0b0b0b;
    --solid-border-contrast: white 14%;
}

/* Hero */
.games-hero{ text-align:center; }
.games-hero h1{ letter-spacing:.25px; margin-bottom:.25rem; }
.games-hero p.lead{
    color: var(--bs-secondary-color);
    max-width: 60ch; margin: 0 auto 1.5rem;
}

/* Make the whole card clickable */
a.card-link-wrap{ display:block; color:inherit; text-decoration:none; }

/* Card */
.game-card{
    position: relative; /* ensures overlays/badges position correctly */
    border: 0;
    border-radius: var(--games-card-radius);
    overflow: hidden;
    box-shadow: var(--games-shadow);
    transition: transform .18s ease, box-shadow .18s ease;
    background: var(--bs-body-bg);
}
a.card-link-wrap:hover .game-card,
a.card-link-wrap:focus .game-card{
    transform: translateY(-2px);
    box-shadow: var(--games-shadow-lg);
}

/* Cover band — now layered: image (top) over your gradient (bottom) */
.game-cover{
    position: relative;
    background-image:
            var(--cover-img),
            var(--cover, radial-gradient(120% 100% at 0% 0%, #d9f0ff, #95c7ff 70%, #4b7fda));
    background-size: cover, cover;
    background-position: center, center;
    background-repeat: no-repeat, no-repeat;
    filter: saturate(.95) contrast(1.05);
    border-top-left-radius: var(--games-card-radius);
    border-top-right-radius: var(--games-card-radius);
}
.game-cover::after{
    content:"";
    position:absolute; inset:0;
    background:
            linear-gradient(180deg, rgba(255,255,255,.28), transparent 40%),
            repeating-linear-gradient(to bottom, var(--games-scan) 0 1px, transparent 1px 3px);
    mix-blend-mode: overlay; pointer-events:none;
}

/* Status ribbon on the cover */
.game-status{
    position: absolute; top:.75rem; right:.75rem; z-index: 2;
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.15);
}

/* Body */
.game-card .card-body{ padding: 1rem 1rem 1.1rem; text-align:center; }
.game-title{ margin:0; font-weight:700; letter-spacing:.2px; }
.game-tagline{ margin-top:.35rem; color: var(--bs-secondary-color); }

/* Tag pills */
.game-tags{ justify-content:center; }
.game-tags .badge{
    background: var(--bs-secondary-bg);
    color: var(--bs-secondary-color);
    border: 1px solid var(--bs-border-color);
    font-weight: 500;
}

/* Clamp long text */
.line-clamp-2{
    display: -webkit-box; -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; overflow: hidden;
}

@media (prefers-reduced-motion: reduce){
    .game-card{ transition: none; }
}

/* Status badge variants — keep your colors; only border mixing uses color-mix() */
.bg-dev{
    background: var(--dev);
    color: var(--on-solid);
    border: 1px solid color-mix(in oklab, var(--dev), var(--solid-border-contrast));
}
.bg-complete{
    background: var(--complete);
    color: var(--on-solid);
    border: 1px solid color-mix(in oklab, var(--complete), var(--solid-border-contrast));
}
.bg-demo{
    background: var(--demo);
    color: var(--on-solid);
    border: 1px solid color-mix(in oklab, var(--demo), var(--solid-border-contrast));
}
.bg-mini{
    background: var(--mini);
    color: var(--on-solid);
    border: 1px solid color-mix(in oklab, var(--mini), var(--solid-border-contrast));
}



/* Per-game cover overrides (no color changes) */
.king-of-chess-cover{
    --cover: radial-gradient(120% 100% at 0% 0%, var(--periwinkle), var(--emerald) 70%, var(--dark-pastel-green));
}
.macro-meso-sub-terra-cover{
    --cover: radial-gradient(120% 100% at 0% 0%, var(--peach-yellow), var(--carrot-orange) 70%, var(--syracuse-red-orange));
}
.heads-in-bits-cover{
    --cover: radial-gradient(120% 100% at 0% 0%, var(--emerald), var(--vista-blue) 70%, var(--delft-blue));
}

:root { --cover-img: none; }
.game-cover{
    background-image:
            linear-gradient(180deg, rgba(0,0,0,.22), rgba(0,0,0,0) 38%),
            var(--cover-img),
            var(--cover, radial-gradient(120% 100% at 0% 0%, #eaf5ff, #beddff 65%, #6aa0f0));
    background-size: auto, cover, cover;
    background-position: 0 0, center, center;
    background-repeat: no-repeat;
    border-top-left-radius: var(--games-card-radius);
    border-top-right-radius: var(--games-card-radius);
}

.cover-img-404 {
    height: 80% !important;
    width: auto !important;
}

.container-404-outer {
    max-width: 1000px;
}