/* =========================================================
   Pigskin Dispatch HOF Memory Match
   style.css
========================================================= */

* {
    box-sizing: border-box;
}

:root {
    --pd-red: #8f1d1d;
    --pd-dark-red: #5d1111;
    --pd-gold: #d8aa3c;
    --pd-gold-light: #f3d77a;
    --pd-cream: #f4ead2;
    --pd-paper: #fff7e6;
    --pd-ink: #1f1b16;
    --pd-muted: #766a57;
    --pd-green: #17452f;
    --pd-deep: #12100d;
    --pd-shadow: rgba(0, 0, 0, 0.28);
}

html {
    min-height: 100%;
    background: radial-gradient(circle at top, rgba(216, 170, 60, 0.18), transparent 28rem), linear-gradient(135deg, #1d160f, #3a1613 45%, #120f0b);
}

body {
    margin: 0;
    min-height: 100vh;
    color: var(--pd-ink);
    font-family: Georgia, "Times New Roman", serif;
    background: linear-gradient(rgba(18, 16, 13, 0.55), rgba(18, 16, 13, 0.75)), repeating-linear-gradient( 45deg, rgba(255, 255, 255, 0.025) 0, rgba(255, 255, 255, 0.025) 2px, transparent 2px, transparent 8px );
}

button,
input,
select {
    font: inherit;
}

button {
    cursor: pointer;
}

.hidden {
    display: none !important;
}

/* =========================================================
   Shell / Hero
========================================================= */

.hof-game-shell {
    width: min(1180px, calc(100% - 24px));
    margin: 0 auto;
    padding: 24px 0 40px;
}

.game-hero {
    text-align: center;
    color: var(--pd-cream);
    padding: 24px 12px 18px;
}

.hero-kicker {
    display: inline-block;
    padding: 6px 12px;
    margin-bottom: 10px;
    color: var(--pd-gold-light);
    background: rgba(0, 0, 0, 0.28);
    border: 1px solid rgba(216, 170, 60, 0.45);
    border-radius: 999px;
    font-size: 0.85rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.game-hero h1 {
    margin: 0;
    color: #fff7e6;
    font-size: clamp(2.25rem, 6vw, 5rem);
    line-height: 0.95;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-shadow: 0 4px 0 rgba(0, 0, 0, 0.38);
}

.game-hero p {
    max-width: 680px;
    margin: 14px auto 0;
    color: rgba(244, 234, 210, 0.9);
    font-size: 1.1rem;
}

/* =========================================================
   Panels / Screens
========================================================= */

.screen {
    margin-top: 18px;
}

.start-screen {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.6fr);
    gap: 18px;
    align-items: stretch;
}

.panel {
    background: linear-gradient(rgba(255, 247, 230, 0.96), rgba(244, 234, 210, 0.96)), repeating-linear-gradient( 0deg, rgba(31, 27, 22, 0.035) 0, rgba(31, 27, 22, 0.035) 1px, transparent 1px, transparent 6px );
    border: 3px solid var(--pd-dark-red);
    border-radius: 18px;
    box-shadow: 0 14px 35px var(--pd-shadow);
    padding: 22px;
    position: relative;
    overflow: hidden;
}

    .panel::before {
        content: "";
        position: absolute;
        inset: 8px;
        border: 1px solid rgba(143, 29, 29, 0.22);
        border-radius: 12px;
        pointer-events: none;
    }

    .panel h2 {
        position: relative;
        margin: 0 0 16px;
        color: var(--pd-dark-red);
        font-size: 1.75rem;
        line-height: 1;
        text-transform: uppercase;
    }

.form-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 18px;
}

.field {
    display: grid;
    gap: 6px;
}

    .field span {
        color: var(--pd-muted);
        font-weight: 700;
        font-size: 0.92rem;
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }

    .field input,
    .field select {
        width: 100%;
        padding: 12px 12px;
        color: var(--pd-ink);
        background: #fffdf6;
        border: 2px solid rgba(93, 17, 17, 0.35);
        border-radius: 10px;
        outline: none;
    }

        .field input:focus,
        .field select:focus {
            border-color: var(--pd-red);
            box-shadow: 0 0 0 3px rgba(216, 170, 60, 0.28);
        }

.rules-panel ul {
    position: relative;
    margin: 0;
    padding-left: 22px;
    color: var(--pd-ink);
    line-height: 1.55;
}

.rules-panel li {
    margin-bottom: 8px;
}

/* =========================================================
   Buttons
========================================================= */

.primary-btn,
.secondary-btn,
.small-btn {
    position: relative;
    border: 0;
    border-radius: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    transition: transform 0.14s ease, box-shadow 0.14s ease, filter 0.14s ease;
}

.primary-btn {
    width: 100%;
    padding: 15px 18px;
    color: #fff7e6;
    background: linear-gradient(180deg, var(--pd-red), var(--pd-dark-red));
    box-shadow: 0 5px 0 #2e0808, 0 12px 24px rgba(0, 0, 0, 0.28);
}

.secondary-btn {
    padding: 13px 18px;
    color: var(--pd-dark-red);
    background: linear-gradient(180deg, #fff7e6, #e7d4ab);
    border: 2px solid rgba(93, 17, 17, 0.45);
    box-shadow: 0 4px 0 rgba(93, 17, 17, 0.28);
}

.small-btn {
    padding: 8px 12px;
    color: #fff7e6;
    background: linear-gradient(180deg, var(--pd-red), var(--pd-dark-red));
    box-shadow: 0 3px 0 #2e0808;
    font-size: 0.78rem;
}

    .primary-btn:hover,
    .secondary-btn:hover,
    .small-btn:hover {
        transform: translateY(-1px);
        filter: brightness(1.04);
    }

    .primary-btn:active,
    .secondary-btn:active,
    .small-btn:active {
        transform: translateY(2px);
        box-shadow: none;
    }

/* =========================================================
   Scoreboard
========================================================= */

.scoreboard {
    display: grid;
    grid-template-columns: repeat(3, minmax(90px, 1fr)) repeat(2, minmax(160px, 1.5fr));
    gap: 10px;
    margin-bottom: 14px;
}

.score-item {
    color: var(--pd-cream);
    background: linear-gradient(180deg, rgba(23, 69, 47, 0.96), rgba(12, 38, 26, 0.96));
    border: 2px solid rgba(216, 170, 60, 0.7);
    border-radius: 14px;
    padding: 12px 14px;
    box-shadow: 0 8px 20px var(--pd-shadow);
    text-align: center;
}

    .score-item span {
        display: block;
        color: var(--pd-gold-light);
        font-size: 0.78rem;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        margin-bottom: 4px;
    }

    .score-item strong {
        display: block;
        color: #fff7e6;
        font-size: 1.25rem;
        line-height: 1.1;
    }

    .score-item.wide strong {
        font-size: 0.98rem;
    }

/* =========================================================
   Match Message
========================================================= */

.match-message {
    min-height: 44px;
    margin: 8px auto 16px;
    padding: 0 12px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--pd-cream);
    text-align: center;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

    .match-message.success {
        color: var(--pd-deep);
        background: linear-gradient(180deg, var(--pd-gold-light), var(--pd-gold));
        border: 2px solid #fff2b0;
        border-radius: 999px;
        box-shadow: 0 8px 22px rgba(0, 0, 0, 0.26);
        animation: matchPop 0.35s ease both;
    }

    .match-message.error {
        color: #fff7e6;
        background: linear-gradient(180deg, #b92222, #671010);
        border: 2px solid rgba(255, 255, 255, 0.35);
        border-radius: 999px;
    }

@keyframes matchPop {
    0% {
        transform: scale(0.85);
        opacity: 0;
    }

    70% {
        transform: scale(1.05);
        opacity: 1;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* =========================================================
   Game Board / Cards
========================================================= */

.game-board {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: 12px;
    align-items: stretch;
}

.memory-card {
    min-height: 158px;
    padding: 0;
    border: 0;
    background: transparent;
    perspective: 1000px;
    cursor: pointer;
}

.card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 158px;
    transform-style: preserve-3d;
    transition: transform 0.48s ease;
}

.memory-card.flipped .card-inner,
.memory-card.matched .card-inner {
    transform: rotateY(180deg);
}

.card-face {
    position: absolute;
    inset: 0;
    border-radius: 14px;
    backface-visibility: hidden;
    overflow: hidden;
    border: 3px solid #3a130d;
    box-shadow: 0 10px 20px var(--pd-shadow);
}

.card-front {
    display: grid;
    place-items: center;
    padding: 12px;
    color: var(--pd-cream);
    background: radial-gradient(circle at center, rgba(216, 170, 60, 0.32), transparent 45%), repeating-linear-gradient( 45deg, rgba(255, 255, 255, 0.07) 0, rgba(255, 255, 255, 0.07) 2px, transparent 2px, transparent 8px ), linear-gradient(135deg, #8f1d1d, #3c0d0d);
    text-align: center;
}

.card-logo {
    align-self: end;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--pd-gold-light);
}

.card-title {
    font-size: 2.35rem;
    font-weight: 900;
    line-height: 1;
    color: #fff7e6;
    text-shadow: 0 3px 0 rgba(0, 0, 0, 0.35);
}

.card-subtitle {
    align-self: start;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.card-back {
    transform: rotateY(180deg);
    background: #fff7e6;
}

.player-card-back,
.clue-card-back {
    height: 100%;
    min-height: 158px;
    display: grid;
    grid-template-rows: 1fr auto;
    gap: 0;
    align-items: stretch;
}

.player-image {
    width: 100%;
    height: 122px;
    object-fit: cover;
    display: block;
    background: #e8dec6;
}

.image-fallback {
    height: 122px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--pd-dark-red);
    background: radial-gradient(circle, rgba(216, 170, 60, 0.35), transparent 50%), #e8dec6;
    font-size: 2rem;
    font-weight: 900;
}

.player-name {
    min-height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 7px 8px;
    color: #fff7e6;
    background: linear-gradient(180deg, var(--pd-red), var(--pd-dark-red));
    font-weight: 900;
    font-size: 0.86rem;
    line-height: 1.1;
    text-align: center;
}

.clue-card-back {
    grid-template-rows: auto 1fr;
    padding: 12px;
    overflow: hidden;
    background: linear-gradient(rgba(255, 247, 230, 0.96), rgba(244, 234, 210, 0.96)), repeating-linear-gradient( 0deg, rgba(31, 27, 22, 0.05) 0, rgba(31, 27, 22, 0.05) 1px, transparent 1px, transparent 6px );
}

.clue-label {
    color: var(--pd-red);
    font-size: 0.68rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 8px;
    text-align: center;
    line-height: 1.05;
}

.clue-text {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--pd-ink);
    font-size: 0.84rem;
    font-weight: 900;
    line-height: 1.12;
    text-align: center;
    word-break: normal;
    overflow-wrap: anywhere;
    padding: 2px;
}

.memory-card.matched {
    cursor: default;
}

    .memory-card.matched .card-face {
        border-color: var(--pd-gold-light);
        box-shadow: 0 0 0 3px rgba(216, 170, 60, 0.55), 0 10px 20px var(--pd-shadow);
    }

/* =========================================================
   Fact Mode Card Size
========================================================= */

.game-board.mode-fact .memory-card,
.game-board.mode-fact .card-inner,
.game-board.mode-fact .player-card-back,
.game-board.mode-fact .clue-card-back {
    min-height: 178px;
}

.game-board.mode-fact .player-image,
.game-board.mode-fact .image-fallback {
    height: 138px;
}

/* =========================================================
   End Screen
========================================================= */

.end-screen {
    display: flex;
    justify-content: center;
}

.result-panel {
    width: min(620px, 100%);
}

.final-stat {
    position: relative;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(93, 17, 17, 0.18);
}

    .final-stat span {
        color: var(--pd-muted);
        font-weight: 900;
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }

    .final-stat strong {
        color: var(--pd-dark-red);
        text-align: right;
    }

.end-actions {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 18px;
}

/* =========================================================
   Leaderboard
========================================================= */

.leaderboard-panel {
    margin-top: 18px;
}

.leaderboard-header {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

    .leaderboard-header h2 {
        margin-bottom: 0;
    }

.leaderboard-list {
    position: relative;
    display: grid;
    gap: 8px;
}

.leaderboard-empty {
    padding: 14px;
    color: var(--pd-muted);
    background: rgba(255, 255, 255, 0.5);
    border: 1px dashed rgba(93, 17, 17, 0.3);
    border-radius: 10px;
    text-align: center;
}

.leaderboard-row {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.52);
    border: 1px solid rgba(93, 17, 17, 0.16);
    border-radius: 12px;
}

.leaderboard-rank {
    color: var(--pd-dark-red);
    font-size: 1.2rem;
    font-weight: 900;
}

.leaderboard-name {
    color: var(--pd-ink);
    font-weight: 900;
}

.leaderboard-meta {
    color: var(--pd-muted);
    font-size: 0.86rem;
}

.leaderboard-stats {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 6px;
}

    .leaderboard-stats span {
        display: inline-flex;
        align-items: center;
        padding: 5px 8px;
        color: #fff7e6;
        background: var(--pd-green);
        border-radius: 999px;
        font-size: 0.78rem;
        font-weight: 900;
    }

/* =========================================================
   Responsive
========================================================= */

@media (max-width: 900px) {
    .start-screen {
        grid-template-columns: 1fr;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .scoreboard {
        grid-template-columns: repeat(3, minmax(90px, 1fr));
    }

    .score-item.wide {
        grid-column: span 3;
    }

    .game-board {
        grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
        gap: 10px;
    }

    .memory-card,
    .card-inner,
    .player-card-back,
    .clue-card-back {
        min-height: 144px;
    }

    .player-image,
    .image-fallback {
        height: 108px;
    }
}

@media (max-width: 560px) {
    .hof-game-shell {
        width: min(100% - 14px, 1180px);
        padding-top: 10px;
    }

    .game-hero {
        padding: 18px 8px 10px;
    }

        .game-hero h1 {
            font-size: clamp(2rem, 13vw, 3.2rem);
        }

        .game-hero p {
            font-size: 0.98rem;
        }

    .panel {
        padding: 16px;
        border-radius: 14px;
    }

        .panel::before {
            inset: 6px;
        }

    .scoreboard {
        grid-template-columns: repeat(3, 1fr);
        gap: 7px;
    }

    .score-item {
        padding: 9px 6px;
        border-radius: 10px;
    }

        .score-item span {
            font-size: 0.66rem;
        }

        .score-item strong {
            font-size: 1rem;
        }

        .score-item.wide strong {
            font-size: 0.78rem;
        }

    .match-message {
        min-height: 38px;
        font-size: 0.82rem;
    }

    .game-board {
        grid-template-columns: repeat(3, 1fr);
        gap: 8px;
    }

    .memory-card,
    .card-inner,
    .player-card-back,
    .clue-card-back {
        min-height: 132px;
    }

    .game-board.mode-fact .memory-card,
    .game-board.mode-fact .card-inner,
    .game-board.mode-fact .player-card-back,
    .game-board.mode-fact .clue-card-back {
        min-height: 150px;
    }

    .game-board.mode-fact .player-image,
    .game-board.mode-fact .image-fallback {
        height: 110px;
    }

    .card-front {
        padding: 8px;
    }

    .card-logo {
        font-size: 0.58rem;
    }

    .card-title {
        font-size: 1.75rem;
    }

    .card-subtitle {
        font-size: 0.6rem;
    }

    .player-image,
    .image-fallback {
        height: 96px;
    }

    .player-name {
        min-height: 36px;
        padding: 5px 4px;
        font-size: 0.68rem;
    }

    .clue-card-back {
        padding: 8px;
    }

    .clue-label {
        font-size: 0.56rem;
        margin-bottom: 5px;
    }

    .clue-text {
        font-size: 0.68rem;
        line-height: 1.08;
    }

    .end-actions {
        grid-template-columns: 1fr;
    }

    .leaderboard-row {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .leaderboard-stats {
        grid-column: 1 / -1;
        justify-content: flex-start;
        padding-left: 54px;
    }
}

@media (max-width: 390px) {
    .game-board {
        grid-template-columns: repeat(2, 1fr);
    }
}
