:root {
    --bg: #0f1224;
    --bg-2: #1b1f3a;
    --panel: #111827;
    --panel-2: #172033;
    --text: #f8fafc;
    --muted: #cbd5e1;
    --line: #f8fafc;
    --blue: #209cee;
    --green: #92cc41;
    --red: #e76e55;
    --yellow: #f7d51d;
    --shadow: rgba(0, 0, 0, .42);
}

* { box-sizing: border-box; }

html,
body,
pre,
code,
kbd,
samp,
button,
input,
select,
textarea {
    font-family: "Press Start 2P", system-ui, sans-serif;
}

body {
    margin: 0;
    color: var(--text);
    background:
        linear-gradient(rgba(255,255,255,.025) 2px, transparent 2px),
        linear-gradient(90deg, rgba(255,255,255,.025) 2px, transparent 2px),
        radial-gradient(circle at 20% 0, rgba(32,156,238,.25), transparent 32%),
        radial-gradient(circle at 88% 14%, rgba(146,204,65,.14), transparent 34%),
        linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
    background-size: 32px 32px, 32px 32px, auto, auto, auto;
    min-height: 100vh;
    font-size: 12px;
    line-height: 1.7;
}

a { color: #bde7ff; text-decoration: none; }
a:hover { color: white; text-decoration: underline; }

.hidden { display: none !important; }

h1, h2, h3, p { margin-top: 0; }
h1 { font-size: clamp(22px, 5vw, 42px); line-height: 1.12; }
h2 { font-size: 16px; }
label { display: block; margin: 12px 0 6px; color: var(--muted); }

.nes-container.is-dark,
.nes-container.is-rounded.is-dark {
    background-color: rgba(17, 24, 39, .92);
}

.nes-container.with-title > .title {
    color: var(--text);
    background-color: #111827;
    font-size: 13px;
}

.nes-input,
.nes-textarea,
.nes-select select {
    width: 100%;
    font-size: 11px;
}

.nes-select { width: 100%; }
.nes-btn { font-size: 11px; line-height: 1.45; }
.nes-btn:disabled { opacity: .5; cursor: not-allowed; }

.landing {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 18px;
}

.lobby-card {
    width: min(820px, 100%);
    box-shadow: 0 22px 0 rgba(0,0,0,.28), 0 36px 80px var(--shadow);
}

.brand {
    display: flex;
    gap: 18px;
    align-items: center;
    margin-bottom: 18px;
}

.brand h1 { margin: 0; }
.brand p { margin: 8px 0 0; color: var(--muted); }

.brand-mark {
    width: 74px;
    min-width: 74px;
    height: 74px;
    display: grid;
    place-items: center;
    color: #111827;
    background: var(--yellow) !important;
    text-shadow: 2px 2px white;
}

.panel,
.status-card {
    margin-top: 18px;
}

.panel.compact { max-width: 400px; margin: 0; }
.panel .nes-btn,
.status-card .nes-btn,
.button-link.nes-btn { width: 100%; margin-top: 12px; }

.subtle-panel { background-color: rgba(17, 24, 39, .78) !important; }
.small-note { color: var(--muted); font-size: 10px; line-height: 1.7; }
.message { min-height: 24px; margin-top: 12px; font-size: 10px; }
.success { color: var(--green); }
.error { color: var(--red); }

.form-inline {
    display: grid;
    grid-template-columns: minmax(170px, 240px) 1fr;
    gap: 16px;
    align-items: end;
    margin-top: 10px;
}

.button-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 12px;
}

.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    min-height: 58px;
    margin: 0;
    border-left: 0 !important;
    border-right: 0 !important;
    border-top: 0 !important;
    position: sticky;
    top: 0;
    z-index: 5;
    border-radius: 0 !important;
}

.topbar .badge {
    display: inline-flex;
    align-items: center;
    margin-left: 10px;
    padding: 4px 8px;
    color: #111827;
    background: var(--yellow);
    box-shadow: 3px 3px 0 #000;
    font-size: 9px;
}

/* Battle screen */
body.battle-page {
    min-height: 100vh;
    overflow: hidden;
}

.compact-topbar {
    min-height: 42px;
    padding: 8px 14px;
    font-size: 10px;
}

.turn-banner {
    position: sticky;
    top: 42px;
    z-index: 4;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    min-height: 58px;
    padding: 8px 14px;
    color: white;
    border-bottom: 4px solid #0a0a0a;
    box-shadow: 0 8px 0 rgba(0,0,0,.25);
    background: #7e3ff2;
}

.turn-banner.active-mine { background: #209cee; }
.turn-banner.active-enemy { background: #e76e55; }
.turn-banner.waiting,
.turn-banner.loading { background: #7e3ff2; }
.turn-banner.finished { background: #f7d51d; color: #111827; }
.turn-banner-main { min-width: 0; }
.turn-banner strong {
    display: block;
    font-size: clamp(13px, 2.1vw, 22px);
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.turn-kicker {
    display: inline-flex;
    margin-bottom: 2px;
    font-size: 8px;
    letter-spacing: .12em;
    text-transform: uppercase;
    opacity: .82;
}
.turn-banner-side {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    min-width: 270px;
}
.turn-meta {
    text-align: right;
    font-size: 9px;
    line-height: 1.35;
    max-width: 340px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.turn-end-btn,
button.turn-end-btn {
    width: auto;
    min-width: 112px;
    margin: 0;
    padding: 7px 10px;
}

.game-shell {
    display: grid;
    grid-template-columns: minmax(320px, auto) minmax(280px, 380px);
    gap: 18px;
    padding: 18px;
    justify-content: center;
    align-items: start;
}
.game-shell-wide {
    grid-template-columns: minmax(0, 1fr) 270px;
    gap: 10px;
    padding: 10px;
    justify-content: stretch;
    height: calc(100vh - 104px);
    overflow: hidden;
}

.board-wrap {
    position: relative;
    overflow: auto;
    max-width: calc(100vw - 440px);
    background: rgba(17,24,39,.94);
    border: 4px solid #f8fafc;
    outline: 4px solid #000;
    padding: 12px;
    box-shadow: 10px 10px 0 #000;
}
.board-wrap-wide {
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    padding: 8px;
}
canvas {
    display: block;
    width: auto;
    max-width: none;
    height: auto;
    image-rendering: pixelated;
    image-rendering: crisp-edges;
    background: #111827;
}

.sidebar { display: grid; gap: 10px; }
.compact-sidebar {
    gap: 8px;
    min-width: 0;
    overflow: auto;
    max-height: 100%;
}
.status-card { margin: 0; }
.compact-card,
.status-card.compact-card {
    padding: 14px 12px !important;
}
.compact-card h2,
.status-card.compact-card h2 { font-size: 10px; }
.compact-card p,
.compact-card div,
.compact-card li { font-size: 9px; }
#statusText,
#selectedInfo,
#playerFunds { color: var(--muted); line-height: 1.65; }
.inline-help { margin: 8px 0 0; }
.log-list {
    margin: 0;
    padding-left: 22px;
    max-height: 220px;
    overflow: auto;
    color: var(--muted);
}
.log-list li { margin-bottom: 6px; }
.compact-log { max-height: 210px; padding-left: 18px; }
.legend p { margin: 6px 0; color: var(--muted); }

.join-overlay {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    background: rgba(2,6,23,.72);
    backdrop-filter: blur(3px);
}

.canvas-message {
    position: absolute;
    left: 16px;
    bottom: 12px;
    z-index: 6;
    min-height: 0;
    max-width: min(560px, calc(100% - 32px));
    margin: 0;
    padding: 8px 10px;
    color: #fff;
    background: #e76e55;
    border: 4px solid white;
    outline: 3px solid #000;
    box-shadow: 5px 5px 0 #000;
    font-size: 9px;
    pointer-events: none;
}
.canvas-message:empty { display: none; }

.context-menu {
    position: fixed;
    z-index: 80;
    width: 252px;
    padding: 14px !important;
    max-height: min(82vh, 600px);
    overflow: auto;
    box-shadow: 8px 8px 0 #000;
}
.context-menu-title {
    margin-bottom: 8px;
    color: var(--yellow);
    font-size: 9px;
    text-transform: uppercase;
}
.context-menu-items { display: grid; gap: 8px; }
.context-action {
    width: 100%;
    margin: 0;
    text-align: left;
    white-space: normal;
}
.context-action small {
    display: block;
    margin-top: 4px;
    color: rgba(255,255,255,.78);
    font-size: 7px;
    line-height: 1.5;
}

.result-overlay {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: grid;
    place-items: center;
    padding: 20px;
    background: rgba(2,6,23,.78);
    backdrop-filter: blur(4px);
}
.result-card {
    width: min(560px, 100%);
    text-align: center;
    box-shadow: 12px 12px 0 #000;
    animation: result-pop .22s ease-out;
}
.result-card.victory { outline-color: var(--green); }
.result-card.defeat { outline-color: var(--red); }
.result-badge {
    display: inline-flex;
    padding: 6px 10px;
    color: #111827;
    background: var(--yellow);
    box-shadow: 4px 4px 0 #000;
    font-size: 8px;
    text-transform: uppercase;
}
.result-card h1 {
    margin: 18px 0 10px;
    font-size: clamp(28px, 8vw, 64px);
    line-height: 1.05;
}
.result-card p { color: var(--muted); }
.result-actions { max-width: 430px; margin: 18px auto 0; }

@keyframes result-pop {
    from { opacity: 0; transform: translateY(10px) scale(.97); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Editor */
.editor-shell {
    display: grid;
    grid-template-columns: minmax(320px, auto) minmax(330px, 440px);
    gap: 18px;
    padding: 18px;
    justify-content: center;
    align-items: start;
}
.editor-board { justify-self: end; }
.editor-sidebar { align-self: start; }
.tool-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}
.tool-grid .nes-btn { margin: 0; width: 100%; }
.map-size-row { align-items: end; }
textarea {
    resize: vertical;
    min-height: 96px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 11px;
    line-height: 1.45;
}

@media (max-width: 1100px) {
    body.battle-page { overflow: auto; }
    .game-shell-wide {
        grid-template-columns: 1fr;
        height: auto;
        overflow: visible;
    }
    .board-wrap-wide {
        max-width: 100%;
        min-height: 420px;
    }
    .compact-sidebar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        display: grid;
        max-height: none;
    }
}

@media (max-width: 960px) {
    .game-shell { grid-template-columns: 1fr; }
    .board-wrap { justify-self: center; width: 100%; max-width: 100%; }
    .editor-shell { grid-template-columns: 1fr; }
    .editor-board { justify-self: center; width: 100%; max-width: 100%; }
}

@media (max-width: 720px) {
    body { font-size: 11px; }
    .brand { align-items: flex-start; }
    .brand-mark { width: 58px; min-width: 58px; height: 58px; }
    .button-row,
    .form-inline { grid-template-columns: 1fr; }
    body.battle-page .turn-banner {
        top: 42px;
        flex-direction: column;
        align-items: stretch;
        min-height: 92px;
    }
    body.battle-page .turn-banner strong { white-space: normal; }
    .turn-banner-side {
        min-width: 0;
        justify-content: space-between;
    }
    .turn-meta { text-align: left; white-space: normal; }
    .game-shell-wide { height: auto; }
    .compact-sidebar { grid-template-columns: 1fr; }
}

/* v7 UI fixes */
.game-code-pill,
.topbar .game-code-pill {
    display: inline-flex;
    align-items: center;
    width: auto;
    min-width: max-content;
    max-width: none;
    margin-left: 10px;
    padding: 5px 10px;
    color: #111827;
    background: var(--yellow);
    border: 3px solid #fff;
    outline: 3px solid #000;
    box-shadow: 4px 4px 0 #000;
    font-size: 9px;
    line-height: 1.35;
    white-space: nowrap;
    overflow: visible;
    text-overflow: clip;
}

.topbar-links {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    flex-wrap: wrap;
}

.context-menu {
    position: fixed !important;
    transform: none !important;
    inset: auto auto auto auto;
    z-index: 9999;
}

.config-shell {
    display: grid;
    grid-template-columns: minmax(320px, 740px) minmax(320px, 1fr);
    gap: 18px;
    padding: 18px;
    align-items: start;
}

.config-card {
    margin: 0;
}

.config-actions {
    max-width: 620px;
}

.unit-config-rows {
    display: grid;
    gap: 12px;
    margin-top: 14px;
}

.unit-config-row {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr) minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    padding: 12px !important;
    background-color: rgba(15, 23, 42, .72) !important;
}

.unit-config-title strong {
    display: block;
    font-size: 10px;
}

.sprite-picker label {
    margin-top: 0;
    font-size: 9px;
}

.sprite-picker-inner {
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
}

.sprite-preview {
    width: 48px;
    height: 48px;
    image-rendering: pixelated;
    background: #243047;
    border: 3px solid #fff;
    outline: 3px solid #000;
}

.sprite-picker-controls {
    display: grid;
    gap: 8px;
}


.building-config-row {
    grid-template-columns: 140px repeat(3, minmax(0, 1fr));
}

.building-config-row .sprite-picker-inner {
    grid-template-columns: 52px minmax(0, 1fr);
}

.tiny-btn {
    width: 100%;
    margin: 0;
    padding: 5px 8px !important;
    font-size: 8px !important;
}

.active-picker .sprite-preview {
    box-shadow: 0 0 0 4px var(--yellow), 5px 5px 0 #000;
}

.tile-browser {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(74px, 1fr));
    gap: 8px;
    max-height: calc(100vh - 190px);
    overflow: auto;
    padding: 4px;
}

.tile-choice {
    display: grid;
    place-items: center;
    gap: 4px;
    min-height: 70px;
    color: var(--text);
    background: #243047;
    border: 3px solid #fff;
    outline: 3px solid #000;
    cursor: pointer;
}

.tile-choice:hover,
.tile-choice.active-tile {
    background: #384766;
    box-shadow: 4px 4px 0 #000;
}

.tile-choice.active-tile {
    border-color: var(--yellow);
}

.tile-choice img {
    width: 32px;
    height: 32px;
    image-rendering: pixelated;
}

.tile-choice span {
    font-size: 7px;
    line-height: 1;
}

@media (max-width: 1100px) {
    .config-shell {
        grid-template-columns: 1fr;
    }
    .tile-browser {
        max-height: 420px;
    }
}

@media (max-width: 780px) {
    .topbar {
        align-items: flex-start;
        gap: 10px;
    }
    .game-code-pill,
    .topbar .game-code-pill {
        margin-left: 0;
        margin-top: 6px;
        max-width: 100%;
    }
    .unit-config-row {
        grid-template-columns: 1fr;
    }
}

/* v8 websocket status */
.connection-pill,
.topbar .connection-pill {
    display: inline-flex;
    align-items: center;
    margin-left: 10px;
    padding: 5px 9px;
    color: #111827;
    background: #cbd5e1;
    border: 3px solid #fff;
    outline: 3px solid #000;
    box-shadow: 4px 4px 0 #000;
    font-size: 8px;
    line-height: 1.35;
    white-space: nowrap;
}
.connection-pill.is-live { background: var(--green); }
.connection-pill.is-connecting { background: var(--yellow); }
.connection-pill.is-polling { background: #cbd5e1; }

@media (max-width: 720px) {
    .connection-pill,
    .topbar .connection-pill {
        margin-left: 0;
        margin-top: 8px;
    }
    .compact-topbar > div:first-child {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        align-items: center;
    }
}

/* v9 account + persistent map pool */
.auth-card {
    width: min(560px, 100%);
    box-shadow: 0 22px 0 rgba(0,0,0,.28), 0 36px 80px var(--shadow);
}
.auth-form .nes-btn { width: 100%; margin-top: 16px; }
.auth-switch { margin-top: 18px; }
.lobby-card-wide { width: min(980px, 100%); }
.map-preview-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 16px;
    align-items: start;
    margin: 14px 0;
    padding: 12px;
    background: rgba(15, 23, 42, .72);
    border: 3px solid rgba(255,255,255,.26);
}
.map-preview-card canvas,
.admin-map-preview {
    image-rendering: pixelated;
    background: #111827;
    border: 3px solid #fff;
    outline: 3px solid #000;
    box-shadow: 5px 5px 0 #000;
}
#mapPreviewName {
    display: block;
    margin-bottom: 8px;
    color: var(--yellow);
    font-size: 12px;
}
.is-disabled,
.nes-btn.is-disabled {
    opacity: .55;
    pointer-events: none;
    filter: grayscale(1);
}
.admin-map-shell {
    display: grid;
    grid-template-columns: minmax(300px, 420px) minmax(300px, 420px);
    gap: 18px;
    padding: 18px;
    align-items: start;
}
.admin-map-card,
.admin-map-list-card { margin: 0; }
.admin-map-list-card { grid-column: 1 / -1; }
.admin-map-card .nes-btn { width: 100%; margin-top: 12px; }
.admin-map-list {
    display: grid;
    gap: 12px;
}
.admin-map-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) minmax(130px, 180px);
    gap: 16px;
    align-items: center;
    background: rgba(15, 23, 42, .72) !important;
}
.admin-map-item strong {
    display: block;
    margin-bottom: 6px;
    color: var(--yellow);
}
.admin-map-actions .nes-btn {
    width: 100%;
    margin: 0;
}

@media (max-width: 900px) {
    .admin-map-shell { grid-template-columns: 1fr; }
    .admin-map-item { grid-template-columns: 1fr; }
    .map-preview-card { grid-template-columns: 1fr; }
}

/* v10 usernames, timer and animation polish */
.turn-timer-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 88px;
    padding: 6px 9px;
    color: #111827;
    background: var(--green);
    border: 3px solid #fff;
    outline: 3px solid #000;
    box-shadow: 4px 4px 0 #000;
    font-size: 9px;
    line-height: 1.2;
    white-space: nowrap;
}
.turn-timer-pill.is-warning { background: var(--yellow); }
.turn-timer-pill.is-danger { background: var(--red); color: #fff; }
.auth-form .small-note { margin: 4px 0 10px; }
@media (max-width: 720px) {
    .turn-timer-pill { min-width: 74px; font-size: 8px; }
}

.combat-preview-box {
  margin-top: .7rem;
  padding: .55rem;
  border: 2px solid rgba(255,255,255,.28);
  background: rgba(15, 23, 42, .72);
  line-height: 1.55;
}

.damage-table-scroll {
  overflow: auto;
  max-width: 100%;
  border: 2px solid rgba(255,255,255,.2);
  background: rgba(0,0,0,.16);
  padding: .5rem;
}

.balance-table {
  border-collapse: separate;
  border-spacing: .35rem;
  min-width: 980px;
  font-size: .58rem;
}

.balance-table th {
  color: #fef3c7;
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
}

.balance-table td {
  text-align: center;
}

.balance-table .damage-input {
  width: 4.2rem;
  min-width: 4.2rem;
  text-align: center;
  padding: .35rem .2rem;
  font-size: .6rem;
}

.balance-actions {
  margin-top: 1rem;
}

/* v13 map pool and content-pack UI */
.admin-map-shell-wide {
    grid-template-columns: minmax(260px, 420px) minmax(260px, 420px) minmax(260px, 420px);
    align-items: start;
}
.admin-map-shell-wide .admin-map-list-card {
    grid-column: 1 / -1;
}
.admin-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.admin-filter-row {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(190px, 260px);
    gap: 12px;
    margin-bottom: 14px;
}
.admin-map-list-v13 {
    display: grid;
    gap: 12px;
}
.admin-map-item-v13 {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) minmax(160px, 220px);
    gap: 14px;
    align-items: start;
}
.admin-map-preview-v13 {
    background: #0f172a;
    border: 4px solid #f8fafc;
    image-rendering: pixelated;
}
.admin-map-title-line {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    margin-bottom: 6px;
}
.admin-map-actions-v13 {
    display: grid;
    gap: 8px;
}
.admin-map-actions-v13 .nes-btn {
    width: 100%;
    margin: 0;
}
.admin-meta-editor {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 4px solid rgba(248,250,252,.35);
}
.map-preview-card-large {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
}
.map-preview-card-large canvas {
    max-width: 280px;
    max-height: 280px;
    image-rendering: pixelated;
}
.map-badge-row {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin: 0 0 8px;
}
.map-pill {
    display: inline-flex;
    align-items: center;
    padding: 2px 6px;
    color: #111827;
    background: #cbd5e1;
    border: 2px solid #0a0a0a;
    box-shadow: 2px 2px 0 #000;
    font-size: 8px;
    line-height: 1.4;
    text-transform: uppercase;
}
.map-pill-featured { background: var(--yellow); }
.map-pill-public { background: var(--green); }
.map-pill-hidden { background: #94a3b8; }
.map-pill-tag { background: #bde7ff; }

@media (max-width: 1080px) {
    .admin-map-shell-wide { grid-template-columns: 1fr; }
    .admin-map-item-v13 { grid-template-columns: 1fr; }
    .admin-map-actions-v13 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 720px) {
    .admin-two-col,
    .admin-filter-row,
    .map-preview-card-large { grid-template-columns: 1fr; }
    .admin-map-actions-v13 { grid-template-columns: 1fr; }
}

/* v14 lobby, ready, profile and rematch UI */
.compact-check {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    margin: 10px 0 14px;
    font-size: .66rem;
}
.public-lobby-list {
    display: grid;
    gap: 10px;
    margin: 10px 0;
}
.public-lobby-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px !important;
}
.public-lobby-item .nes-btn {
    margin: 0;
    white-space: nowrap;
}
.turn-ready-btn {
    min-width: 92px;
}
.profile-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}
.profile-stats span,
.match-result {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 8px;
    background: #0f172a;
    border: 3px solid #f8fafc;
    box-shadow: 3px 3px 0 #000;
    font-size: .62rem;
}
.match-history-list {
    display: grid;
    gap: 10px;
}
.match-history-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 10px 0;
    border-bottom: 3px solid rgba(248,250,252,.25);
}
.match-result.win { background: #14532d; }
.match-result.loss { background: #7f1d1d; }
.match-result.neutral { background: #1e293b; }

@media (max-width: 720px) {
    .public-lobby-item,
    .match-history-item {
        grid-template-columns: 1fr;
    }
    .profile-stats {
        grid-template-columns: 1fr 1fr;
    }
}

/* v15 lobby lifecycle + dashboard layout */
.dashboard-page {
    place-items: start center;
    padding: 16px;
}

.lobby-dashboard {
    width: min(1360px, 100%);
    box-shadow: 0 20px 0 rgba(0,0,0,.28), 0 34px 70px var(--shadow);
}

.dashboard-hero {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
    margin-bottom: 14px;
}

.dashboard-brand { margin-bottom: 0; }

.dashboard-hero-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.dashboard-hero-actions .nes-btn { margin: 0; width: auto; }

.dashboard-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
    gap: 18px;
    align-items: start;
}

.dashboard-main,
.dashboard-sidebar {
    display: grid;
    gap: 16px;
}

.dashboard-main .panel,
.dashboard-sidebar .panel {
    margin-top: 0;
}

.dashboard-section-primary {
    min-height: 260px;
}

.dashboard-inline-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 12px;
}

.dashboard-inline-actions .nes-btn { width: auto; margin: 0; }

.create-lobby-grid {
    display: grid;
    grid-template-columns: minmax(240px, 330px) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.dashboard-map-preview {
    margin: 0;
    min-height: 292px;
}

.public-lobby-list {
    display: grid;
    gap: 10px;
}

.public-lobby-list-large {
    max-height: 360px;
    overflow: auto;
    padding-right: 4px;
}

.public-lobby-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    padding: 12px !important;
    background-color: rgba(15, 23, 42, .76) !important;
}

.public-lobby-item strong { color: var(--yellow); }
.public-lobby-item .nes-btn { width: auto; min-width: 84px; margin: 0; }
.public-lobby-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: wrap;
}

.lifecycle-notice {
    margin: 0 0 14px;
    color: #111827;
    background: var(--yellow) !important;
    font-size: 9px;
}

.my-game-list,
.sidebar-menu-list {
    display: grid;
    gap: 9px;
}

.my-game-item {
    display: grid;
    gap: 3px;
    padding: 10px;
    color: var(--text);
    background: rgba(15, 23, 42, .72);
    border: 3px solid #fff;
    outline: 3px solid #000;
    box-shadow: 4px 4px 0 #000;
}

.my-game-item:hover {
    color: #fff;
    background: rgba(32, 156, 238, .35);
    text-decoration: none;
}

.my-game-item strong {
    color: var(--yellow);
    font-size: 10px;
}

.my-game-item span,
.my-game-item small {
    font-size: 8px;
    line-height: 1.55;
    color: var(--muted);
}

.sidebar-menu-list .nes-btn {
    width: 100%;
    margin: 0;
}

.dashboard-footer-note {
    margin: 16px 0 0;
}

@media (max-width: 1180px) {
    .dashboard-grid,
    .create-lobby-grid {
        grid-template-columns: 1fr;
    }
    .dashboard-sidebar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 820px) {
    .dashboard-page { padding: 8px; }
    .dashboard-hero {
        align-items: flex-start;
        flex-direction: column;
    }
    .dashboard-hero-actions {
        justify-content: stretch;
        width: 100%;
    }
    .dashboard-hero-actions .nes-btn { width: 100%; }
    .dashboard-sidebar { grid-template-columns: 1fr; }
    .public-lobby-item { grid-template-columns: 1fr; }
    .public-lobby-item .nes-btn { width: 100%; }
    .public-lobby-actions { width: 100%; justify-content: stretch; }
}

/* v16 ranked matchmaking */
.ranked-panel {
    border-color: #f7d51d !important;
}

.ranked-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
}

.ranked-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.hidden {
    display: none !important;
}

.leaderboard-table-wrap {
    overflow-x: auto;
}

.leaderboard-table {
    width: 100%;
    min-width: 760px;
}

.leaderboard-table .is-current-user td {
    color: #f7d51d;
}

.rating-history-list {
    display: grid;
    gap: .5rem;
}

.rating-history-item {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: .75rem;
    align-items: center;
    padding: .55rem .65rem;
    border: 2px solid rgba(255,255,255,.22);
    background: rgba(0,0,0,.22);
}

.rating-gain {
    color: #92cc41;
}

.rating-loss {
    color: #e76e55;
}

@media (max-width: 760px) {
    .ranked-card,
    .rating-history-item {
        grid-template-columns: 1fr;
    }
    .ranked-actions {
        justify-content: stretch;
    }
    .ranked-actions .nes-btn {
        width: 100%;
    }
}

/* v17 clarity overlays */
.tile-hover-panel {
    position: absolute;
    right: 14px;
    top: 14px;
    z-index: 7;
    width: min(340px, calc(100% - 28px));
    padding: 10px 12px;
    color: #f8fafc;
    background: rgba(17, 24, 39, .92);
    border: 4px solid #fff;
    outline: 3px solid #000;
    box-shadow: 6px 6px 0 #000;
    font-size: 9px;
    line-height: 1.55;
    pointer-events: none;
}
.tile-hover-panel hr {
    border: 0;
    border-top: 2px solid rgba(255,255,255,.28);
    margin: 7px 0;
}
.hover-coords {
    float: right;
    color: var(--yellow);
}
.combat-preview-box.is-move {
    border-color: rgba(147,197,253,.7);
    background: rgba(30,64,175,.35);
}
.combat-preview-box.is-warning {
    border-color: rgba(247,213,29,.8);
    background: rgba(120,53,15,.42);
}
.help-overlay {
    position: fixed;
    inset: 0;
    z-index: 110;
    display: grid;
    place-items: center;
    padding: 18px;
    background: rgba(2,6,23,.78);
    backdrop-filter: blur(4px);
}
.help-card {
    width: min(760px, 100%);
    max-height: 88vh;
    overflow: auto;
    box-shadow: 10px 10px 0 #000;
}
.help-card p { color: var(--muted); font-size: 10px; }
.unit-codex-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 14px;
    margin-top: 16px;
}
.unit-codex-card {
    min-height: 240px;
}
.unit-codex-card h2 {
    font-size: 12px;
    color: var(--yellow);
}
.unit-codex-card p,
.unit-codex-card li {
    color: var(--muted);
    font-size: 9px;
    line-height: 1.65;
}
.unit-codex-card ul { padding-left: 18px; margin-bottom: 0; }
.codex-damage-table {
    width: 100%;
    min-width: 720px;
    border-collapse: separate;
    border-spacing: 6px;
    font-size: 8px;
}
.codex-damage-table th,
.codex-damage-table td {
    text-align: center;
    padding: 4px;
    background: rgba(15,23,42,.7);
}
.codex-damage-table th { color: var(--yellow); }
.codex-scroll { overflow: auto; margin-top: 16px; }
@media (max-width: 900px) {
    .tile-hover-panel { left: 14px; right: 14px; top: auto; bottom: 14px; width: auto; }
}

/* v18 lifecycle/admin polish */
.my-game-item-with-actions {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 8px;
}
.my-game-link {
    color: inherit;
    text-decoration: none;
    display: grid;
    gap: 4px;
}
.my-game-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    justify-content: flex-end;
}
.tiny-btn {
    font-size: 0.58rem !important;
    padding: 4px 6px !important;
}
.admin-match-page .brand { margin-bottom: 18px; }
.admin-match-list {
    display: grid;
    gap: 10px;
}
.admin-match-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px !important;
}
.admin-match-main {
    display: grid;
    gap: 4px;
}
.admin-match-actions {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
@media (max-width: 780px) {
    .my-game-item-with-actions,
    .admin-match-item {
        grid-template-columns: 1fr;
    }
    .my-game-actions,
    .admin-match-actions {
        justify-content: flex-start;
    }
}

/* v19 Replay / Action Log */
.replay-dashboard {
    max-width: 1380px;
}
.replay-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 18px;
    align-items: start;
}
.replay-board-panel {
    overflow: auto;
    max-height: calc(100vh - 220px);
    background: #111827;
}
#replayCanvas {
    display: block;
    image-rendering: pixelated;
    background: #101820;
    border: 4px solid #e5e7eb;
    min-width: 480px;
}
.replay-controls {
    position: sticky;
    top: 16px;
    max-height: calc(100vh - 170px);
    overflow: auto;
}
.replay-step-title {
    font-size: 0.72rem;
    line-height: 1.6;
    color: #fff;
    margin-bottom: 8px;
}
.replay-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 12px 0;
}
.replay-range {
    width: 100%;
    margin: 10px 0 6px;
    accent-color: #209cee;
}
.replay-timeline {
    display: grid;
    gap: 8px;
    margin-top: 12px;
}
.replay-timeline-item {
    text-align: left;
    color: #fff;
    background: rgba(255,255,255,0.08);
    border: 2px solid rgba(255,255,255,0.25);
    padding: 8px;
    cursor: pointer;
}
.replay-timeline-item.active {
    background: rgba(32,156,238,0.35);
    border-color: #209cee;
}
.replay-timeline-item strong,
.replay-timeline-item span {
    display: block;
}
.replay-timeline-item strong {
    font-size: 0.58rem;
    margin-bottom: 4px;
}
.replay-timeline-item span {
    font-size: 0.5rem;
    line-height: 1.5;
    opacity: 0.86;
}
.event-log-list {
    display: grid;
    gap: 12px;
}
.event-log-item {
    background: rgba(255,255,255,0.06);
    border: 2px solid rgba(255,255,255,0.18);
    padding: 12px;
}
.event-log-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}
.event-log-head strong {
    font-size: 0.65rem;
}
.event-log-head span,
.event-log-item p,
.event-log-item summary,
.event-log-item pre {
    font-size: 0.55rem;
    line-height: 1.7;
}
.event-log-item pre {
    white-space: pre-wrap;
    word-break: break-word;
    background: rgba(0,0,0,0.35);
    padding: 10px;
    margin-top: 8px;
    max-height: 320px;
    overflow: auto;
}
.match-history-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
}
.tiny-link {
    font-size: 0.52rem;
    color: #92cc41;
}
@media (max-width: 1100px) {
    .replay-layout {
        grid-template-columns: 1fr;
    }
    .replay-controls {
        position: static;
        max-height: none;
    }
}

/* v22 audio config */
.audio-volume-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: .75rem;
    margin: 1rem 0;
}

.audio-config-rows {
    display: grid;
    gap: .7rem;
}

.audio-config-row {
    display: grid;
    grid-template-columns: minmax(170px, 1fr) minmax(220px, 2fr) auto;
    gap: .75rem;
    align-items: center;
    padding: .65rem;
    border: 2px solid rgba(255,255,255,.18);
    background: rgba(15,23,42,.55);
}

@media (max-width: 780px) {
    .audio-config-row {
        grid-template-columns: 1fr;
    }
}

/* v27 CPU difficulty controls */
.bot-create-box {
    margin-top: 10px;
    padding: 10px;
    border: 2px solid rgba(255,255,255,.18);
    background: rgba(0,0,0,.18);
}
.bot-create-box .nes-select {
    margin-bottom: 8px;
}
.bot-create-box .nes-btn {
    width: 100%;
}

/* v30 achievements / profile medals */
.showcase-medal-row {
    display: grid;
    grid-template-columns: 140px minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
}
.showcase-medal-preview {
    min-height: 120px;
    display: grid;
    place-items: center;
    background: rgba(15, 23, 42, .55);
    border: 3px solid rgba(255,255,255,.18);
    padding: .5rem;
}
.showcase-medal-preview img {
    max-width: 92px;
    max-height: 112px;
    image-rendering: pixelated;
}
.showcase-medal-form {
    display: grid;
    gap: .55rem;
}
.achievement-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: .75rem;
}
.achievement-card {
    display: grid;
    grid-template-columns: 68px minmax(0, 1fr);
    gap: .65rem;
    align-items: center;
    padding: .65rem;
    border: 3px solid rgba(255,255,255,.16);
    background: rgba(15, 23, 42, .58);
}
.achievement-card img {
    width: 56px;
    max-height: 76px;
    object-fit: contain;
    image-rendering: pixelated;
    justify-self: center;
}
.achievement-card p {
    margin: .25rem 0;
    font-size: .62rem;
    line-height: 1.55;
}
.achievement-card small {
    color: #cbd5e1;
    font-size: .55rem;
}
.achievement-card.locked {
    opacity: .48;
    filter: grayscale(.8);
}
.achievement-card.unlocked {
    border-color: rgba(250, 204, 21, .72);
    box-shadow: 0 0 0 2px rgba(250, 204, 21, .18) inset;
}
.match-player-line {
    display: flex;
    align-items: center;
    gap: .55rem;
    margin: .35rem 0;
    line-height: 1.45;
}
.match-player-badge,
.match-player-badge-placeholder {
    width: 34px;
    height: 42px;
    flex: 0 0 34px;
    object-fit: contain;
    image-rendering: pixelated;
}
.match-player-badge-placeholder {
    border: 2px solid rgba(255,255,255,.15);
    background: rgba(255,255,255,.05);
}
@media (max-width: 760px) {
    .showcase-medal-row {
        grid-template-columns: 1fr;
    }
    .achievement-grid {
        grid-template-columns: 1fr;
    }
}

/* v30.2 lobby polish */
.ranked-panel {
    position: relative;
    overflow: hidden;
    transition: box-shadow .18s ease, transform .18s ease;
}

.ranked-panel.is-searching {
    border-color: #92cc41 !important;
    box-shadow: 0 0 0 4px rgba(146, 204, 65, .22), 0 0 28px rgba(146, 204, 65, .22);
}

.ranked-panel.is-searching::after {
    content: "SEARCHING";
    position: absolute;
    right: 16px;
    top: 12px;
    padding: 5px 9px;
    border: 3px solid #0a0a0a;
    background: #92cc41;
    color: #0a0a0a;
    font-size: .52rem;
    line-height: 1;
    animation: rankedPulse 1s steps(2, end) infinite;
    z-index: 2;
}

.ranked-status-text.is-searching {
    display: inline-block;
    padding: 8px 10px;
    margin-top: 6px;
    background: rgba(146, 204, 65, .14);
    border: 3px solid rgba(146, 204, 65, .75);
    color: #d9ffd0;
}

@keyframes rankedPulse {
    0%, 100% { opacity: 1; transform: translateY(0); }
    50% { opacity: .65; transform: translateY(-1px); }
}

/* v30.3 battle UI polish */
.turn-banner-main {
    display: grid;
    gap: 4px;
}
.turn-banner-players {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    min-height: 30px;
}
.turn-player-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 2px 7px 2px 4px;
    border: 2px solid rgba(255,255,255,.34);
    background: rgba(0,0,0,.22);
    color: #fff;
    font-size: 8px;
    line-height: 1.2;
    max-width: min(34vw, 260px);
}
.turn-player-chip.is-current {
    border-color: #f7d51d;
    box-shadow: 0 0 0 2px rgba(247,213,29,.22), 0 0 12px rgba(247,213,29,.34);
}
.turn-player-chip.is-me {
    background: rgba(0,0,0,.35);
}
.turn-player-chip span:last-child {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.turn-player-medal {
    width: 25px;
    height: 31px;
    flex: 0 0 25px;
}
.match-player-line {
    gap: .8rem;
    margin: .5rem 0 .7rem;
    padding: .35rem .3rem;
    border-bottom: 2px solid rgba(255,255,255,.1);
}
.match-player-line.is-active {
    background: rgba(247, 213, 29, .08);
    box-shadow: inset 4px 0 0 rgba(247, 213, 29, .85);
}
.match-player-line strong {
    color: #fff;
}
.match-player-line small {
    color: #f7d51d;
}
.match-player-badge-large {
    width: 58px;
    height: 70px;
    flex-basis: 58px;
}
.match-player-badge-placeholder.match-player-badge-large {
    width: 58px;
    height: 70px;
    flex-basis: 58px;
}
#playerFunds {
    line-height: 1.45;
}
@media (max-width: 720px) {
    .turn-banner-players {
        gap: 4px;
    }
    .turn-player-chip {
        max-width: 100%;
        font-size: 7px;
    }
    .match-player-badge-large,
    .match-player-badge-placeholder.match-player-badge-large {
        width: 48px;
        height: 58px;
        flex-basis: 48px;
    }
}

/* v30.4 turn banner player strip polish */
body.battle-page .turn-banner {
    gap: 12px;
    min-height: 52px;
    padding-top: 7px;
    padding-bottom: 7px;
}
body.battle-page .turn-banner-main {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    flex: 1 1 auto;
    flex-wrap: wrap;
}
body.battle-page .turn-kicker {
    margin: 0 2px 0 0;
    font-size: 7px;
    flex: 0 0 auto;
}
body.battle-page .turn-banner strong {
    display: inline-flex;
    align-items: center;
    flex: 0 1 auto;
    max-width: min(34vw, 420px);
    font-size: clamp(10px, 1.25vw, 15px);
    line-height: 1.15;
}
body.battle-page .turn-banner-players {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    min-height: 0;
    flex: 1 1 auto;
    flex-wrap: wrap;
}
body.battle-page .turn-player-chip {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    color: #fff;
    font-size: 10px;
    line-height: 1.15;
    max-width: min(24vw, 260px);
}
body.battle-page .turn-player-chip.is-current {
    border: 0;
    box-shadow: none;
    color: #fff6a5;
    text-shadow: 2px 2px 0 rgba(0,0,0,.55);
}
body.battle-page .turn-player-chip.is-me {
    background: transparent;
}
body.battle-page .turn-player-chip.is-current .turn-player-medal {
    filter: drop-shadow(0 0 6px rgba(247,213,29,.75));
}
body.battle-page .turn-player-medal {
    width: 34px;
    height: 42px;
    flex: 0 0 34px;
    object-fit: contain;
    image-rendering: pixelated;
}
body.battle-page .turn-banner-side {
    min-width: 240px;
}
@media (max-width: 960px) {
    body.battle-page .turn-banner strong {
        max-width: 100%;
    }
    body.battle-page .turn-banner-players {
        flex-basis: 100%;
        gap: 10px;
    }
}
@media (max-width: 720px) {
    body.battle-page .turn-banner-main {
        gap: 8px;
    }
    body.battle-page .turn-player-chip {
        font-size: 8px;
        max-width: calc(50vw - 20px);
    }
    body.battle-page .turn-player-medal {
        width: 28px;
        height: 35px;
        flex-basis: 28px;
    }
}

/* Invite based registration */
.invite-create-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.invite-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
}
.invite-link-field {
    font-size: 0.72rem;
}
.invite-table-wrap {
    overflow-x: auto;
}
.invite-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.68rem;
}
.invite-table th,
.invite-table td {
    border-bottom: 2px solid rgba(255,255,255,0.18);
    padding: 10px 8px;
    text-align: left;
    vertical-align: middle;
}
.invite-status {
    display: inline-block;
    padding: 3px 6px;
    border-radius: 4px;
    background: rgba(255,255,255,0.12);
}
.invite-status-active {
    color: #92ff9e;
}
.invite-status-revoked,
.invite-status-expired,
.invite-status-used_up {
    color: #ff8d8d;
}
.inline-form {
    display: inline;
}
