:root {
    --bg: #07111c;
    --bg-2: #0d1726;
    --panel: rgba(12, 20, 32, 0.88);
    --panel-2: rgba(18, 27, 43, 0.92);
    --panel-glass: rgba(12, 20, 32, 0.62);
    --border: rgba(154, 173, 201, 0.16);
    --border-strong: rgba(154, 173, 201, 0.28);
    --text: #edf3ff;
    --text-soft: #adc0dd;
    --text-dim: #7689a6;
    --accent: #7c8cff;
    --accent-2: #59d2ff;
    --success: #4fe0a5;
    --danger: #ff7272;
    --warning: #ffc56a;
    --shadow: 0 18px 48px rgba(0, 0, 0, 0.34);
    --radius: 22px;
    --radius-sm: 14px;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
    margin: 0;
    font-family: Inter, Outfit, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at top left, rgba(89, 210, 255, 0.12), transparent 30%),
        radial-gradient(circle at top right, rgba(124, 140, 255, 0.12), transparent 32%),
        linear-gradient(180deg, #09131f 0%, #060d18 100%);
}

a { color: inherit; text-decoration: none; }
code {
    font-family: "JetBrains Mono", "Fira Code", monospace;
    background: rgba(255,255,255,0.06);
    padding: 2px 7px;
    border-radius: 10px;
}

h1, h2, h3, p { margin: 0; }
small { color: var(--text-dim); }
label { display: grid; gap: 8px; font-size: 14px; color: var(--text-soft); }
input, select, textarea, button {
    font: inherit;
}
input, select, textarea {
    width: 100%;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: rgba(6, 12, 20, 0.7);
    color: var(--text);
    padding: 12px 14px;
    outline: none;
}
input:focus, select:focus, textarea:focus {
    border-color: rgba(124, 140, 255, 0.64);
    box-shadow: 0 0 0 4px rgba(124, 140, 255, 0.12);
}
textarea { resize: vertical; }
button {
    cursor: pointer;
    border: 0;
    border-radius: 14px;
    transition: transform .18s ease, opacity .18s ease, box-shadow .18s ease;
}
button:hover { transform: translateY(-1px); }
button:disabled { opacity: .45; cursor: default; transform: none; }

.btnPrimary, .btnGhost, .btnDanger {
    padding: 12px 16px;
    font-weight: 700;
    box-shadow: var(--shadow);
}
.btnPrimary {
    color: #fff;
    background: linear-gradient(135deg, var(--accent), #5e74ff 65%, var(--accent-2));
}
.btnGhost {
    color: var(--text);
    background: rgba(255,255,255,0.06);
    border: 1px solid var(--border);
}
.btnDanger {
    color: #fff;
    background: linear-gradient(135deg, #ff7c7c, #ff5f75);
}
.btnSmall, .btnMini {
    padding: 8px 10px;
    font-size: 13px;
    border-radius: 12px;
}

.stackLg { display: grid; gap: 24px; }
.stackMd { display: grid; gap: 16px; }
.stackSm { display: grid; gap: 10px; }

.pageAuth, .pageGame, .pageStream, .pageAdmin {
    padding: 24px;
}

.authShell, .gameShell, .streamShell, .adminShell {
    width: min(1600px, 100%);
    margin: 0 auto;
}
.authShell { display: grid; gap: 24px; }
.authGrid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.panelCard, .heroCard {
    border: 1px solid var(--border);
    background: var(--panel);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 24px;
    backdrop-filter: blur(18px);
}
.panelCard--glass {
    background: var(--panel-glass);
}
.heroCard--landing { padding: 30px; }
.heroText { color: var(--text-soft); line-height: 1.6; }
.eyebrow {
    text-transform: uppercase;
    letter-spacing: .16em;
    font-size: 11px;
    color: var(--accent-2);
    margin-bottom: 8px;
    font-weight: 700;
}
.heroBadges, .toolbarActions, .legendRow, .streamMeta, .splitMeta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.heroBadges span, .streamMeta span, .splitMeta span {
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.05);
    color: var(--text-soft);
    border-radius: 999px;
    padding: 8px 12px;
    font-size: 13px;
}
.toolbarRow {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
}
.toolbarRow--tight { align-items: flex-start; }
.hintText { color: var(--text-dim); font-size: 14px; line-height: 1.5; }

.roleBadge, .rarityBadge, .statusInline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 999px;
    padding: 7px 12px;
    font-size: 12px;
    font-weight: 700;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.05);
}
.roleBadge--admin { background: rgba(255,114,114,0.15); color: #ffc0c0; }
.roleBadge--moderator { background: rgba(255,197,106,0.16); color: #ffd79a; }
.roleBadge--player { background: rgba(89,210,255,0.12); color: #aeeaff; }
.statusInline--success { background: rgba(79,224,165,0.16); color: #aff7d7; }
.statusInline--danger { background: rgba(255,114,114,0.16); color: #ffc3c3; }

.gameHeroPanel {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 22px;
}
.heroStatsGrid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.heroStatsGrid--game { align-content: start; }
.heroStatCard, .statItem {
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 14px 16px;
    display: grid;
    gap: 6px;
}
.heroStatCard span, .statItem span { color: var(--text-dim); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.heroStatCard strong, .statItem strong { font-size: 20px; }

.announcementBar {
    display: none;
    border: 1px solid rgba(124,140,255,0.28);
    border-radius: 16px;
    padding: 12px 16px;
    background: linear-gradient(135deg, rgba(124,140,255,0.18), rgba(89,210,255,0.14));
    color: #eef3ff;
}
.announcementBar.isVisible { display: block; }
.announcementBar--landing { display: block; margin-top: 18px; }
.diagnosticsBar {
    display: none;
    border: 1px solid rgba(255,196,107,0.28);
    border-radius: 16px;
    padding: 10px 14px;
    background: linear-gradient(135deg, rgba(255,196,107,0.16), rgba(255,126,95,0.12));
    color: #fff2d6;
    font-size: 14px;
}
.diagnosticsBar.isVisible { display: block; }
.diagnosticsBar.isError {
    border-color: rgba(255,114,114,0.34);
    background: linear-gradient(135deg, rgba(255,114,114,0.18), rgba(123,31,65,0.18));
    color: #ffe1e1;
}

.gameGridV3 {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(330px, .7fr);
    gap: 24px;
    align-items: start;
}

canvas {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 18px;
    background: #050c15;
    border: 1px solid rgba(255,255,255,0.06);
}
.legendDot {
    width: 12px;
    height: 12px;
    display: inline-block;
    border-radius: 999px;
    margin-right: 8px;
}
.legendDot--player { background: #67d4ff; }
.legendDot--enemy { background: #ff8fa3; }
.legendDot--resource { background: #86efac; }
.legendDot--event { background: #ffbf69; }
.legendDot--boss { background: #ff7272; }
.legendDot--dead { background: #9ca3af; }

.controlsGrid {
    display: grid;
    gap: 12px;
}
.controlsGrid--movement { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.controlsGrid--actions { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.commandForm {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
}
.statusBox {
    border-radius: 16px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.05);
}
.statusBox.isError { border-color: rgba(255,114,114,0.34); color: #ffd0d0; }
.statusBox.isSuccess { border-color: rgba(79,224,165,0.24); color: #dffcf1; }

.infoCard, .bossPanel, .bossAdminCard, .streamBossPanel {
    display: grid;
    gap: 12px;
}
.onboardingCard {
    display: grid;
    gap: 12px;
}
.onboardingCard .toolbarActions {
    justify-content: flex-start;
}
.infoRow {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}
.infoRow:last-child { border-bottom: 0; }
.progressBar {
    height: 14px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.06);
}
.progressBar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #ff8d72, #ff5f75 70%, #ffca7a);
}
.emptyState, .inventoryEmpty {
    padding: 16px;
    border-radius: 16px;
    background: rgba(255,255,255,0.04);
    color: var(--text-soft);
    border: 1px dashed rgba(255,255,255,0.12);
}

.inventoryList, .equipmentList, .enemyList, .eventList, .leaderboardList, .logList, .listCompact {
    display: grid;
    gap: 12px;
}
.inventoryItem, .equipmentItem, .enemyItem, .eventItem, .leaderboardItem, .logItem, .eventAdminItem {
    border-radius: 18px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.04);
    padding: 14px;
}
.inventoryItem, .enemyItem, .eventItem, .leaderboardItem {
    display: flex;
    justify-content: space-between;
    gap: 14px;
}
.inventoryMain, .equipmentItem, .enemyMain, .eventMain { display: grid; gap: 8px; }
.inventorySide { display: grid; gap: 10px; align-content: start; justify-items: end; }
.inventoryQty {
    min-width: 46px;
    text-align: center;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.08);
}
.itemMeta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.itemMeta span {
    padding: 5px 9px;
    border-radius: 999px;
    background: rgba(255,255,255,0.06);
    font-size: 12px;
    color: var(--text-soft);
}
.equipmentHead, .inventoryTitleRow {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
}
.equipmentSlot { color: var(--text-dim); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.isEmpty { opacity: .75; }

.rarity--common { border-color: rgba(255,255,255,0.08); }
.rarity--uncommon { border-color: rgba(79,224,165,0.34); }
.rarity--rare { border-color: rgba(89,210,255,0.36); }
.rarity--epic { border-color: rgba(171,104,255,0.36); }
.rarity--legendary { border-color: rgba(255,197,106,0.42); }
.rarityBadge--common { color: #d6deec; }
.rarityBadge--uncommon { color: #baf5db; }
.rarityBadge--rare { color: #b4ebff; }
.rarityBadge--epic { color: #e2c4ff; }
.rarityBadge--legendary { color: #ffe1a3; }

.logItem small { display: block; margin-top: 6px; }

.streamHeader, .streamStage, .streamMeta--v3, .streamSidebar {
    display: grid;
    gap: 18px;
}
.streamHeader--v3 {
    grid-template-columns: 1fr auto;
    align-items: end;
    margin-bottom: 18px;
}
.streamBossPanel {
    min-height: 0;
    margin-bottom: 18px;
    border: 1px solid rgba(255,114,114,0.25);
    border-radius: var(--radius);
    padding: 18px 20px;
    background: linear-gradient(135deg, rgba(255,114,114,0.16), rgba(255,95,117,0.1));
}
.streamStage--v3 {
    grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr);
    align-items: start;
}
.streamMapWrap { padding: 16px; }
.streamSidebar .panelCard { padding: 18px; }

.adminShell--rich { display: grid; gap: 24px; }
.heroPanel__content {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: start;
}
.adminGrid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
    gap: 24px;
}
.adminActionGrid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.settingsGrid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.switchRow {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
}
.switchRow input { width: auto; }
.tableWrap { overflow: auto; }
.adminTable {
    width: 100%;
    border-collapse: collapse;
    min-width: 980px;
}
.adminTable th, .adminTable td {
    vertical-align: top;
    text-align: left;
    padding: 14px 12px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.adminTable th { color: var(--text-dim); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.inlineForm { display: flex; flex-wrap: wrap; gap: 8px; }
.inlineForm--stack { display: grid; gap: 8px; }
.inlineForm--compact { margin-top: 10px; }
.listCompact__item, .eventAdminItem {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
}

@media (max-width: 1200px) {
    .gameGridV3, .streamStage--v3, .adminGrid, .gameHeroPanel, .authGrid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    body { padding: 12px; }
    .panelCard, .heroCard { padding: 18px; }
    .heroPanel__content, .toolbarRow, .commandForm { grid-template-columns: 1fr; display: grid; }
    .heroStatsGrid, .controlsGrid--actions, .controlsGrid--movement, .settingsGrid, .adminActionGrid {
        grid-template-columns: 1fr;
    }
}

/* ===== v1.6 layout bez scrollování stránky ===== */
html, body { height: 100%; }
body.pageGame--v4 {
    height: 100vh;
    overflow: hidden;
}

.gameShell--v4 {
    width: min(1760px, 100%);
    height: calc(100vh - 48px);
    margin: 0 auto;
    display: grid;
    gap: 16px;
    grid-template-rows: auto auto minmax(0, 1fr);
}

.gameTopbarV4 {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(520px, .85fr);
    gap: 18px;
    padding: 20px 22px;
}
.gameTopbarV4__titleRow {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}
.gameTopbarV4__main { display: grid; gap: 10px; }
.gameTopbarV4__stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    align-content: start;
}
.toolbarActions--compact { justify-content: flex-end; }

.gameLayoutV4 {
    min-height: 0;
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(420px, .85fr);
    gap: 16px;
}
.gameMainV4,
.gameSidebarV4 {
    min-height: 0;
    display: grid;
    gap: 16px;
}
.gameMainV4 {
    grid-template-rows: minmax(0, 1fr) auto;
}
.gameSidebarV4 {
    grid-template-rows: auto auto minmax(210px, .75fr) minmax(220px, .9fr);
}
.mapPanelV4,
.controlsPanelV4,
.sidebarCardV4,
.panelCard--boss {
    min-height: 0;
}
.mapPanelV4 { display: grid; gap: 12px; }
.mapPanelV4 canvas {
    width: 100%;
    height: min(54vh, 620px);
    max-height: 100%;
}
.controlsPanelV4 { padding-top: 18px; }
.controlsGrid--actionsCompact { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.sidebarCardV4 { display: grid; gap: 10px; }
.sidebarCardV4--scroll { grid-template-rows: auto minmax(0, 1fr); overflow: hidden; }
.sidebarCardV4--split {
    min-height: 0;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.sidebarSplitColumn { min-height: 0; display: grid; gap: 10px; }
.compactScroll {
    min-height: 0;
    overflow: auto;
    padding-right: 4px;
}
.sidebarDivider {
    height: 1px;
    background: rgba(255,255,255,0.06);
    margin: 2px 0;
}
.questList, .achievementList, .titleList {
    display: grid;
    gap: 10px;
}
.questItem, .achievementItem, .titleItem {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.04);
}
.questItem.isComplete,
.achievementItem.isUnlocked,
.titleItem.isActive {
    border-color: rgba(79,224,165,0.28);
    background: rgba(79,224,165,0.08);
}
.questItem__main,
.achievementItem__main,
.titleItem__main { display: grid; gap: 8px; }
.progressBar--thin { height: 10px; }
.panelCard--boss { overflow: hidden; }

.modalOverlay {
    position: fixed;
    inset: 0;
    background: rgba(3, 8, 14, 0.74);
    backdrop-filter: blur(12px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    z-index: 1000;
}
.modalOverlay.isOpen { display: flex; }
.modalCard {
    width: min(1500px, 100%);
    max-height: calc(100vh - 48px);
    border-radius: 28px;
    border: 1px solid var(--border-strong);
    background: rgba(8, 14, 24, 0.96);
    box-shadow: 0 28px 70px rgba(0,0,0,0.45);
    padding: 22px;
    display: grid;
    gap: 18px;
}
.modalCard--inventory { width: min(1450px, 100%); }
.modalCard--progress { width: min(1600px, 100%); }
.modalBody {
    min-height: 0;
    display: grid;
    gap: 16px;
}
.modalBody--inventory {
    grid-template-columns: minmax(320px, .7fr) minmax(0, 1.3fr);
}
.modalBody--progress {
    grid-template-columns: minmax(280px, .68fr) minmax(0, 1fr) minmax(0, 1fr);
}
.modalSection {
    min-height: 0;
    display: grid;
    gap: 12px;
}
.modalSection--scroll {
    min-height: 0;
    overflow: auto;
    padding-right: 6px;
}
.profileStatsGrid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.pageAdmin .adminShell--rich { width: min(1820px, 100%); }
.adminPlayerMeta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
}
.adminSearchBar {
    display: grid;
    grid-template-columns: minmax(280px, 420px) auto;
    gap: 12px;
    align-items: center;
}
.tableWrap { max-height: 52vh; overflow: auto; }
.adminTable--wide td, .adminTable--wide th { vertical-align: top; }
.inlineForm--stack textarea { min-height: 78px; }
.mutedBadge { background: rgba(255,197,106,0.16); color: #ffd79a; }
.bannedBadge { background: rgba(255,114,114,0.16); color: #ffc3c3; }

@media (max-width: 1400px) {
    .gameTopbarV4,
    .gameLayoutV4,
    .modalBody--progress,
    .modalBody--inventory,
    .sidebarCardV4--split {
        grid-template-columns: 1fr;
    }
    .gameShell--v4 {
        height: auto;
        min-height: calc(100vh - 48px);
    }
    body.pageGame--v4 { overflow: auto; }
    .mapPanelV4 canvas { height: auto; }
    .gameSidebarV4 { grid-template-rows: none; }
}

/* ===== v1.7 ekonomika, crafting a fullscreen stream ===== */
.modalCard--crafting { width: min(1600px, 100%); }
.modalBody--crafting {
    grid-template-columns: minmax(340px, .72fr) minmax(0, 1.28fr);
}
.craftingList {
    display: grid;
    gap: 12px;
}
.craftRecipeItem {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding: 14px;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.04);
}
.craftRecipeItem__main {
    display: grid;
    gap: 8px;
}
.itemMeta--recipe .isMissing {
    border-color: rgba(255,114,114,0.26);
    color: #ffc2c2;
    background: rgba(255,114,114,0.10);
}

body.pageStream--fullscreen {
    padding: 0;
    margin: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    background: #02070f;
}
.streamFullscreenShell {
    position: relative;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(89,210,255,0.10), transparent 28%),
        radial-gradient(circle at top right, rgba(124,140,255,0.10), transparent 32%),
        linear-gradient(180deg, rgba(2,7,15,1) 0%, rgba(2,7,15,1) 100%);
}
.streamMapCanvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
}
.streamHud {
    position: absolute;
    z-index: 5;
    display: grid;
    gap: 14px;
}
.streamHud--topLeft {
    top: 18px;
    left: 18px;
    width: min(560px, calc(100vw - 36px));
}
.streamHud--topRight {
    top: 18px;
    right: 18px;
    width: min(520px, calc(100vw - 36px));
}
.streamHud--bottomLeft {
    left: 18px;
    bottom: 18px;
    width: min(520px, calc(100vw - 36px));
}
.streamHud--bottomRight {
    right: 18px;
    bottom: 18px;
    width: min(440px, calc(100vw - 36px));
}
.streamOverlayCard {
    padding: 16px 18px;
    backdrop-filter: blur(16px);
    background: rgba(7, 14, 24, 0.72);
}
.streamBrandCard h1 {
    font-size: clamp(24px, 2vw, 36px);
    line-height: 1.05;
}
.streamMeta--tight {
    margin-top: 10px;
}
.streamSummaryCards {
    margin-top: 14px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}
.streamSummaryCard {
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.05);
    padding: 10px 12px;
    display: grid;
    gap: 5px;
}
.streamSummaryCard span {
    color: var(--text-dim);
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.streamSummaryCard strong {
    font-size: 18px;
}
.streamBossPanel--overlay {
    margin: 0;
    padding: 16px 18px;
    background: linear-gradient(135deg, rgba(255,114,114,0.24), rgba(255,95,117,0.14));
    backdrop-filter: blur(18px);
}
.announcementBar--overlay {
    margin: 0;
    background: linear-gradient(135deg, rgba(124,140,255,0.26), rgba(89,210,255,0.18));
    backdrop-filter: blur(16px);
}
.diagnosticsBar--stream {
    margin: 0;
    backdrop-filter: blur(16px);
}
.streamList {
    max-height: min(34vh, 360px);
    overflow: auto;
    padding-right: 4px;
}
.streamList--events {
    max-height: min(28vh, 300px);
}
.eventItem--stream {
    align-items: center;
}

@media (max-width: 1200px) {
    .modalBody--crafting {
        grid-template-columns: 1fr;
    }
    .streamHud--topLeft,
    .streamHud--topRight,
    .streamHud--bottomLeft,
    .streamHud--bottomRight {
        position: static;
        width: auto;
    }
    body.pageStream--fullscreen {
        overflow: auto;
    }
    .streamFullscreenShell {
        min-height: 100vh;
        height: auto;
        display: grid;
        gap: 16px;
        padding: 16px;
    }
    .streamMapCanvas {
        position: relative;
        aspect-ratio: 16 / 9;
        height: auto;
    }
}

/* ===== v1.9 UI refresh: modals, tooltips, scroll, buttons, inventory ===== */
:root {
    --bg: #081018;
    --bg-2: #101a25;
    --panel: color-mix(in srgb, #122033 84%, transparent);
    --panel-2: color-mix(in srgb, #18283c 92%, transparent);
    --panel-glass: rgba(14, 24, 36, 0.72);
    --panel-strong: rgba(11, 18, 29, 0.96);
    --border: rgba(150, 190, 228, 0.15);
    --border-strong: rgba(164, 209, 241, 0.32);
    --text: #eef6ff;
    --text-soft: #c2d3ea;
    --text-dim: #8397b1;
    --accent: #63c4ff;
    --accent-2: #ff9966;
    --accent-3: #8ce6c2;
    --success: #6bf0be;
    --danger: #ff7e7c;
    --warning: #ffcf7b;
    --shadow: 0 26px 70px rgba(0, 0, 0, 0.36);
    --shadow-soft: 0 16px 40px rgba(0, 0, 0, 0.22);
    --glow-accent: 0 0 0 1px rgba(99, 196, 255, 0.24), 0 18px 44px rgba(26, 74, 122, 0.24);
    --radius: 24px;
    --radius-sm: 16px;
}

body {
    font-family: "Segoe UI Variable Display", "Aptos", "Trebuchet MS", sans-serif;
    background:
        radial-gradient(circle at 12% 14%, rgba(99, 196, 255, 0.16), transparent 24%),
        radial-gradient(circle at 88% 10%, rgba(255, 153, 102, 0.14), transparent 22%),
        radial-gradient(circle at 50% 100%, rgba(140, 230, 194, 0.08), transparent 28%),
        linear-gradient(180deg, #081019 0%, #050b13 100%);
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    opacity: 0.42;
    background-image:
        linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
    background-size: 32px 32px;
    mask-image: radial-gradient(circle at center, black 48%, transparent 88%);
}

::selection {
    background: rgba(99, 196, 255, 0.28);
    color: #ffffff;
}

input,
select,
textarea {
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02)),
        rgba(6, 11, 18, 0.82);
    border-color: rgba(160, 196, 228, 0.14);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

input:hover,
select:hover,
textarea:hover {
    border-color: rgba(164, 209, 241, 0.24);
}

input:focus,
select:focus,
textarea:focus {
    border-color: rgba(99, 196, 255, 0.7);
    box-shadow: 0 0 0 4px rgba(99, 196, 255, 0.12), inset 0 1px 0 rgba(255,255,255,0.06);
}

button,
.btnPrimary,
.btnGhost,
.btnDanger {
    position: relative;
    overflow: hidden;
}

.btnPrimary,
.btnGhost,
.btnDanger {
    border-radius: 16px;
    letter-spacing: 0.01em;
    box-shadow: var(--shadow-soft);
}

.btnPrimary::before,
.btnGhost::before,
.btnDanger::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    pointer-events: none;
    opacity: 0.65;
}

.btnPrimary {
    background:
        linear-gradient(135deg, rgba(255,255,255,0.16), transparent 42%),
        linear-gradient(135deg, #4ab8ff 0%, #5fc0ff 34%, #ff9966 100%);
    color: #fdfefe;
    box-shadow: 0 18px 34px rgba(46, 119, 177, 0.34);
}

.btnPrimary::before {
    border: 1px solid rgba(255,255,255,0.18);
}

.btnGhost {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.085), rgba(255,255,255,0.025)),
        rgba(15, 23, 34, 0.88);
    border: 1px solid rgba(173, 202, 232, 0.15);
}

.btnDanger {
    background:
        linear-gradient(135deg, rgba(255,255,255,0.12), transparent 46%),
        linear-gradient(135deg, #ff8d86 0%, #ff6b77 62%, #e04357 100%);
    box-shadow: 0 18px 36px rgba(169, 54, 76, 0.32);
}

.btnSmall,
.btnMini {
    font-weight: 700;
    border-radius: 13px;
}

button:hover,
.btnPrimary:hover,
.btnGhost:hover,
.btnDanger:hover {
    transform: translateY(-2px);
    filter: saturate(1.04);
}

button:active,
.btnPrimary:active,
.btnGhost:active,
.btnDanger:active {
    transform: translateY(0);
}

.panelCard,
.heroCard {
    position: relative;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015)),
        var(--panel);
    border-color: rgba(160, 200, 236, 0.13);
    box-shadow: var(--shadow);
}

.panelCard::before,
.heroCard::before,
.modalCard::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    background:
        linear-gradient(140deg, rgba(255,255,255,0.08), transparent 24%),
        linear-gradient(320deg, rgba(255,255,255,0.03), transparent 18%);
    opacity: 0.7;
}

.heroStatCard,
.statItem,
.inventoryItem,
.equipmentItem,
.enemyItem,
.eventItem,
.leaderboardItem,
.logItem,
.questItem,
.achievementItem,
.titleItem,
.craftRecipeItem,
.streamSummaryCard,
.listCompact__item,
.eventAdminItem {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.015)),
        rgba(8, 14, 22, 0.78);
    border-color: rgba(170, 206, 236, 0.14);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.heroStatCard:hover,
.inventoryItem:hover,
.equipmentItem:hover,
.enemyItem:hover,
.eventItem:hover,
.questItem:hover,
.achievementItem:hover,
.titleItem:hover,
.craftRecipeItem:hover,
.leaderboardItem:hover {
    border-color: rgba(164, 209, 241, 0.24);
    transform: translateY(-1px);
}

.toolbarActions {
    align-items: center;
}

.toolbarActions--compact,
.cardActions {
    gap: 8px;
}

.cardActions > .btnMini,
.cardActions > .btnSmall,
.questItem .inventorySide > .btnMini,
.achievementItem .inventorySide > .btnMini,
.titleItem .inventorySide > .btnMini {
    width: 100%;
    justify-content: center;
}

.compactScroll,
.modalSection--scroll,
.tableWrap,
.streamList,
.authGrid,
textarea {
    scrollbar-width: thin;
    scrollbar-color: rgba(99, 196, 255, 0.55) rgba(255,255,255,0.05);
}

.compactScroll::-webkit-scrollbar,
.modalSection--scroll::-webkit-scrollbar,
.tableWrap::-webkit-scrollbar,
.streamList::-webkit-scrollbar,
textarea::-webkit-scrollbar {
    width: 11px;
    height: 11px;
}

.compactScroll::-webkit-scrollbar-track,
.modalSection--scroll::-webkit-scrollbar-track,
.tableWrap::-webkit-scrollbar-track,
.streamList::-webkit-scrollbar-track,
textarea::-webkit-scrollbar-track {
    background: rgba(255,255,255,0.04);
    border-radius: 999px;
}

.compactScroll::-webkit-scrollbar-thumb,
.modalSection--scroll::-webkit-scrollbar-thumb,
.tableWrap::-webkit-scrollbar-thumb,
.streamList::-webkit-scrollbar-thumb,
textarea::-webkit-scrollbar-thumb {
    border-radius: 999px;
    border: 2px solid transparent;
    background:
        linear-gradient(180deg, rgba(99, 196, 255, 0.92), rgba(255, 153, 102, 0.92)) padding-box;
}

.compactScroll,
.modalSection--scroll,
.streamList,
.tableWrap {
    mask-image: linear-gradient(to bottom, transparent 0, black 18px, black calc(100% - 18px), transparent 100%);
}

.modalOverlay {
    display: flex;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    background:
        radial-gradient(circle at top, rgba(99, 196, 255, 0.14), transparent 28%),
        rgba(3, 8, 14, 0.78);
    transition: opacity 180ms ease, visibility 180ms ease;
}

.modalOverlay.isOpen {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.modalCard {
    overflow: hidden;
    border-radius: 30px;
    border-color: rgba(164, 209, 241, 0.24);
    background:
        linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.015)),
        var(--panel-strong);
    transform: translateY(18px) scale(0.985);
    transition: transform 180ms ease, box-shadow 180ms ease;
    box-shadow: 0 34px 80px rgba(0, 0, 0, 0.44);
}

.modalOverlay.isOpen .modalCard {
    transform: translateY(0) scale(1);
}

.modalCard > .toolbarRow {
    position: sticky;
    top: 0;
    z-index: 3;
    margin: -22px -22px 0;
    padding: 18px 22px 16px;
    background:
        linear-gradient(180deg, rgba(10, 18, 30, 0.94), rgba(10, 18, 30, 0.76));
    border-bottom: 1px solid rgba(164, 209, 241, 0.14);
    backdrop-filter: blur(18px);
}

.modalBody {
    padding-top: 2px;
}

.modalSection {
    align-content: start;
    padding: 16px;
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)),
        rgba(9, 15, 24, 0.62);
    border: 1px solid rgba(164, 209, 241, 0.09);
}

.modalSection--scroll {
    padding-right: 12px;
}

body.hasOpenModal {
    overflow: hidden;
}

.inventoryList,
.craftingList,
#merchantOfferList {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    align-content: start;
}

.equipmentList {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.inventoryItem,
.craftRecipeItem,
.leaderboardItem,
.eventItem,
.enemyItem,
.questItem,
.achievementItem,
.titleItem {
    border-radius: 20px;
}

.inventoryItem,
.craftRecipeItem {
    min-height: 180px;
}

.inventoryMain,
.craftRecipeItem__main,
.questItem__main,
.achievementItem__main,
.titleItem__main,
.enemyMain,
.eventMain {
    min-width: 0;
}

.inventorySide {
    min-width: 110px;
}

.inventorySide.cardActions {
    align-content: space-between;
}

.inventoryQty {
    min-width: 54px;
    padding: 7px 11px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(164, 209, 241, 0.16);
    color: var(--text);
    font-weight: 700;
}

.itemMeta span {
    border: 1px solid rgba(164, 209, 241, 0.12);
    background: rgba(255,255,255,0.045);
}

.itemMeta--recipe span {
    display: inline-flex;
    align-items: center;
}

.equipmentItem {
    min-height: 180px;
    align-content: start;
}

.equipmentItem.isEmpty {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01)),
        rgba(10, 15, 22, 0.55);
    border-style: dashed;
}

.questItem,
.achievementItem,
.titleItem {
    align-items: start;
}

.questItem .inventorySide,
.achievementItem .inventorySide,
.titleItem .inventorySide {
    min-width: 104px;
}

.questItem.isComplete,
.achievementItem.isUnlocked,
.titleItem.isActive {
    border-color: rgba(107, 240, 190, 0.32);
    background:
        linear-gradient(180deg, rgba(107, 240, 190, 0.09), rgba(107, 240, 190, 0.03)),
        rgba(7, 16, 22, 0.82);
}

.onboardingCard {
    padding: 2px;
}

.onboardingCard .toolbarActions {
    padding-top: 2px;
}

.infoCard {
    padding: 8px 2px 2px;
}

.infoRow {
    padding: 12px 0;
}

.progressBar {
    background: rgba(255,255,255,0.055);
    border-color: rgba(255,255,255,0.04);
}

.progressBar span {
    background: linear-gradient(90deg, #63c4ff 0%, #7fe4cc 52%, #ff9966 100%);
    box-shadow: 0 0 24px rgba(99, 196, 255, 0.22);
}

.statusBox {
    border-radius: 18px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

.announcementBar,
.diagnosticsBar {
    box-shadow: var(--shadow-soft);
}

.mapPanelV4 canvas,
.streamMapCanvas {
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.05), 0 20px 40px rgba(0,0,0,0.22);
}

.gameTopbarV4,
.heroPanel__content {
    align-items: stretch;
}

.gameTopbarV4__titleRow {
    gap: 18px;
}

.controlsPanelV4 {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015)),
        rgba(13, 22, 33, 0.86);
}

.controlsGrid--movement .btnPrimary {
    min-height: 64px;
    font-size: 15px;
}

.controlsGrid--actionsCompact .btnGhost {
    min-height: 60px;
}

.commandForm input {
    min-height: 52px;
}

.tableWrap {
    border-radius: 18px;
    border: 1px solid rgba(164, 209, 241, 0.09);
    background: rgba(8, 13, 21, 0.54);
}

.adminTable tr:hover td {
    background: rgba(255,255,255,0.025);
}

[data-tooltip] {
    position: relative;
}

[data-tooltip]::after,
[data-tooltip]::before {
    position: absolute;
    left: 50%;
    opacity: 0;
    pointer-events: none;
    transition: opacity 140ms ease, transform 140ms ease;
    z-index: 1200;
}

[data-tooltip]::after {
    content: attr(data-tooltip);
    bottom: calc(100% + 12px);
    transform: translate(-50%, 6px);
    width: max-content;
    max-width: min(260px, 70vw);
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid rgba(164, 209, 241, 0.22);
    background: rgba(8, 14, 24, 0.96);
    color: var(--text);
    font-size: 12px;
    line-height: 1.45;
    text-align: left;
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.36);
    white-space: normal;
}

[data-tooltip]::before {
    content: "";
    bottom: calc(100% + 6px);
    transform: translate(-50%, 6px);
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 7px solid rgba(8, 14, 24, 0.96);
}

[data-tooltip]:hover::after,
[data-tooltip]:hover::before,
[data-tooltip]:focus-visible::after,
[data-tooltip]:focus-visible::before {
    opacity: 1;
    transform: translate(-50%, 0);
}

@media (max-width: 900px) {
    .inventoryList,
    .craftingList,
    #merchantOfferList,
    .equipmentList,
    .profileStatsGrid {
        grid-template-columns: 1fr;
    }

    .modalOverlay {
        padding: 12px;
    }

    .modalCard {
        border-radius: 24px;
        max-height: calc(100vh - 24px);
    }

    .modalCard > .toolbarRow {
        margin: -22px -22px 0;
    }
}

@media (hover: none) {
    [data-tooltip]::after,
    [data-tooltip]::before {
        display: none;
    }
}
