/* ===================================================
   DARTCOUNTER — Dark Theme
   =================================================== */

:root {
    --dc-bg:           #0c0c14;
    --dc-surface:      #121220;
    --dc-card:         #191927;
    --dc-card-hover:   #20202f;
    --dc-border:       #28283c;
    --dc-border-hi:    #3a3a55;

    --dc-gold:         #f0c030;
    --dc-gold-dim:     rgba(240,192,48,.12);
    --dc-gold-glow:    rgba(240,192,48,.28);
    --dc-red:          #e04848;
    --dc-red-dim:      rgba(224,72,72,.12);
    --dc-green:        #35c86c;
    --dc-green-dim:    rgba(53,200,108,.12);

    --dc-text:         #dde0ee;
    --dc-text-dim:     #9090b0;
    --dc-text-muted:   #5c5c78;

    --dc-font-head: 'Barlow Condensed', 'Arial Narrow', Arial, sans-serif;
    --dc-font-mono: 'Share Tech Mono', 'Courier New', monospace;
    --dc-font-body: system-ui, -apple-system, 'Segoe UI', sans-serif;

    --dc-radius:    10px;
    --dc-radius-sm: 6px;
    --dc-ease:      0.15s ease;
}

/* === RESET & BASE === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
    height: 100%;
    background: var(--dc-bg);
    color: var(--dc-text);
    font-family: var(--dc-font-body);
    -webkit-font-smoothing: antialiased;
    overscroll-behavior: none;
}

#app { min-height: 100vh; display: flex; flex-direction: column; }

/* Bootstrap dark overrides */
[data-bs-theme="dark"] {
    --bs-body-bg: var(--dc-bg);
    --bs-body-color: var(--dc-text);
}

/* === LOADING SCREEN === */
.dc-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    gap: 1.25rem;
    background: var(--dc-bg);
}

.dc-loading-target {
    font-size: 4.5rem;
    animation: dc-pulse 1.6s ease-in-out infinite;
}

.dc-loading-text {
    font-family: var(--dc-font-mono);
    font-size: 0.8rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--dc-text-muted);
}

@keyframes dc-pulse {
    0%, 100% { opacity: 1;   transform: scale(1);    }
    50%       { opacity: .45; transform: scale(.88);  }
}

/* === APP SHELL === */
.dc-app {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: var(--dc-bg);
}

.dc-header {
    display: flex;
    align-items: center;
    padding: 0 1.25rem;
    height: 3.25rem;
    background: var(--dc-surface);
    border-bottom: 1px solid var(--dc-border);
    position: sticky;
    top: 0;
    z-index: 100;
    flex-shrink: 0;
}

.dc-logo {
    font-family: var(--dc-font-head);
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--dc-gold);
    text-decoration: none;
}
.dc-logo:hover { opacity: .82; color: var(--dc-gold); }

.dc-main { flex: 1; display: flex; flex-direction: column; }

/* === HOME PAGE === */
.dc-home {
    width: 100%;
    max-width: 440px;
    margin: 0 auto;
    padding: 2rem 1.25rem 3.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.dc-hero {
    text-align: center;
    padding: 1rem 0 0.25rem;
}

.dc-dartboard-icon {
    font-size: 5.5rem;
    line-height: 1;
    display: block;
    margin-bottom: 0.875rem;
    filter: drop-shadow(0 0 24px rgba(240,192,48,.45));
}

.dc-title {
    font-family: var(--dc-font-head);
    font-size: 3rem;
    font-weight: 800;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--dc-text);
    line-height: 1;
    margin-bottom: .35rem;
}

.dc-subtitle {
    font-size: .875rem;
    color: var(--dc-text-muted);
    letter-spacing: .03em;
}

/* === LABELS === */
.dc-label {
    display: block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--dc-text-muted);
    margin-bottom: .45rem;
}

/* === INPUTS === */
.dc-input {
    width: 100%;
    background: var(--dc-card);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius-sm);
    color: var(--dc-text);
    font-family: var(--dc-font-body);
    font-size: 1rem;
    padding: .75rem 1rem;
    outline: none;
    transition: border-color var(--dc-ease), box-shadow var(--dc-ease);
}
.dc-input::placeholder { color: var(--dc-text-muted); }
.dc-input:focus {
    border-color: var(--dc-gold);
    box-shadow: 0 0 0 3px var(--dc-gold-dim);
}

.dc-input-code {
    font-family: var(--dc-font-mono);
    font-size: 1.3rem;
    letter-spacing: .28em;
    text-transform: uppercase;
    text-align: center;
    flex: 1;
    min-width: 0;
}

/* === BUTTONS === */
.dc-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: var(--dc-radius-sm);
    font-family: var(--dc-font-head);
    font-weight: 700;
    font-size: 1.05rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .8rem 1.5rem;
    cursor: pointer;
    transition: all var(--dc-ease);
    white-space: nowrap;
    text-decoration: none;
}
.dc-btn:disabled { opacity: .3; cursor: not-allowed; }

.dc-btn-primary {
    background: var(--dc-gold);
    color: #0a0800;
}
.dc-btn-primary:hover:not(:disabled) {
    background: #f8d448;
    box-shadow: 0 0 20px var(--dc-gold-glow);
}

.dc-btn-outline {
    background: transparent;
    color: var(--dc-gold);
    border: 1.5px solid var(--dc-gold);
}
.dc-btn-outline:hover:not(:disabled) { background: var(--dc-gold-dim); }

.dc-btn-success {
    background: var(--dc-green);
    color: #041408;
}
.dc-btn-success:hover:not(:disabled) {
    background: #48d880;
    box-shadow: 0 0 20px rgba(53,200,108,.3);
}

.dc-btn-full  { width: 100%; }

.dc-btn-icon {
    padding: .2rem .38rem;
    font-size: .65rem;
    line-height: 1;
    border-radius: 4px;
    background: var(--dc-surface);
    color: var(--dc-text-dim);
    border: 1px solid var(--dc-border);
    font-family: var(--dc-font-body);
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
}
.dc-btn-icon:hover:not(:disabled) {
    color: var(--dc-text);
    border-color: var(--dc-border-hi);
    background: var(--dc-card-hover);
}

/* === DIVIDER === */
.dc-divider {
    display: flex;
    align-items: center;
    gap: .875rem;
    color: var(--dc-text-muted);
    font-size: .75rem;
    letter-spacing: .08em;
}
.dc-divider::before, .dc-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--dc-border);
}

/* === JOIN ROW === */
.dc-join-row {
    display: flex;
    gap: .5rem;
    align-items: stretch;
}

/* === ERROR === */
.dc-error {
    background: var(--dc-red-dim);
    border: 1px solid rgba(224,72,72,.3);
    border-radius: var(--dc-radius-sm);
    color: #f08080;
    font-size: .875rem;
    padding: .6rem .875rem;
}

/* === CARDS === */
.dc-card {
    background: var(--dc-card);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius);
    padding: 1.125rem;
}

.dc-card-header {
    font-family: var(--dc-font-head);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--dc-text-muted);
    margin-bottom: .875rem;
}

/* === GAME CODE CARD === */
.dc-code-card {
    background: var(--dc-card);
    border: 1px solid rgba(240,192,48,.18);
    border-radius: var(--dc-radius);
    padding: 1.5rem 1.25rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.dc-code-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(240,192,48,.07), transparent);
    pointer-events: none;
}

.dc-code-label {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--dc-text-muted);
    margin-bottom: .625rem;
}

.dc-code-value {
    font-family: var(--dc-font-mono);
    font-size: 3rem;
    color: var(--dc-gold);
    letter-spacing: .32em;
    text-shadow: 0 0 24px var(--dc-gold-glow);
    line-height: 1;
    margin-bottom: .625rem;
    padding-left: .32em; /* compensate letter-spacing */
}

.dc-code-hint {
    font-size: .78rem;
    color: var(--dc-text-muted);
}

/* === SECTION TITLE === */
.dc-section-title {
    font-family: var(--dc-font-head);
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--dc-text-muted);
    margin-bottom: .5rem;
}

/* === PLAYER LIST === */
.dc-player-list {
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

.dc-player-row {
    display: flex;
    align-items: center;
    gap: .7rem;
    background: var(--dc-card);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius-sm);
    padding: .7rem .875rem;
    transition: border-color var(--dc-ease), background var(--dc-ease), box-shadow var(--dc-ease);
}
.dc-player-row[draggable="true"]        { cursor: grab; }
.dc-player-row[draggable="true"]:active { cursor: grabbing; }

.dc-player-row.drag-over {
    border-color: var(--dc-gold);
    background: var(--dc-card-hover);
    box-shadow: 0 0 0 2px var(--dc-gold-dim);
}

.dc-drag-handle {
    font-size: 1.05rem;
    color: var(--dc-text-muted);
    opacity: .4;
    flex-shrink: 0;
    line-height: 1;
    transition: opacity var(--dc-ease);
}
.dc-player-row:hover .dc-drag-handle { opacity: .85; }

.dc-player-rank {
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 50%;
    background: var(--dc-surface);
    border: 1px solid var(--dc-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--dc-font-mono);
    font-size: .72rem;
    color: var(--dc-text-dim);
    flex-shrink: 0;
}

.dc-player-name {
    flex: 1;
    font-size: .95rem;
    font-weight: 500;
    color: var(--dc-text);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dc-player-you {
    color: var(--dc-text-muted);
    font-size: .73rem;
    margin-left: .3rem;
    font-weight: 400;
}

.dc-badge-creator {
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--dc-gold);
    background: var(--dc-gold-dim);
    border: 1px solid rgba(240,192,48,.22);
    border-radius: 4px;
    padding: .15rem .45rem;
    flex-shrink: 0;
    white-space: nowrap;
}

.dc-arrow-btns {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex-shrink: 0;
}

/* === CONFIG === */
.dc-config-group { margin-bottom: .875rem; }

.dc-select {
    width: 100%;
    background: var(--dc-surface);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius-sm);
    color: var(--dc-text);
    font-size: .95rem;
    font-family: var(--dc-font-body);
    padding: .65rem .875rem;
    padding-right: 2.25rem;
    outline: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235c5c78' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .875rem center;
    cursor: pointer;
    transition: border-color var(--dc-ease);
}
.dc-select:focus {
    border-color: var(--dc-gold);
    box-shadow: 0 0 0 3px var(--dc-gold-dim);
}
.dc-select option { background: var(--dc-card); }

.dc-check-row {
    display: flex;
    align-items: center;
    gap: .625rem;
    padding: .425rem 0;
    cursor: pointer;
}
.dc-check-row input[type="checkbox"] {
    width: 1.05rem;
    height: 1.05rem;
    accent-color: var(--dc-gold);
    cursor: pointer;
    flex-shrink: 0;
}
.dc-check-label {
    font-size: .9rem;
    color: var(--dc-text);
    user-select: none;
}

/* === LOBBY PAGE === */
.dc-lobby {
    width: 100%;
    max-width: 440px;
    margin: 0 auto;
    padding: 1.25rem 1.25rem 3.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* === CONNECTION STATUS DOT === */
.dc-status-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
    transition: background var(--dc-ease), box-shadow var(--dc-ease);
}
.dc-status-dot.connected {
    background: var(--dc-green);
    box-shadow: 0 0 5px rgba(53,200,108,.5);
}
.dc-status-dot.disconnected {
    background: transparent;
    border: 1.5px solid var(--dc-red);
    opacity: .6;
}

/* === RECONNECTING BANNER === */
.dc-reconnecting {
    background: rgba(240,192,48,.08);
    border: 1px solid rgba(240,192,48,.25);
    border-radius: var(--dc-radius-sm);
    padding: .5rem .875rem;
    text-align: center;
    color: var(--dc-gold);
    font-size: .78rem;
    font-family: var(--dc-font-mono);
    letter-spacing: .06em;
    animation: dc-pulse 1.6s ease-in-out infinite;
}

/* === WAITING BANNER === */
.dc-waiting {
    background: var(--dc-card);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius-sm);
    padding: .875rem 1rem;
    text-align: center;
    color: var(--dc-text-muted);
    font-size: .875rem;
}

/* === SPINNER === */
.dc-spinner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 5rem 1rem;
    gap: 1.25rem;
    color: var(--dc-text-muted);
    font-family: var(--dc-font-mono);
    font-size: .82rem;
    letter-spacing: .1em;
}
.dc-spinner::before {
    content: '🎯';
    font-size: 3.5rem;
    animation: dc-pulse 1.6s ease-in-out infinite;
}

/* === NOT FOUND === */
.dc-not-found {
    text-align: center;
    padding: 5rem 1.25rem;
}
.dc-not-found h2 {
    font-family: var(--dc-font-head);
    font-size: 2rem;
    font-weight: 700;
    color: var(--dc-text-muted);
    margin-bottom: .75rem;
}

/* === ERROR UI === */
#blazor-error-ui {
    background: #14080a;
    border-top: 1px solid rgba(224,72,72,.5);
    color: #f08080;
    font-size: .875rem;
    padding: .7rem 1.25rem;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
    display: none;
}
#blazor-error-ui a        { color: #f0a0a0; }
#blazor-error-ui .dismiss { cursor: pointer; float: right; }

/* Hide default Blazor loading progress (replaced by custom) */
.loading-progress, .loading-progress-text { display: none !important; }

/* ===================================================
   X01 GAME VIEW
   =================================================== */

.dc-game {
    display: flex;
    flex-direction: column;
    gap: .75rem;
    padding: .75rem 1rem 320px; /* bottom padding for fixed keypad */
    max-width: 500px;
    margin: 0 auto;
}

.dc-game-header {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
}

.dc-game-mode {
    font-family: var(--dc-font-mono);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--dc-gold);
}

.dc-game-leg {
    font-size: .78rem;
    color: var(--dc-text-muted);
    font-family: var(--dc-font-mono);
    letter-spacing: .05em;
}

.dc-game-badge {
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: var(--dc-gold-dim);
    color: var(--dc-gold);
    border: 1px solid rgba(240,192,48,.22);
    border-radius: 4px;
    padding: .15rem .45rem;
}

/* === Player cards === */
.dc-players-area {
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

.dc-player-card {
    background: var(--dc-card);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius);
    padding: .875rem 1rem;
    transition: border-color var(--dc-ease), box-shadow var(--dc-ease);
    position: relative;
}

.dc-player-card.active {
    border-color: var(--dc-gold);
    box-shadow: 0 0 0 2px var(--dc-gold-dim);
}

.dc-player-card.me {
    border-color: var(--dc-border-hi);
}

.dc-player-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .4rem;
}

.dc-player-card-name {
    display: flex;
    align-items: center;
    gap: .3rem;
    font-size: .9rem;
    font-weight: 500;
    color: var(--dc-text);
}

.dc-leg-star {
    color: var(--dc-gold);
    font-size: .85rem;
}

.dc-you-tag {
    font-size: .7rem;
    color: var(--dc-text-muted);
    font-weight: 400;
}

.dc-player-legs {
    display: flex;
    gap: 4px;
    align-items: center;
}

.dc-leg-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 1.5px solid var(--dc-border-hi);
    background: transparent;
    transition: background var(--dc-ease), border-color var(--dc-ease);
}

.dc-leg-dot.won {
    background: var(--dc-gold);
    border-color: var(--dc-gold);
    box-shadow: 0 0 6px var(--dc-gold-glow);
}

.dc-player-score {
    font-family: var(--dc-font-mono);
    font-size: 2.8rem;
    font-weight: 700;
    color: var(--dc-text);
    line-height: 1;
    letter-spacing: -.02em;
}

.dc-player-card.active .dc-player-score {
    color: var(--dc-gold);
}

.dc-checkout-hint {
    font-family: var(--dc-font-mono);
    font-size: .72rem;
    color: var(--dc-green);
    letter-spacing: .06em;
    margin-top: .2rem;
}

.dc-current-indicator {
    font-size: .7rem;
    color: var(--dc-gold);
    font-family: var(--dc-font-mono);
    letter-spacing: .06em;
    margin-top: .35rem;
}

/* === History === */
.dc-history {
    background: var(--dc-card);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius);
    padding: .75rem;
}

.dc-history-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: .4rem;
}

.dc-history-row {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .78rem;
    padding: .2rem 0;
    border-bottom: 1px solid var(--dc-border);
}
.dc-history-row:last-child { border-bottom: none; }
.dc-history-row.bust { opacity: .5; }

.dc-history-player {
    flex: 1;
    color: var(--dc-text-dim);
    font-weight: 500;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dc-history-score {
    font-family: var(--dc-font-mono);
    color: var(--dc-text);
    font-weight: 600;
    min-width: 2.5rem;
    text-align: right;
}

.dc-bust-label {
    color: var(--dc-red);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .06em;
}

.dc-history-remaining {
    color: var(--dc-text-muted);
    font-family: var(--dc-font-mono);
    font-size: .7rem;
    min-width: 3rem;
    text-align: right;
}

/* === Spectator notice === */
.dc-spectator-notice {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 1rem;
    text-align: center;
    background: var(--dc-surface);
    border-top: 1px solid var(--dc-border);
    color: var(--dc-text-muted);
    font-size: .875rem;
    z-index: 200;
}

/* ===================================================
   NUMERIC KEYPAD
   =================================================== */

.dc-keypad-wrapper {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 200;
    background: var(--dc-surface);
    border-top: 1px solid var(--dc-border);
    padding: .5rem .75rem .75rem;
    max-width: 500px;
    left: 50%;
    transform: translateX(-50%);
}

.dc-keypad-msg {
    font-size: .8rem;
    text-align: center;
    padding: .35rem;
    border-radius: var(--dc-radius-sm);
    margin-bottom: .4rem;
}
.dc-keypad-msg.error {
    background: var(--dc-red-dim);
    color: #f08080;
    border: 1px solid rgba(224,72,72,.25);
}

.dc-keypad {
    display: flex;
    flex-direction: column;
    gap: .4rem;
}

.dc-keypad-display {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--dc-card);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius-sm);
    padding: .5rem .875rem;
    min-height: 3rem;
}

.dc-keypad-preview {
    font-family: var(--dc-font-mono);
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--dc-gold);
    letter-spacing: .05em;
    line-height: 1;
}

.dc-keypad-status {
    font-size: .72rem;
    color: var(--dc-text-muted);
    font-family: var(--dc-font-mono);
    text-align: right;
    max-width: 55%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.dc-keypad-status.error { color: #f08080; }

.dc-keypad-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .35rem;
}

.dc-key {
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: var(--dc-radius-sm);
    font-family: var(--dc-font-mono);
    font-weight: 700;
    font-size: 1.3rem;
    cursor: pointer;
    min-height: 58px;
    transition: all var(--dc-ease);
    user-select: none;
    -webkit-tap-highlight-color: transparent;
}
.dc-key:disabled { opacity: .35; cursor: not-allowed; }

.dc-key-digit {
    background: var(--dc-card);
    color: var(--dc-text);
    border: 1px solid var(--dc-border);
}
.dc-key-digit:active:not(:disabled) {
    background: var(--dc-card-hover);
    border-color: var(--dc-border-hi);
    transform: scale(.95);
}

.dc-key-del {
    background: var(--dc-surface);
    color: var(--dc-text-dim);
    border: 1px solid var(--dc-border);
    font-size: 1.1rem;
}
.dc-key-del:active:not(:disabled) { opacity: .7; transform: scale(.95); }

.dc-keypad-actions {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: .35rem;
}

.dc-key-bust {
    background: var(--dc-red-dim);
    color: var(--dc-red);
    border: 1.5px solid rgba(224,72,72,.35);
    font-family: var(--dc-font-head);
    font-size: 1rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    min-height: 56px;
}
.dc-key-bust:active:not(:disabled) { opacity: .7; transform: scale(.97); }

.dc-key-validate {
    background: var(--dc-green);
    color: #041408;
    font-family: var(--dc-font-head);
    font-size: 1.05rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    min-height: 56px;
}
.dc-key-validate:hover:not(:disabled) { background: #48d880; }
.dc-key-validate:active:not(:disabled) { transform: scale(.97); }
.dc-key-validate:disabled { background: var(--dc-card); color: var(--dc-text-muted); }

/* ===================================================
   GAME OVER SCREEN
   =================================================== */

.dc-gameover {
    max-width: 500px;
    margin: 0 auto;
    padding: 1.5rem 1rem 3rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.dc-gameover-header {
    text-align: center;
    padding: 1rem 0 .5rem;
}

.dc-gameover-icon {
    font-size: 4rem;
    display: block;
    margin-bottom: .5rem;
}

.dc-gameover-title {
    font-family: var(--dc-font-head);
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--dc-gold);
}

.dc-gameover-stats {
    display: flex;
    flex-direction: column;
    gap: .6rem;
}

.dc-stat-card {
    background: var(--dc-card);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius);
    padding: .875rem 1rem;
}

.dc-stat-card.winner {
    border-color: rgba(240,192,48,.4);
    background: linear-gradient(135deg, var(--dc-card), rgba(240,192,48,.04));
}

.dc-stat-name {
    font-size: 1rem;
    font-weight: 600;
    color: var(--dc-text);
    margin-bottom: .6rem;
}

.dc-stat-card.winner .dc-stat-name { color: var(--dc-gold); }

.dc-stat-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .2rem 0;
    border-bottom: 1px solid var(--dc-border);
}
.dc-stat-row:last-child { border-bottom: none; }

.dc-stat-label {
    font-size: .78rem;
    color: var(--dc-text-muted);
}

.dc-stat-value {
    font-family: var(--dc-font-mono);
    font-size: .88rem;
    color: var(--dc-text);
    font-weight: 600;
}

.dc-gameover-lobby {
    margin-top: .5rem;
}
