@import url("https://fonts.googleapis.com/css2?family=Barlow:wght@400;600;700&display=swap");

:root {
    --color-bg: #f5efe8;
    --color-surface: #fff9f3;
    --color-board: #f3e4d1;
    --color-accent: #d96b2b;
    --color-accent-2: #004f6e;
    --color-text: #1f1f1f;
    --space-1: 0.5rem;
    --space-2: 1rem;
    --space-3: 1.5rem;
    --radius-1: 0.75rem;
}

body {
    font-family: "Barlow", sans-serif;
    color: var(--color-text);
    background-color: var(--color-bg);
    background-image: linear-gradient(rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.58)), url("../images/background-imgs/soybackground.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
}

body[data-theme="sneed"] {
    --color-bg: #f5efe8;
    --color-surface: #fff9f3;
    --color-board: #f3e4d1;
    --color-accent: #d96b2b;
    --color-accent-2: #004f6e;
    background-image: linear-gradient(rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.58)), url("../images/background-imgs/soybackground.png");
}

body[data-theme="downfall"] {
    --color-bg: #ecfff8;
    --color-surface: #ffffff;
    --color-board: #daf7eb;
    --color-accent: #0a7a58;
    --color-accent-2: #045f52;
    background-image: linear-gradient(rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0.52)), url("../images/background-imgs/soybackground2.png");
}

body[data-theme="prom"] {
    --color-bg: #ebebeb;
    --color-surface: #ffffff;
    --color-board: #d8d8d8;
    --color-accent: #1d1d1d;
    --color-accent-2: #454545;
    background-image: linear-gradient(rgba(255, 255, 255, 0.62), rgba(255, 255, 255, 0.62)), url("../images/background-imgs/prombackground.jpg");
}

body[data-theme="odyssey"] {
    --color-bg: #f1f6ff;
    --color-surface: #ffffff;
    --color-board: #dce9ff;
    --color-accent: #205ecf;
    --color-accent-2: #11317f;
    background-image: linear-gradient(rgba(255, 255, 255, 0.54), rgba(255, 255, 255, 0.54)), url("../images/background-imgs/soybackground3.png");
}

body[data-theme="ballroom"] {
    --color-bg: #fdf8f3;
    --color-surface: #fffdf9;
    --color-board: #f4e8d9;
    --color-accent: #7a4733;
    --color-accent-2: #4d2a1f;
    background-image: linear-gradient(rgba(255, 255, 255, 0.48), rgba(255, 255, 255, 0.48)), url("../images/background-imgs/ballroom.webp");
}

body[data-secret-theme="sneed"] {
    --color-bg: #e6ddc8;
    --color-surface: #fff7e9;
    --color-board: #e6cf9f;
    --color-accent: #815100;
    --color-accent-2: #4a2f00;
    background-image: linear-gradient(rgba(255, 255, 255, 0.35), rgba(255, 255, 255, 0.35)), url("../images/sneed-imgs/sneed.gif");
}

main .card {
    background-color: var(--color-surface);
}

.jak-identity-card {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    min-width: 330px;
    padding: 0.9rem 1.1rem;
    margin-left: calc(50% - 50vw);
    border: 1px solid #d7c5b3;
    border-left: 0;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: var(--radius-1);
    border-bottom-right-radius: var(--radius-1);
    background-color: var(--color-surface);
}

.jak-identity-card img {
    width: 96px;
    height: 96px;
    border-radius: 0.4rem;
    object-fit: cover;
}

.game-board {
    position: relative;
    width: min(100%, 700px);
    height: min(75vh, 620px);
    margin-inline: auto;
    border: 3px dashed var(--color-accent);
    border-radius: var(--radius-1);
    background: linear-gradient(145deg, var(--color-board), #ffffff);
    overflow: hidden;
}

.leaderboard-controls {
    width: min(100%, 700px);
    margin: 0 auto 1rem;
    display: flex;
    justify-content: center;
    gap: 0.65rem;
}

.navbar-music {
    margin-left: auto;
}

.navbar-music select {
    width: 220px;
}

.navbar-music input[type="range"] {
    width: 88px;
}

.feraljak-actor {
    position: absolute;
    width: auto;
    height: 156px;
    left: 0;
    top: 0;
    user-select: none;
    cursor: grab;
    filter: drop-shadow(0 6px 8px rgba(0, 0, 0, 0.2));
    transition: filter 160ms ease, transform 160ms ease;
}

.feraljak-actor:active {
    cursor: grabbing;
    transform: scale(1.02);
}

.controls-wrap > .btn + .btn {
    margin-left: var(--space-1);
}

input[required]:invalid:focus {
    border-color: #bb2d3b;
    box-shadow: 0 0 0 0.2rem rgba(187, 45, 59, 0.15);
}

.footer-links li + li::before {
    content: "|";
    margin-inline: 0.45rem;
    color: #777;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible {
    outline: 3px solid var(--color-accent-2);
    outline-offset: 2px;
}

@media (max-width: 992px) {
    .jak-identity-card {
        min-width: 280px;
        margin-left: calc(50% - 50vw);
    }

    .game-board {
        height: 58vh;
    }

    .navbar-music {
        margin-top: 0.6rem;
        width: 100%;
    }

    .navbar-music select {
        width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
    }
}
