/* ── Variables ───────────────────────────────────────────────────────────── */

:root {
    --bg: #EBF3FA;
    --header: #F5F9FD;
    --surface: #F5F9FD;
    --border: #B8CEE0;
    --border-dark: #87AECA;
    --text: #111827;
    --muted: #6B8FA8;
    --cell-empty: #D0E4F0;
    --cell-board: #F8FCFF;
    --cell-assigned: #C8E0F5;
    --cell-sel-bg: #D8EEFF;
    --accent: #5A9AC5;
    --accent-lt: #7BB5D8;
    --accent-dim: #A8CEEA;
    --blue: #6BAED6;
    --blue-lt: #88C2E3;
    --blue-dim: #C4DFF0;
    --font-head: 'Comfortaa', 'Nunito', sans-serif;
    --font: 'Nunito', 'Comic Sans MS', sans-serif;
}

/* ── Reset ───────────────────────────────────────────────────────────────── */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    background: var(--bg);
    background-image:
        radial-gradient(circle, rgba(107, 174, 214, 0.10) 1px, transparent 1px);
    background-size: 22px 22px;
    color: var(--text);
    font-family: var(--font);
    font-weight: 400;
    min-height: 100vh;
}

/* ── Section label + heading ─────────────────────────────────────────────── */

.section-label {
    font-size: 0.60rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--accent-lt);
    margin-bottom: 0.25rem;
    font-weight: 700;
}

h2 {
    font-family: var(--font-head);
    font-weight: 700;
    font-size: 1.2rem;
    margin-bottom: 1.5rem;
    border-bottom: 2px solid var(--border);
    padding-bottom: 0.6rem;
    color: var(--text);
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */

.action-btn {
    background: var(--accent);
    color: #fff;
    border: 2px solid var(--accent);
    border-top: none;
    border-radius: 0 0 10px 10px;
    padding: 0.75rem 1rem;
    font-family: var(--font-head);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.15s, box-shadow 0.15s;
    width: 100%;
    text-align: center;
}

.action-btn:hover:not(:disabled) {
    background: var(--accent-lt);
    border-color: var(--accent-lt);
    box-shadow: 0 4px 16px rgba(90, 154, 197, 0.35);
}

.action-btn:disabled {
    background: var(--border);
    border-color: var(--border);
    color: var(--muted);
    cursor: not-allowed;
}

/* ── Small copy / action button ──────────────────────────────────────────── */

.copy-btn {
    background: none;
    border: 1.5px solid var(--border);
    border-radius: 6px;
    padding: 0.1rem 0.5rem;
    height: 90%;
    font-family: var(--font);
    font-size: 0.55rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted);
    cursor: pointer;
    transition: border-color 0.12s, color 0.12s;
    white-space: nowrap;
    flex-shrink: 0;
}

.copy-btn:hover {
    border-color: var(--accent);
    color: var(--accent);
}

/* ── Shared monospace code display ───────────────────────────────────────── */

.order-code-display {
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--accent);
    letter-spacing: 0.06em;
}

/* ── Utility ─────────────────────────────────────────────────────────────── */

.hidden {
    display: none;
}