/* ═══════════════════════════════════════════════════════════
   Star Atlas Flares – Core UI  ·  Tactical HUD Theme
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;600;700;900&family=Rajdhani:wght@400;500;600;700&family=Share+Tech+Mono&display=swap');

/* ── CSS Variables ─────────────────────────────────────── */
:root {
	--bg-deep:        #050b16;
	--bg-panel:       #0a1428;
	--bg-card:        rgba(15, 24, 44, 0.88);
	--bg-input:       rgba(11, 18, 36, 0.92);
	--bg-hover:       rgba(58, 102, 196, 0.3);
	--border-dim:     rgba(74, 106, 168, 0.42);
	--border-active:  rgba(98, 154, 255, 0.82);
	--border-glow:    rgba(108, 172, 255, 0.5);
	--accent:         #3c74ff;
	--accent-bright:  #8abaff;
	--accent-dim:     #2a4f9a;
	--cyan:           #68d0ff;
	--green:          #32c96b;
	--green-glow:     rgba(50, 201, 107, 0.4);
	--orange:         #ffb347;
	--orange-glow:    rgba(255, 179, 71, 0.35);
	--red:            #e14b4b;
	--red-glow:       rgba(225, 75, 75, 0.35);
	--text:           #e6eeff;
	--text-bright:    #f7faff;
	--text-dim:       rgba(194, 214, 255, 0.72);
	--font-display:   'Orbitron', sans-serif;
	--font-body:      'Rajdhani', sans-serif;
	--font-mono:      'Share Tech Mono', monospace;
	--glow-spread:    0 0 34px rgba(85, 138, 255, 0.2);
	--radius:         8px;
	--radius-lg:      12px;

	/* HUD panel geometry */
	--hud-w:          300px;   /* left/right panel width  */
	--hud-top:        46px;   /* updated by JS            */
	--hud-gap:        14px;    /* gap from screen edge     */
	--clip-corner:    14px;    /* diagonal corner cut size */
}

/* ── Reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body {
	margin: 0; padding: 0;
	width: 100%; height: 100%;
	overflow: hidden;
	background: var(--bg-deep);
}

body {
	font-family: var(--font-body);
	font-weight: 500;
	color: var(--text);
	letter-spacing: 0.02em;
}

.contract-logo-inline {
	position: relative;
	z-index: 1250;
	display: flex;
	align-items: center;
	margin: 10px 14px 0;
	opacity: 0.96;
	pointer-events: none;
}

.contract-logo-inline img {
	display: block;
	width: min(170px, 34vw);
	height: auto;
	max-height: 46px;
	object-fit: contain;
	filter: drop-shadow(0 0 12px rgba(255, 255, 255, 0.2));
}

.top-brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
	max-width: 100%;
}

.top-brand .contract-logo-inline {
	margin: 0;
	flex: 0 0 auto;
}

.top-brand .contract-logo-inline img {
	width: min(128px, 26vw);
	max-height: 34px;
}

.top-brand .logo,
.top-brand h1 {
	margin: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

@media (max-width: 900px) {
	.contract-logo-inline {
		margin: 8px 10px 0;
	}

	.contract-logo-inline img {
		width: min(92px, 28vw);
		max-height: 26px;
	}

	.top-brand {
		gap: 8px;
	}

	.top-brand .contract-logo-inline img {
		width: min(92px, 28vw);
		max-height: 26px;
	}
}

/* Custom scrollbar */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: rgba(4, 8, 18, 0.6); }
::-webkit-scrollbar-thumb { background: var(--accent-dim); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ══════════════════════════════════════════════════════════
   ROOT
   ══════════════════════════════════════════════════════════ */
#appRoot {
	position: fixed;
	inset: 0;
	overflow: hidden;
}

/* ══════════════════════════════════════════════════════════
   WELCOME OVERLAY (wallet gate)
   ══════════════════════════════════════════════════════════ */
.core-welcome-overlay {
	position: fixed;
	inset: 0;
	z-index: 1200;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(2, 4, 10, 0.92);
	backdrop-filter: blur(8px) saturate(1.2);
	-webkit-backdrop-filter: blur(8px) saturate(1.2);
}

.core-welcome-card {
	width: min(560px, calc(100vw - 28px));
	padding: 24px 22px 20px;
	border-radius: 12px;
	border: 1px solid rgba(60, 116, 255, 0.45);
	background: radial-gradient(circle at top, rgba(8, 14, 32, 0.97), rgba(3, 7, 18, 0.97));
	box-shadow:
		0 0 0 1px rgba(60, 116, 255, 0.08),
		0 30px 80px rgba(0, 0, 0, 0.65),
		0 0 50px rgba(60, 116, 255, 0.12);
	text-align: center;
}

.core-welcome-logo {
	display: block;
	max-width: min(420px, 88%);
	max-height: 140px;
	object-fit: contain;
	margin: 0 auto 12px;
	filter: drop-shadow(0 0 14px rgba(60, 116, 255, 0.18));
}

.core-welcome-title {
	font-family: var(--font-display);
	font-size: 16px;
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--accent-bright);
	margin-bottom: 6px;
}

.core-welcome-subtitle {
	font-family: var(--font-body);
	font-size: 13px;
	color: var(--text-dim);
	margin-bottom: 14px;
}

.core-welcome-row {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
	margin-bottom: 10px;
}

.core-welcome-status {
	font-family: var(--font-mono);
	font-size: 11px;
	line-height: 1.35;
	color: var(--text-dim);
	min-height: 16px;
}

#core-welcome-status.is-error {
	color: #f59aa1;
}

/* ══════════════════════════════════════════════════════════
   TOP HUD BAR — slim single row (46px)
   Left: title · Centre: nav buttons · Right: wallet
   ══════════════════════════════════════════════════════════ */
.core-hud-topbar {
	position: fixed;
	top: 0;
	left: var(--hud-w);
	right: var(--hud-w);
	z-index: 600;
	height: 46px;
	background: rgba(3, 6, 18, 0.90);
	backdrop-filter: blur(18px) saturate(1.5);
	-webkit-backdrop-filter: blur(18px) saturate(1.5);
	border-bottom: 1px solid rgba(50, 80, 150, 0.30);
	pointer-events: auto;
	overflow: hidden;
}

/* Bottom accent line */
.core-hud-topbar::after {
	content: '';
	position: absolute;
	bottom: 0; left: 8%; right: 8%;
	height: 1px;
	background: linear-gradient(90deg,
		transparent 0%,
		var(--accent-dim) 25%,
		var(--cyan) 50%,
		var(--accent-dim) 75%,
		transparent 100%);
	opacity: 0.55;
}

/* Single flex row */
.core-hud-bar-inner {
	display: flex;
	align-items: center;
	height: 100%;
	padding: 0 16px;
	gap: 0;
}

/* Left: title */
.core-hud-title {
	font-family: var(--font-display);
	font-size: 13px; font-weight: 900;
	letter-spacing: 0.18em; text-transform: uppercase;
	background: linear-gradient(120deg, var(--accent-bright) 20%, var(--cyan) 100%);
	-webkit-background-clip: text; -webkit-text-fill-color: transparent;
	background-clip: text;
	white-space: nowrap; flex-shrink: 0;
}
.core-hud-title-sub {
	font-size: 9px; font-weight: 400; letter-spacing: 0.22em; opacity: 0.55;
}

/* Centre: nav buttons */
.core-hud-nav {
	display: flex; align-items: center; gap: 2px;
	flex: 1; justify-content: center;
}

/* Right: wallet */
.core-hud-wallet {
	display: flex; align-items: center; gap: 6px; flex-shrink: 0;
}

.core-hud-provider {
	padding: 3px 6px; border-radius: 4px;
	border: 1px solid var(--border-dim);
	background: rgba(5, 9, 22, 0.75); color: var(--text-dim);
	font-family: var(--font-mono); font-size: 10px;
	cursor: pointer; outline: none; width: 80px;
}
.core-hud-pubkey {
	width: 155px; padding: 4px 8px; border-radius: 4px;
	border: 1px solid var(--border-dim);
	background: rgba(5, 9, 22, 0.75); color: var(--text-bright);
	font-family: var(--font-mono); font-size: 10px;
	outline: none; transition: border-color 0.2s;
}
.core-hud-pubkey:focus { border-color: var(--accent); }
.core-hud-pubkey::placeholder { color: var(--text-dim); opacity: 0.5; }

.core-hud-btn {
	padding: 4px 10px; border-radius: 4px;
	border: 1px solid rgba(60, 116, 255, 0.45);
	background: rgba(10, 22, 65, 0.82);
	color: var(--text-bright);
	font-family: var(--font-display); font-size: 9px;
	font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
	cursor: pointer; transition: all 0.18s; white-space: nowrap;
}
.core-hud-btn:hover {
	background: rgba(22, 48, 140, 0.90);
	border-color: var(--accent);
	box-shadow: 0 0 10px rgba(60, 116, 255, 0.25);
}
.core-hud-btn-connect {
	border-color: rgba(50, 201, 107, 0.50);
	background: rgba(10, 38, 20, 0.82);
}
.core-hud-btn-connect:hover {
	background: rgba(14, 58, 28, 0.92); border-color: var(--green);
	box-shadow: 0 0 10px var(--green-glow);
}
.core-hud-btn-danger {
	border-color: rgba(225, 75, 75, 0.48);
	background: rgba(38, 10, 10, 0.82);
}
.core-hud-btn-danger:hover {
	background: rgba(68, 14, 14, 0.92); border-color: var(--red);
	box-shadow: 0 0 10px var(--red-glow);
}
.core-hud-status {
	font-family: var(--font-mono); font-size: 10px; color: var(--text-dim);
	white-space: nowrap; max-width: 140px;
	overflow: hidden; text-overflow: ellipsis;
}

/* Legacy .core-container — stripped */
.core-container {
	max-width: none; width: 100%; margin: 0; padding: 0;
	background: transparent; border: none; border-radius: 0;
	box-shadow: none; backdrop-filter: none; position: relative;
}
.core-container::before { display: none; }
.core-container h1, .core-container > p { display: none; }

/* ══════════════════════════════════════════════════════════
   POPUP PANELS — floating over map, centred below topbar
   ══════════════════════════════════════════════════════════ */
.core-popup-panel {
	display: none;
	position: fixed;
	top: 56px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 900;
	width: min(840px, calc(100vw - var(--hud-w) * 2 - 32px));
	max-height: calc(100vh - 80px);
	background: rgba(3, 7, 20, 0.96);
	border: 1px solid rgba(55, 90, 160, 0.55);
	border-radius: 10px;
	overflow: hidden;
	box-shadow:
		0 0 0 1px rgba(60, 116, 255, 0.07),
		0 28px 70px rgba(0, 0, 0, 0.60),
		0 0 50px rgba(25, 55, 140, 0.10);
	backdrop-filter: blur(22px) saturate(1.5);
	-webkit-backdrop-filter: blur(22px) saturate(1.5);
	clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 0 100%);
}
.core-popup-panel.core-popup-open {
	display: flex;
	flex-direction: column;
	animation: popupIn 0.20s cubic-bezier(0.22, 1, 0.36, 1) both;
}
@keyframes popupIn {
	from { opacity: 0; transform: translateX(-50%) translateY(-8px); }
	to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
/* Top accent line */
.core-popup-panel::before {
	content: ''; position: absolute;
	top: 0; left: 0; right: 0; height: 1px;
	background: linear-gradient(90deg,
		transparent, var(--accent) 20%, var(--cyan) 50%, var(--accent) 80%, transparent);
	opacity: 0.80; z-index: 2; pointer-events: none;
}
.core-popup-header {
	display: flex; align-items: center; gap: 14px;
	padding: 10px 16px 9px;
	border-bottom: 1px solid rgba(40, 65, 120, 0.35);
	background: rgba(4, 9, 26, 0.65); flex-shrink: 0;
}
.core-popup-title {
	font-family: var(--font-display); font-size: 11px; font-weight: 700;
	letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--accent-bright); flex-shrink: 0;
}
.core-popup-meta {
	display: flex; gap: 18px;
	font-family: var(--font-mono); font-size: 10px; color: var(--text-dim); flex: 1;
}
.core-popup-close {
	margin-left: auto; flex-shrink: 0;
	width: 24px; height: 24px; border-radius: 4px;
	border: 1px solid rgba(60, 116, 255, 0.28);
	background: rgba(10, 20, 50, 0.70);
	color: var(--text-dim); font-size: 12px; line-height: 1;
	cursor: pointer; transition: all 0.15s;
	display: flex; align-items: center; justify-content: center;
}
.core-popup-close:hover {
	border-color: var(--accent); color: var(--text-bright);
	box-shadow: 0 0 8px rgba(60, 116, 255, 0.25);
}
.core-popup-body {
	overflow-y: auto; padding: 14px 16px;
	flex: 1; max-height: calc(100vh - 150px);
}

/* ══════════════════════════════════════════════════════════
   HUD PANEL — shared "floating glass" mixin
   Applied to .core-fleet-block, .core-bases-block
   ══════════════════════════════════════════════════════════ */
.core-fleet-block,
.core-bases-block {
	/* Break out of normal flow, float over the map */
	position: fixed !important;
	top: calc(var(--hud-top, 46px) + 10px) !important;
	bottom: var(--hud-gap) !important;
	width: var(--hud-w) !important;
	z-index: 200 !important;

	/* Frosted glass with clipped corner top-right (fleet) / top-left (bases) */
	background: rgba(3, 7, 18, 0.82) !important;
	border: 1px solid rgba(50, 80, 140, 0.45) !important;
	border-radius: 0 !important;
	backdrop-filter: blur(16px) saturate(1.3) !important;
	-webkit-backdrop-filter: blur(16px) saturate(1.3) !important;

	overflow-y: auto !important;
	overflow-x: hidden !important;
	padding: 12px 14px 18px !important;

	/* Subtle ambient glow on the inner edge facing the map */
	box-shadow:
		0 0 0 1px rgba(60, 116, 255, 0.06),
		inset 0 0 40px rgba(4, 10, 28, 0.5) !important;

	/* Entrance animation */
	animation: hudSlideIn 0.35s cubic-bezier(0.22, 1, 0.36, 1) both !important;
}

/* Fleet panel → right side */
.core-fleet-block {
	right: var(--hud-gap) !important;
	left: auto !important;
	/* Clipped bottom-left corner for asymmetric sci-fi feel */
	clip-path: polygon(
		0 0,
		100% 0,
		100% calc(100% - var(--clip-corner)),
		calc(100% - var(--clip-corner)) 100%,
		0 100%
	) !important;
	/* Right-side accent border glow */
	border-right: 1px solid rgba(60, 116, 255, 0.55) !important;
	border-top: 1px solid rgba(60, 116, 255, 0.40) !important;
}

/* Bases panel → left side */
.core-bases-block {
	left: var(--hud-gap) !important;
	right: auto !important;
	/* Clipped bottom-right corner */
	clip-path: polygon(
		0 0,
		100% 0,
		100% 100%,
		var(--clip-corner) 100%,
		0 calc(100% - var(--clip-corner))
	) !important;
	border-left: 1px solid rgba(78, 195, 255, 0.50) !important;
	border-top: 1px solid rgba(78, 195, 255, 0.35) !important;
	display: block !important;
}

/* Shared panel entrance */
@keyframes hudSlideIn {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* Thin luminous top edge line on each panel */
.core-fleet-block::before,
.core-bases-block::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 1px;
	pointer-events: none;
	z-index: 3;
}
.core-fleet-block::before {
	background: linear-gradient(90deg,
		transparent 0%, var(--accent) 30%, var(--accent-bright) 60%, transparent 100%);
	opacity: 0.7;
}
.core-bases-block::before {
	background: linear-gradient(90deg,
		transparent 0%, var(--cyan) 40%, var(--accent-bright) 70%, transparent 100%);
	opacity: 0.6;
}

/* ── Panel headings ───────────────────────────────────── */
.core-fleet-block h2,
.core-bases-block h2 {
	font-family: var(--font-display) !important;
	font-size: 10px !important;
	font-weight: 700 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	color: var(--accent-bright) !important;
	margin: 0 0 10px !important;
	padding: 0 0 6px !important;
	border-bottom: 1px solid rgba(60, 116, 255, 0.18) !important;
	position: sticky !important;
	top: 0 !important;
	background: rgba(3, 7, 18, 0.96) !important;
	z-index: 2 !important;
}
.core-bases-block h2 { color: var(--cyan) !important; }

/* ══════════════════════════════════════════════════════════
   FLEET BLOCK — card list layout
   Table is restyled to a vertical card list via CSS.
   Each <tr data-core-fleet-row> becomes a clickable card;
   the actions cell expands into a drawer on click.
   No JS in novagrid-fleet.js is changed.
   ══════════════════════════════════════════════════════════ */

/* Top utility buttons row */
.core-fleet-actions {
	display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 10px;
}
.core-fleet-actions button {
	padding: 3px 9px; border-radius: 4px;
	border: 1px solid var(--accent-dim);
	background: rgba(8, 18, 48, 0.72);
	color: var(--text-dim);
	font-family: var(--font-mono); font-size: 10px;
	cursor: pointer; transition: all 0.18s; letter-spacing: 0.04em;
}
.core-fleet-actions button:hover {
	border-color: var(--accent); color: var(--text-bright);
	box-shadow: 0 0 8px rgba(60, 116, 255, 0.2);
}
.core-fleet-actions label {
	font-family: var(--font-mono); font-size: 10px; color: var(--text-dim);
	cursor: pointer; display: inline-flex; align-items: center; gap: 4px; margin-left: 4px;
}
.core-fleet-actions input[type="checkbox"] { accent-color: var(--accent); }

/* ── Table → card list ──────────────────────────────────── */
/* Hide the original table layout entirely */
.core-fleet-table,
.core-fleet-block .core-table {
	display: block !important;
	width: 100% !important;
	border: none !important;
}

/* Hide thead */
.core-fleet-table thead,
.core-fleet-block .core-table thead {
	display: none !important;
}

/* tbody as vertical flex column */
.core-fleet-table tbody,
.core-fleet-block .core-table tbody {
	display: flex !important;
	flex-direction: column !important;
	gap: 4px !important;
	width: 100% !important;
}

/* Each <tr> becomes a card */
.core-fleet-table tbody tr,
.core-fleet-block .core-table tbody tr {
	display: block !important;
	background: rgba(5, 10, 26, 0.70) !important;
	border: 1px solid rgba(45, 70, 130, 0.35) !important;
	border-radius: 6px !important;
	cursor: pointer !important;
	transition: border-color 0.18s, background 0.18s !important;
	overflow: hidden !important;
	position: relative !important;
}
.core-fleet-table tbody tr:hover,
.core-fleet-block .core-table tbody tr:hover {
	background: rgba(8, 18, 50, 0.85) !important;
	border-color: rgba(60, 116, 255, 0.45) !important;
}
/* Expanded card */
.core-fleet-table tbody tr.core-fleet-row-open,
.core-fleet-block .core-table tbody tr.core-fleet-row-open {
	border-color: var(--accent) !important;
	background: rgba(8, 18, 50, 0.92) !important;
	box-shadow: 0 0 20px rgba(60, 116, 255, 0.12) !important;
}

/* Left accent bar */
.core-fleet-table tbody tr::before,
.core-fleet-block .core-table tbody tr::before {
	content: '' !important;
	position: absolute !important;
	left: 0 !important; top: 0 !important; bottom: 0 !important;
	width: 2px !important;
	background: var(--accent-dim) !important;
	transition: background 0.18s !important;
}
.core-fleet-table tbody tr.core-fleet-row-open::before,
.core-fleet-block .core-table tbody tr.core-fleet-row-open::before {
	background: var(--cyan) !important;
}

/* All <td> hidden by default */
.core-fleet-table tbody tr td,
.core-fleet-block .core-table tbody tr td {
	display: none !important;
	border: none !important;
	padding: 0 !important;
}

/* ── Card summary row (always visible) ──────────────────
   We show: td:nth-child(2)=Name  td:nth-child(9)=State
            td:nth-child(7)=Pos   td:nth-child(10)=Fuel
   Using a grid via the card-summary wrapper injected by CSS */

/* Show name (col2), state (col9), pos (col7), fuel (col10) always */
.core-fleet-table tbody tr td:nth-child(2),
.core-fleet-block .core-table tbody tr td:nth-child(2) {
	display: inline-block !important;
	font-family: var(--font-body) !important;
	font-weight: 700 !important; font-size: 12px !important;
	color: var(--text-bright) !important;
	padding: 7px 0 0 14px !important;
	width: 100% !important;
	white-space: nowrap !important; overflow: hidden !important;
	text-overflow: ellipsis !important;
}

/* State badge (col9) */
.core-fleet-table tbody tr td:nth-child(9),
.core-fleet-block .core-table tbody tr td:nth-child(9) {
	display: inline-block !important;
	font-family: var(--font-mono) !important; font-size: 9px !important;
	color: var(--cyan) !important;
	padding: 0 14px 0 14px !important;
	letter-spacing: 0.06em !important; text-transform: uppercase !important;
}

/* Position */
.core-fleet-table tbody tr td:nth-child(7),
.core-fleet-block .core-table tbody tr td:nth-child(7) {
	display: inline-block !important;
	font-family: var(--font-mono) !important; font-size: 9px !important;
	color: var(--text-dim) !important;
	padding: 0 6px 0 14px !important;
}
.core-fleet-table tbody tr td:nth-child(7)::before,
.core-fleet-block .core-table tbody tr td:nth-child(7)::before {
	content: '📍 ' !important;
	font-size: 8px !important;
}

/* Fuel (col10) */
.core-fleet-table tbody tr td:nth-child(10),
.core-fleet-block .core-table tbody tr td:nth-child(10) {
	display: inline-block !important;
	font-family: var(--font-mono) !important; font-size: 9px !important;
	color: var(--orange) !important;
	padding: 0 14px 5px 14px !important;
}
.core-fleet-table tbody tr td:nth-child(10)::before,
.core-fleet-block .core-table tbody tr td:nth-child(10)::before {
	content: '⛽ ' !important;
	font-size: 8px !important;
}

/* ── Expanded details (col 1,3,4,5,6,8,11,12,13,14) ────── */
/* Show all detail cells when row is open */
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(1),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(1),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(3),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(3),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(4),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(4),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(5),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(5),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(6),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(6),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(8),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(8),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(11),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(11),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(12),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(12),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(13),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(13),
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(14),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(14) {
	display: inline-block !important;
	font-family: var(--font-mono) !important; font-size: 10px !important;
	color: var(--text-dim) !important;
	padding: 1px 10px 1px 14px !important;
}

/* ── Actions cell (col15) — always last, shown as button row ── */
/* Hidden when card is collapsed */
.core-fleet-table tbody tr td:nth-child(15),
.core-fleet-block .core-table tbody tr td:nth-child(15) {
	display: none !important;
	width: 100% !important;
	padding: 8px 12px 10px 12px !important;
	border-top: 1px solid rgba(40, 65, 120, 0.30) !important;
	background: rgba(4, 9, 26, 0.60) !important;
	margin-top: 4px !important;
}

/* Show actions when expanded */
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(15),
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(15) {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 5px !important;
	align-items: center !important;
}

/* Action buttons inside the drawer */
.core-fleet-table tbody tr td:nth-child(15) button,
.core-fleet-block .core-table tbody tr td:nth-child(15) button,
.core-fleet-action {
	padding: 4px 10px !important;
	border-radius: 4px !important;
	border: 1px solid rgba(60, 116, 255, 0.45) !important;
	background: rgba(8, 20, 64, 0.80) !important;
	color: var(--text-bright) !important;
	font-family: var(--font-display) !important;
	font-size: 9px !important; font-weight: 700 !important;
	letter-spacing: 0.07em !important; text-transform: uppercase !important;
	cursor: pointer !important; transition: all 0.16s !important;
}
.core-fleet-table tbody tr td:nth-child(15) button:hover,
.core-fleet-block .core-table tbody tr td:nth-child(15) button:hover,
.core-fleet-action:hover {
	background: rgba(20, 45, 140, 0.90) !important;
	border-color: var(--accent) !important;
	box-shadow: 0 0 10px rgba(60, 116, 255, 0.25) !important;
	transform: translateY(-1px) !important;
}
.core-fleet-table tbody tr td:nth-child(15) button:disabled,
.core-fleet-block .core-table tbody tr td:nth-child(15) button:disabled,
.core-fleet-action:disabled {
	opacity: 0.35 !important; cursor: not-allowed !important; transform: none !important;
}

/* Expand/collapse chevron indicator */
.core-fleet-table tbody tr td:nth-child(2)::after,
.core-fleet-block .core-table tbody tr td:nth-child(2)::after {
	content: ' ▸' !important;
	font-size: 9px !important;
	color: var(--accent-dim) !important;
	transition: transform 0.2s !important;
}
.core-fleet-table tbody tr.core-fleet-row-open td:nth-child(2)::after,
.core-fleet-block .core-table tbody tr.core-fleet-row-open td:nth-child(2)::after {
	content: ' ▾' !important;
	color: var(--cyan) !important;
}

/* Action buttons at panel level (not inside fleet rows) */
.core-fleet-block button:not(.core-fleet-action):not([data-core-fleet-action]) {
	padding: 3px 9px !important;
	border-radius: 4px !important;
	border: 1px solid var(--accent-dim) !important;
	background: rgba(8, 18, 48, 0.72) !important;
	color: var(--text-dim) !important;
	font-family: var(--font-mono) !important; font-size: 10px !important;
	cursor: pointer !important; transition: all 0.18s !important;
}
.core-fleet-block button:not(.core-fleet-action):not([data-core-fleet-action]):hover {
	border-color: var(--accent) !important; color: var(--text-bright) !important;
	box-shadow: 0 0 8px rgba(60, 116, 255, 0.2) !important;
}

/* ══════════════════════════════════════════════════════════
   BASES BLOCK — list only (detail hidden / in popup)
   ══════════════════════════════════════════════════════════ */
.core-bases-layout { display: block; }
.core-bases-detail { display: none; }

.core-bases-search-wrap {
	margin: 0 0 8px;
}
.core-bases-search-wrap input {
	width: 100%;
	padding: 6px 10px;
	border-radius: var(--radius);
	border: 1px solid rgba(40, 80, 120, 0.45);
	background: rgba(4, 9, 22, 0.72);
	color: var(--text-bright);
	font-family: var(--font-mono);
	font-size: 11px;
	outline: none;
	transition: border-color 0.15s, box-shadow 0.15s;
}
.core-bases-search-wrap input:focus {
	border-color: var(--accent);
	box-shadow: 0 0 10px rgba(60, 116, 255, 0.2);
}
.core-bases-search-wrap input::placeholder {
	color: var(--text-dim);
}

.core-bases-list {
	list-style: none; padding: 0; margin: 0;
	font-size: 11px; font-family: var(--font-mono);
	border: 1px solid rgba(40, 80, 120, 0.30);
	border-radius: var(--radius);
	background: rgba(4, 9, 22, 0.50);
	width: 100%;
}
.core-bases-list li {
	padding: 6px 10px;
	cursor: pointer;
	border-bottom: 1px solid rgba(20, 35, 60, 0.35);
	transition: background 0.14s, border-left-color 0.14s;
	border-left: 2px solid transparent;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}
.core-bases-list li:last-child { border-bottom: none; }
.core-bases-list li:hover {
	background: rgba(30, 60, 120, 0.30);
	border-left-color: var(--cyan);
}
.core-bases-list li.core-sb-faction-mud {
	border-left-color: var(--red);
}
.core-bases-list li.core-sb-faction-ustur {
	border-left-color: var(--orange);
}
.core-bases-list li.core-sb-faction-oni {
	border-left-color: var(--accent-bright);
}
.core-bases-list li.core-sb-selected {
	background: rgba(20, 50, 100, 0.50);
	border-left: 3px solid var(--cyan);
	color: var(--text-bright);
}
.core-sb-name {
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.core-sb-faction-badge {
	font-size: 10px;
	line-height: 1;
	padding: 2px 6px;
	border-radius: 999px;
	font-family: var(--font-display);
	letter-spacing: 0.06em;
	border: 1px solid var(--border-dim);
	color: var(--text-bright);
	background: rgba(10, 18, 36, 0.65);
	flex-shrink: 0;
}
.core-sb-badges {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex-shrink: 0;
}
.core-bases-list li.core-sb-central {
	box-shadow: inset 0 0 0 1px rgba(60, 116, 255, 0.25);
}
.core-sb-central-badge {
	font-size: 9px;
	line-height: 1;
	padding: 2px 6px;
	border-radius: 999px;
	font-family: var(--font-display);
	letter-spacing: 0.08em;
	border: 1px solid rgba(60, 116, 255, 0.6);
	color: var(--cyan);
	background: rgba(8, 20, 45, 0.8);
	text-transform: uppercase;
}
.core-bases-list li.core-sb-faction-mud .core-sb-faction-badge {
	border-color: rgba(225, 75, 75, 0.65);
	color: var(--red);
	background: rgba(36, 10, 10, 0.75);
}
.core-bases-list li.core-sb-faction-ustur .core-sb-faction-badge {
	border-color: rgba(255, 179, 71, 0.65);
	color: var(--orange);
	background: rgba(42, 28, 10, 0.75);
}
.core-bases-list li.core-sb-faction-oni .core-sb-faction-badge {
	border-color: rgba(110, 168, 255, 0.65);
	color: var(--accent-bright);
	background: rgba(10, 22, 48, 0.75);
}
.core-sb-detail { font-size: 11px; font-family: var(--font-mono); }

/* Floating starbase popup (left side, near starbase list) */
.core-starbase-float-popup {
	position: fixed;
	top: calc(var(--hud-top, 56px) + 16px);
	left: calc(var(--hud-gap, 14px) + var(--hud-w, 300px) + 18px);
	z-index: 340;
	width: min(520px, calc(100vw - var(--hud-w, 300px) - 64px));
	max-height: calc(100vh - var(--hud-top, 56px) - 36px);
	display: flex;
	flex-direction: column;
	background: rgba(5, 10, 24, 0.94);
	border: 1px solid rgba(60, 116, 255, 0.42);
	border-radius: var(--radius-lg);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.55), 0 0 20px rgba(60, 116, 255, 0.10);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	overflow: hidden;
	pointer-events: auto;
}
.core-starbase-float-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	border-bottom: 1px solid rgba(40, 70, 120, 0.35);
	font-family: var(--font-display);
	font-size: 11px;
	letter-spacing: 0.07em;
}
.core-starbase-float-header[data-core-starbase-drag-handle="1"] {
	cursor: move;
	user-select: none;
}
.core-starbase-float-header[data-core-starbase-drag-handle="1"] .core-fleet-modal-close {
	cursor: pointer;
}
.core-starbase-float-hero {
	padding: 10px 12px 6px;
	border-bottom: 1px solid rgba(40, 70, 120, 0.20);
	background: linear-gradient(180deg, rgba(10, 20, 42, 0.55), rgba(6, 12, 28, 0.30));
}
.core-starbase-float-hero img {
	display: block;
	width: 100%;
	max-height: 150px;
	object-fit: contain;
	border-radius: 8px;
	border: 1px solid rgba(60, 116, 255, 0.28);
	background: rgba(3, 8, 18, 0.55);
}
.core-starbase-float-tabs {
	display: flex;
	gap: 6px;
	padding: 8px 12px 6px;
	border-bottom: 1px solid rgba(40, 70, 120, 0.25);
	background: rgba(8, 14, 30, 0.5);
}
.core-sb-popup-tab {
	padding: 5px 10px;
	border-radius: 6px;
	border: 1px solid rgba(60, 116, 255, 0.3);
	background: rgba(10, 22, 50, 0.5);
	color: var(--text-dim);
	cursor: pointer;
	font-family: var(--font-display);
	font-size: 10px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.core-sb-popup-tab:hover {
	color: var(--text-bright);
	border-color: rgba(60, 116, 255, 0.55);
}
.core-sb-popup-tab-active {
	color: var(--text-bright);
	border-color: var(--accent);
	background: rgba(20, 45, 115, 0.7);
	box-shadow: 0 0 10px rgba(60, 116, 255, 0.2);
}
.core-starbase-float-body {
	padding: 10px 12px;
	overflow: auto;
	font-family: var(--font-mono);
	font-size: 11px;
	line-height: 1.45;
	flex: 1;
}
.core-starbase-float-pane ul {
	margin: 6px 0;
	padding-left: 18px;
}
.core-sb-popup-fleet-state {
	color: var(--text-dim);
	font-size: 10px;
}
.core-starbase-float-footer {
	padding: 8px 12px 12px;
	display: flex;
	justify-content: flex-end;
	border-top: 1px solid rgba(40, 70, 120, 0.25);
}

/* ══════════════════════════════════════════════════════════
   FULLSCREEN 3D MAP  — background layer
   .core-map-block is the static host; #core-map3d-wrapper
   bursts out to fixed full-screen via CSS.
   All event handlers live inside #core-fleet-panel — untouched.
   ══════════════════════════════════════════════════════════ */

.core-map-block {
	position: static !important;
	display: block !important;
	height: 0 !important; overflow: visible !important;
	margin: 0 !important; padding: 0 !important;
	border: none !important; background: transparent !important;
}
.core-map-block > h2 { display: none !important; }

#core-map3d-wrapper,
.core-map3d-wrapper {
	position: fixed !important;
	top: 0 !important; left: 0 !important;
	right: 0 !important; bottom: 0 !important;
	width: 100vw !important; height: 100vh !important;
	z-index: 0 !important;
	border: none !important; border-radius: 0 !important;
	margin: 0 !important; overflow: hidden !important;
	box-shadow: none !important;
}
#core-map3d {
	width: 100% !important; height: 100vh !important;
	border-radius: 0 !important; overflow: hidden !important;
}
/* CRT scanlines overlay */
.core-map3d-wrapper::after {
	content: '';
	position: absolute; inset: 0;
	pointer-events: none;
	background: repeating-linear-gradient(
		0deg, transparent, transparent 2px,
		rgba(0, 8, 24, 0.022) 2px, rgba(0, 8, 24, 0.022) 4px
	);
	z-index: 1; border-radius: 0;
}
.core-map3d-wrapper::before { display: none !important; }

/* ── Fleet tab wrapper — fixed fullscreen transparent host ── */
[data-core-tab-id="fleet"] {
	position: fixed !important;
	inset: 0 !important;
	overflow: visible !important;
	background: transparent !important;
	border: none !important;
	padding: 0 !important;
	display: block !important;
}
#core-fleet-panel {
	position: fixed !important;
	inset: 0 !important;
	overflow: visible !important;
	background: transparent !important;
}

/* Floating left/right side panels for fleets and starbases */
.core-fleet-block, .core-bases-block {
	position: fixed;
	top: calc(var(--hud-top, 56px) + 14px);
	bottom: 20px;
	width: 300px;
	max-width: 38vw;
	background: rgba(3,8,22,0.9);
	border: 1px solid rgba(60,116,255,0.08);
	border-radius: 8px;
	padding: 12px;
	box-shadow: 0 6px 24px rgba(0,0,0,0.6), 0 1px 0 rgba(255,255,255,0.02) inset;
	backdrop-filter: blur(8px);
	z-index: 320;
	overflow: auto;
}
.core-fleet-block { right: 18px; }
.core-bases-block { left: 18px; }

/* Toggle buttons */
.core-floating-toggle {
	position: fixed;
	top: calc(var(--hud-top, 56px) + 8px);
	width: 36px;
	height: 36px;
	border-radius: 6px;
	background: rgba(10,18,36,0.85);
	border: 1px solid rgba(60,116,255,0.12);
	color: var(--text-bright);
	display: flex; align-items: center; justify-content: center;
	cursor: pointer; z-index: 330; backdrop-filter: blur(6px);
}
.core-toggle-fleets { right: 18px; }
.core-toggle-bases { left: 18px; }

/* Collapsed state: slide out of view */
.core-floating-collapsed.core-fleet-block { transform: translateX(calc(100% + 12px)); transition: transform 0.28s ease; }
.core-floating-collapsed.core-bases-block { transform: translateX(calc(-100% - 12px)); transition: transform 0.28s ease; }

/* Small screens: hide floating panels and fall back to inline */
@media (max-width: 900px) {
	.core-fleet-block, .core-bases-block { position: static; width: auto; max-width: none; margin: 8px; }
	.core-floating-toggle { display: none; }
}

/* ══════════════════════════════════════════════════════════
   MAP CONTROLS  — floating buttons over the map
   ══════════════════════════════════════════════════════════ */
.core-map-controls {
	position: fixed !important;
	right: calc(var(--hud-w) + var(--hud-gap) + 14px) !important;
	bottom: 20px !important;
	z-index: 300 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 5px !important;
	pointer-events: auto !important;
}
.core-map-controls button {
	padding: 6px 12px;
	border-radius: 4px;
	border: 1px solid rgba(60, 116, 255, 0.5);
	background: rgba(4, 10, 28, 0.88);
	color: var(--text-bright);
	font-family: var(--font-mono); font-size: 10px;
	cursor: pointer; backdrop-filter: blur(8px);
	transition: all 0.18s; letter-spacing: 0.06em;
}
.core-map-controls button:hover {
	background: rgba(16, 38, 90, 0.95);
	border-color: var(--accent);
	box-shadow: 0 0 12px rgba(60, 116, 255, 0.35);
	transform: translateY(-1px);
}

/* Map refresh button (bottom left over map) */
.core-map-header {
	position: fixed !important;
	bottom: 20px !important;
	left: calc(var(--hud-w) + var(--hud-gap) + 14px) !important;
	z-index: 300 !important;
	display: flex !important; align-items: center !important;
	gap: 8px !important; font-family: var(--font-mono) !important;
	font-size: 11px !important;
}
.core-map-header button {
	padding: 5px 12px;
	border-radius: 4px;
	border: 1px solid rgba(60, 116, 255, 0.45);
	background: rgba(4, 10, 28, 0.88);
	color: var(--text-bright);
	font-family: var(--font-body); font-weight: 600; font-size: 11px;
	cursor: pointer; backdrop-filter: blur(6px); transition: all 0.18s;
}
.core-map-header button:hover {
	box-shadow: 0 0 12px rgba(60, 116, 255, 0.3);
	border-color: var(--accent);
}

/* Fleet action bar — bottom-center over map */
.core-map-actions {
	position: fixed !important;
	bottom: 20px !important;
	left: 50% !important;
	transform: translateX(-50%) !important;
	z-index: 300 !important;
	padding: 7px 14px !important;
	border: 1px solid rgba(60, 116, 255, 0.38) !important;
	border-radius: 6px !important;
	background: rgba(3, 8, 22, 0.90) !important;
	display: flex !important; flex-wrap: wrap !important;
	gap: 7px !important; align-items: center !important;
	backdrop-filter: blur(10px) !important;
	box-shadow: 0 0 20px rgba(0,0,0,0.4),
		inset 0 1px 0 rgba(60,116,255,0.08) !important;
}
.core-map-actions-title {
	font-family: var(--font-display);
	font-size: 9px; letter-spacing: 0.1em;
	color: var(--cyan); margin-right: 6px;
	text-transform: uppercase;
}
.core-map-action {
	padding: 4px 10px;
	border-radius: 4px;
	border: 1px solid rgba(60, 116, 255, 0.55);
	background: linear-gradient(180deg, rgba(20, 50, 140, 0.75), rgba(10, 32, 90, 0.90));
	color: var(--text-bright);
	font-family: var(--font-body); font-weight: 600; font-size: 11px;
	cursor: pointer; transition: all 0.18s; letter-spacing: 0.03em;
}
.core-map-action:hover {
	background: linear-gradient(180deg, rgba(35, 75, 185, 0.9), rgba(20, 55, 140, 0.95));
	box-shadow: 0 0 12px rgba(60, 116, 255, 0.3);
	transform: translateY(-1px);
}

/* ══════════════════════════════════════════════════════════
   WALLET BAR
   ══════════════════════════════════════════════════════════ */
.core-wallet-bar {
	display: flex; flex-wrap: wrap; align-items: center;
	gap: 6px; margin-bottom: 5px;
}
.core-wallet-bar label {
	min-width: 85px; font-family: var(--font-mono); font-size: 11px;
	color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.06em;
}
.core-wallet-bar input[type="text"] {
	flex: 1 1 200px; padding: 5px 10px;
	border-radius: var(--radius); border: 1px solid var(--border-dim);
	background: rgba(5, 9, 22, 0.72); color: var(--text-bright);
	font-family: var(--font-mono); font-size: 11px;
	transition: border-color 0.22s, box-shadow 0.22s; outline: none;
}
.core-wallet-bar input[type="text"]:focus {
	border-color: var(--accent);
	box-shadow: 0 0 10px rgba(60, 116, 255, 0.18);
}
.core-wallet-bar select {
	padding: 4px 8px; border-radius: var(--radius);
	border: 1px solid var(--border-dim);
	background: rgba(5, 9, 22, 0.72); color: var(--text-bright);
	font-family: var(--font-body); font-size: 11px; cursor: pointer; outline: none;
}
.core-wallet-bar button,
.core-wallet-connect-bar button {
	padding: 5px 12px; border-radius: var(--radius);
	border: 1px solid var(--accent);
	background: linear-gradient(180deg, rgba(35, 75, 195, 0.72), rgba(22, 50, 135, 0.90));
	color: var(--text-bright); font-family: var(--font-body);
	font-weight: 600; font-size: 11px; cursor: pointer;
	letter-spacing: 0.04em; transition: all 0.18s;
	text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.core-wallet-bar button:hover:not(:disabled) {
	background: linear-gradient(180deg, rgba(50, 100, 220, 0.9), rgba(35, 75, 195, 0.95));
	box-shadow: 0 0 14px rgba(60, 116, 255, 0.3); transform: translateY(-1px);
}
.core-wallet-bar button:disabled { opacity: 0.4; cursor: default; }
.core-wallet-status {
	font-size: 10px; font-family: var(--font-mono); color: var(--text-dim);
}

/* ══════════════════════════════════════════════════════════
   DIAGNOSTICS BAR
   ══════════════════════════════════════════════════════════ */
.core-diagnostics-bar {
	margin: 5px 0 6px; font-size: 10px;
	display: flex; gap: 12px; align-items: center;
	font-family: var(--font-mono);
	padding: 4px 10px;
	background: rgba(6, 12, 30, 0.45);
	border: 1px solid rgba(30, 50, 80, 0.22);
	border-radius: var(--radius);
}
.core-diagnostics-bar strong {
	color: var(--accent-bright); letter-spacing: 0.06em;
	text-transform: uppercase; font-size: 9px;
}

/* ══════════════════════════════════════════════════════════
   NAV BUTTONS (inside slim HUD bar — toggle popups)
   ══════════════════════════════════════════════════════════ */
.core-tabs-bar { display: none; } /* legacy – replaced by .core-hud-nav */

.core-tab-btn {
	padding: 5px 12px;
	border-radius: 5px;
	border: 1px solid transparent;
	background: transparent;
	color: var(--text-dim); cursor: pointer;
	font-family: var(--font-display); font-size: 9px;
	font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
	transition: all 0.18s; position: relative;
	white-space: nowrap;
}
.core-tab-btn:hover {
	color: var(--text-bright);
	background: rgba(20, 40, 100, 0.45);
	border-color: rgba(60, 116, 255, 0.25);
}
.core-tab-btn.active {
	color: var(--accent-bright);
	background: rgba(10, 25, 75, 0.65);
	border-color: rgba(60, 116, 255, 0.50);
	box-shadow: 0 0 12px rgba(60, 116, 255, 0.15);
}
.core-tab-btn.active::after {
	content: '';
	position: absolute; bottom: -1px; left: 15%; right: 15%; height: 1px;
	background: var(--cyan); opacity: 0.8;
}

.core-tabs-container { display: none; } /* legacy */
.core-tab { display: none; } /* legacy sections hidden */

/* ══════════════════════════════════════════════════════════
   STATS ROW
   ══════════════════════════════════════════════════════════ */
.core-stats {
	display: flex; flex-wrap: wrap; gap: 8px;
	margin-bottom: 10px; font-size: 11px; font-family: var(--font-mono);
}
.core-stats > div {
	padding: 4px 10px;
	background: rgba(8, 14, 34, 0.55);
	border: 1px solid rgba(40, 65, 110, 0.32);
	border-radius: var(--radius);
}
.core-stats strong { color: var(--accent-bright); font-weight: 600; margin-right: 4px; }

/* ══════════════════════════════════════════════════════════
   TABLES (market, player, mining etc.)
   ══════════════════════════════════════════════════════════ */
.core-table {
	width: 100%; border-collapse: collapse;
	font-size: 11px; font-family: var(--font-body);
}
.core-table th, .core-table td {
	border: 1px solid rgba(28, 42, 76, 0.40); padding: 4px 6px; text-align: left;
}
.core-table thead { background: rgba(12, 20, 44, 0.82); }
.core-table thead th {
	font-family: var(--font-display); font-size: 9px; font-weight: 700;
	letter-spacing: 0.09em; text-transform: uppercase;
	color: var(--accent-bright); border-bottom: 2px solid var(--accent-dim);
}
.core-table tbody tr { transition: background 0.12s; }
.core-table tbody tr:hover { background: rgba(30, 60, 120, 0.28); }
.core-table tbody tr:nth-child(even) { background: rgba(6, 12, 28, 0.28); }
.core-table tbody tr:nth-child(even):hover { background: rgba(30, 60, 120, 0.28); }

/* ══════════════════════════════════════════════════════════
   PLAYER / SETTINGS / LOG  (inside HUD tabs)
   ══════════════════════════════════════════════════════════ */
.core-player-block h2,
.core-settings-block h2,
.core-log-block h2 {
	font-family: var(--font-display); font-size: 12px;
	font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
	color: var(--accent-bright); margin-top: 10px; margin-bottom: 6px;
	padding-bottom: 4px; border-bottom: 1px solid rgba(60, 116, 255, 0.15);
}
.core-log-block { margin-top: 8px; }
.core-log-output {
	background: rgba(2, 4, 11, 0.82); border: 1px solid var(--border-dim);
	border-radius: var(--radius); padding: 7px 12px;
	font-family: var(--font-mono); font-size: 10px;
	max-height: 80px; overflow-y: auto;
	white-space: pre-wrap; color: rgba(80, 200, 130, 0.88);
}
.core-settings-block label {
	font-family: var(--font-mono); font-size: 12px; cursor: pointer;
	display: inline-flex; align-items: center; gap: 6px; margin: 4px 0;
}
.core-settings-block input[type="checkbox"] {
	accent-color: var(--accent); width: 15px; height: 15px;
}

/* ══════════════════════════════════════════════════════════
   MODALS  (z-index 2000 — above all HUD panels)
   ══════════════════════════════════════════════════════════ */
.core-fleet-modal {
	position: fixed !important;
	left: 0; top: 0; width: 100%; height: 100%;
	z-index: 2000 !important;
	display: flex; align-items: center; justify-content: center;
}
.core-fleet-modal-backdrop {
	position: absolute; left: 0; top: 0; width: 100%; height: 100%;
	background: rgba(0,0,0,0.62); backdrop-filter: blur(4px);
}
.core-fleet-modal-content {
	position: relative; background: rgba(5, 10, 26, 0.97);
	border: 1px solid rgba(60, 116, 255, 0.45);
	border-radius: var(--radius-lg);
	width: 540px; max-width: 92vw; max-height: 85vh;
	overflow-y: auto; padding: 16px;
	box-shadow: 0 0 60px rgba(8,20,70,0.6), 0 0 24px rgba(60,116,255,0.12);
}
.core-fleet-modal-header {
	display: flex; justify-content: space-between; align-items: center;
	margin-bottom: 10px; font-family: var(--font-display);
	font-size: 12px; letter-spacing: 0.08em;
}
.core-fleet-modal-close,
.core-fleet-modal-action {
	padding: 5px 12px; border-radius: var(--radius);
	border: 1px solid var(--accent);
	background: linear-gradient(180deg, rgba(35, 75, 195, 0.65), rgba(22, 50, 135, 0.85));
	color: var(--text-bright); cursor: pointer;
	font-family: var(--font-body); font-weight: 600;
	font-size: 11px; transition: all 0.18s;
}
.core-fleet-modal-action { margin-right: 6px; }
.core-fleet-modal-close:hover,
.core-fleet-modal-action:hover {
	box-shadow: 0 0 12px rgba(60,116,255,0.3);
}
.core-fleet-modal-body {
	font-size: 11px; font-family: var(--font-mono);
}

/* ── Cargo Row ─────────────────────────────────────────── */
.core-fleet-cargo-row {
	display: grid;
	grid-template-columns: 90px 1fr 1fr auto auto auto;
	gap: 6px; align-items: center; margin-top: 6px;
}
.core-fleet-cargo-row input,
.core-fleet-cargo-row select {
	padding: 4px 8px; border-radius: var(--radius);
	border: 1px solid var(--border-dim); background: var(--bg-input);
	color: var(--text-bright); font-family: var(--font-mono);
	font-size: 11px; outline: none; transition: border-color 0.2s;
}
.core-fleet-cargo-row input:focus,
.core-fleet-cargo-row select:focus { border-color: var(--accent); }
.core-fleet-cargo-row input[type="range"] {
	padding: 0; background: transparent; accent-color: var(--accent);
}
.core-fleet-cargo-row button {
	padding: 4px 9px; border-radius: var(--radius);
	border: 1px solid var(--accent);
	background: linear-gradient(180deg, rgba(35,75,195,0.65), rgba(22,50,135,0.85));
	color: var(--text-bright); cursor: pointer;
	font-family: var(--font-body); font-weight: 600; font-size: 11px; transition: all 0.18s;
}
.core-fleet-cargo-row button:hover { box-shadow: 0 0 10px rgba(60,116,255,0.25); }

/* ── Cargo Lists ─────────────────────────────────────── */
.core-fleet-cargo-lists {
	display: flex; gap: 14px; margin: 10px 0 14px;
	font-size: 11px; font-family: var(--font-mono);
}
.core-fleet-cargo-list {
	flex: 1 1 0; border: 1px solid var(--border-dim);
	border-radius: var(--radius); padding: 7px 10px; background: var(--bg-input);
}
.core-fleet-cargo-list ul { margin: 4px 0 8px; padding-left: 18px; }

.core-fleet-ships-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
	gap: 8px;
	margin: 6px 0 10px;
}
.core-fleet-ship-card {
	border: 1px solid var(--border-dim);
	border-radius: var(--radius);
	background: rgba(4, 9, 22, 0.72);
	padding: 6px;
	text-align: center;
	cursor: pointer;
	transition: border-color 0.18s, box-shadow 0.18s, transform 0.18s;
}
.core-fleet-ship-card:hover {
	border-color: rgba(60, 116, 255, 0.55);
	box-shadow: 0 0 10px rgba(60, 116, 255, 0.2);
	transform: translateY(-1px);
}
.core-fleet-ship-card.is-selected {
	border-color: var(--accent);
	box-shadow: 0 0 12px rgba(60, 116, 255, 0.35);
	background: rgba(8, 18, 40, 0.88);
}
.core-fleet-ship-img {
	width: 100%;
	height: 70px;
	object-fit: cover;
	border-radius: 6px;
	border: 1px solid rgba(40, 80, 120, 0.45);
	background: rgba(2, 5, 14, 0.9);
	display: block;
}
.core-fleet-ship-img-fallback {
	color: var(--text-dim);
	font-size: 10px;
	line-height: 70px;
	text-align: center;
}
.core-fleet-ship-name {
	margin-top: 6px;
	font-size: 10px;
	line-height: 1.25;
	color: var(--text-bright);
	word-break: break-word;
}
.core-fleet-ship-qty {
	margin-top: 2px;
	font-size: 10px;
	color: var(--text-dim);
}
.core-fleet-ship-model {
	margin-top: 4px;
	font-size: 10px;
	color: var(--text-dim);
	line-height: 1.2;
	word-break: break-word;
}
.core-fleet-ship-choose {
	margin-top: 6px;
	width: 100%;
	padding: 4px 8px;
	border-radius: 6px;
	border: 1px solid rgba(60, 116, 255, 0.45);
	background: rgba(18, 38, 88, 0.8);
	color: var(--text-bright);
	font-family: var(--font-body);
	font-size: 10px;
	font-weight: 600;
	cursor: pointer;
	transition: border-color 0.18s, box-shadow 0.18s;
}
.core-fleet-ship-choose:hover {
	border-color: var(--accent);
	box-shadow: 0 0 9px rgba(60, 116, 255, 0.28);
}

.core-fleet-composition-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
	gap: 8px;
	margin: 6px 0 10px;
}
.core-fleet-composition-card {
	border: 1px solid var(--border-dim);
	border-radius: var(--radius);
	background: rgba(4, 9, 22, 0.76);
	padding: 6px;
	text-align: center;
}
.core-fleet-composition-img {
	width: 100%;
	height: 86px;
	object-fit: cover;
	border-radius: 6px;
	border: 1px solid rgba(40, 80, 120, 0.45);
	background: rgba(2, 5, 14, 0.9);
	display: block;
}
.core-fleet-composition-img-fallback {
	font-size: 11px;
	line-height: 86px;
	color: var(--text-dim);
	text-align: center;
}
.core-fleet-composition-name {
	margin-top: 6px;
	font-size: 10px;
	line-height: 1.25;
	color: var(--text-bright);
	word-break: break-word;
}
.core-fleet-composition-qty {
	margin-top: 2px;
	font-size: 10px;
	color: var(--text-dim);
}
.core-fleet-composition-mint {
	margin-top: 2px;
	font-size: 9px;
	color: var(--text-dim);
	word-break: break-all;
}
.core-fleet-composition-loading {
	font-size: 10px;
	color: var(--text-dim);
	margin-top: 4px;
}

/* ── Showroom ───────────────────────────────────────── */
.core-showroom-wrap {
	display: block;
}
.core-showroom-head {
	font-family: var(--font-body);
	font-size: 12px;
	font-weight: 700;
	color: var(--text-bright);
	margin-bottom: 10px;
}
.core-showroom-empty {
	padding: 10px;
	border: 1px dashed var(--border-dim);
	border-radius: var(--radius);
	color: var(--text-dim);
	font-size: 11px;
}
.core-showroom-tier {
	margin-bottom: 12px;
}
.core-showroom-tier-title {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: var(--cyan);
	margin-bottom: 6px;
}
.core-showroom-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
	gap: 8px;
}
.core-showroom-card {
	border: 1px solid var(--border-dim);
	border-radius: var(--radius);
	background: rgba(6, 12, 28, 0.85);
	padding: 8px;
	text-align: left;
	cursor: pointer;
	transition: border-color 0.18s, box-shadow 0.18s, transform 0.18s;
	color: var(--text-bright);
}
.core-showroom-card:hover {
	border-color: rgba(60, 116, 255, 0.55);
	box-shadow: 0 0 10px rgba(60, 116, 255, 0.25);
	transform: translateY(-1px);
}
.core-showroom-card-img {
	width: 100%;
	height: 92px;
	object-fit: cover;
	border-radius: 6px;
	border: 1px solid rgba(40, 80, 120, 0.45);
	background: rgba(2, 5, 14, 0.95);
	display: block;
}
.core-showroom-card-fallback {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--text-dim);
	font-family: var(--font-display);
	font-size: 11px;
}
.core-showroom-card-name {
	margin-top: 6px;
	font-size: 11px;
	font-weight: 700;
	line-height: 1.2;
}
.core-showroom-card-meta {
	margin-top: 3px;
	font-size: 10px;
	color: var(--text-dim);
}

.core-showroom-modal {
	position: fixed;
	inset: 0;
	z-index: 980;
}
.core-showroom-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	backdrop-filter: blur(3px);
}
.core-showroom-modal-card {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: min(1080px, calc(100vw - 30px));
	max-height: calc(100vh - 42px);
	overflow: hidden;
	border: 1px solid var(--border-active);
	border-radius: 12px;
	background: rgba(4, 10, 24, 0.97);
	box-shadow: 0 18px 80px rgba(0, 0, 0, 0.55);
	display: flex;
	flex-direction: column;
}
.core-showroom-modal-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 12px;
	border-bottom: 1px solid var(--border-dim);
	font-size: 12px;
	font-family: var(--font-body);
}
.core-showroom-modal-head button {
	border: 1px solid var(--border-dim);
	border-radius: 6px;
	background: rgba(15, 25, 55, 0.85);
	color: var(--text-bright);
	padding: 5px 10px;
	cursor: pointer;
}
.core-showroom-modal-body {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 10px;
	padding: 10px;
	overflow: auto;
}
.core-showroom-viewer {
	min-height: 330px;
	border: 1px solid rgba(60, 116, 255, 0.35);
	border-radius: 8px;
	overflow: hidden;
}
.core-showroom-chain {
	border: 1px solid var(--border-dim);
	border-radius: 8px;
	background: rgba(3, 8, 20, 0.85);
	padding: 10px;
	font-size: 11px;
	font-family: var(--font-mono);
	color: var(--text-bright);
	max-height: 540px;
	overflow: auto;
}
.core-showroom-chain-empty {
	color: var(--text-dim);
}
.core-showroom-chain-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 4px;
	margin-bottom: 8px;
}
.core-showroom-chain-section {
	margin-top: 8px;
}
.core-showroom-nft-thumb {
	display: block;
	width: 100%;
	max-height: 180px;
	object-fit: cover;
	border-radius: 6px;
	border: 1px solid rgba(68, 116, 185, 0.42);
	background: rgba(4, 10, 24, 0.8);
}
.core-showroom-chain pre {
	margin: 6px 0 0;
	padding: 8px;
	background: rgba(2, 6, 16, 0.85);
	border: 1px solid rgba(50, 80, 140, 0.35);
	border-radius: 6px;
	max-height: 220px;
	overflow: auto;
	white-space: pre-wrap;
	word-break: break-word;
}

/* ══════════════════════════════════════════════════════════
   NEW CARGO MODAL  (.cfc-* classes)
   ══════════════════════════════════════════════════════════ */

/* Wider modal for the cargo UI */
.cfc-modal {
	width: 760px !important;
	max-width: 96vw !important;
}

/* Header */
.cfc-header { padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,0.07); }
.cfc-header-title { display: flex; align-items: center; gap: 10px; }
.cfc-icon {
	font-size: 22px; width: 38px; height: 38px;
	display: flex; align-items: center; justify-content: center;
	background: rgba(60,116,255,0.15); border: 1px solid rgba(60,116,255,0.3);
	border-radius: 8px;
}
.cfc-fleet-name { font-size: 13px; font-weight: 700; color: #fff; letter-spacing: 0.04em; }
.cfc-sb-name    { font-size: 10px; color: rgba(255,255,255,0.45); letter-spacing: 0.06em; margin-top: 1px; }

/* Inventory panels */
.cfc-inv-grid { display: flex; gap: 12px; margin-bottom: 14px; }
.cfc-inv-panel {
	flex: 1 1 0; padding: 8px 10px;
	background: rgba(255,255,255,0.02);
	border: 1px solid rgba(255,255,255,0.07); border-radius: 8px;
	max-height: 150px; overflow-y: auto;
}
.cfc-inv-label {
	font-size: 9px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
	color: rgba(255,255,255,0.35); margin-bottom: 4px; margin-top: 2px;
}

/* Divider */
.cfc-divider {
	display: flex; align-items: center; gap: 8px;
	margin: 14px 0 10px; color: rgba(255,255,255,0.25);
	font-size: 9px; font-weight: 700; letter-spacing: 0.12em;
}
.cfc-divider::before, .cfc-divider::after {
	content: ''; flex: 1; height: 1px; background: rgba(255,255,255,0.08);
}

/* Consumable rows grid */
.cfc-cons-grid { display: flex; flex-direction: column; gap: 6px; margin-bottom: 4px; }
.cfc-cons-row {
	display: grid;
	grid-template-columns: 90px 100px 1fr;
	gap: 8px; align-items: center;
	padding: 6px 8px; border-radius: 8px;
	background: rgba(255,255,255,0.02);
	border: 1px solid rgba(255,255,255,0.05);
	border-left: 3px solid var(--row-accent, #3c74ff);
	transition: background 0.15s;
}
.cfc-cons-row:hover { background: rgba(255,255,255,0.04); }
.cfc-cons-label {
	font-size: 11px; font-weight: 600; color: #fff;
	font-family: var(--font-mono); letter-spacing: 0.04em;
}
.cfc-cons-row input[type="number"] {
	padding: 4px 8px; border-radius: 6px; width: 100%;
	border: 1px solid rgba(255,255,255,0.12); background: rgba(0,0,0,0.3);
	color: #fff; font-family: var(--font-mono); font-size: 11px;
	outline: none; box-sizing: border-box; transition: border-color 0.2s;
}
.cfc-cons-row input[type="number"]:focus { border-color: var(--row-accent, #3c74ff); }
.cfc-cons-row input[type="number"]:disabled { opacity: 0.35; cursor: not-allowed; }

/* Button group inside rows */
.cfc-cons-btns { display: flex; gap: 4px; }
.cfc-btn {
	padding: 4px 9px; border-radius: 5px; border: 1px solid rgba(255,255,255,0.15);
	font-size: 10px; font-weight: 700; cursor: pointer;
	font-family: var(--font-body); letter-spacing: 0.04em;
	transition: all 0.16s; white-space: nowrap;
}
.cfc-btn:disabled { opacity: 0.3; cursor: not-allowed; pointer-events: none; }
.cfc-btn-load   { background: rgba(46,204,113,0.18); color: #2ecc71; border-color: rgba(46,204,113,0.35); }
.cfc-btn-unload { background: rgba(231,76,60,0.18);  color: #e74c3c; border-color: rgba(231,76,60,0.35);  }
.cfc-btn-max    { background: rgba(60,116,255,0.22); color: #7ba9ff; border-color: rgba(60,116,255,0.45); }
.cfc-btn-half        { background: rgba(155,89,182,0.18); color: #c39bd3; border-color: rgba(155,89,182,0.35); }
.cfc-btn-max-unload  { background: rgba(230,126,34,0.18);  color: #e67e22; border-color: rgba(230,126,34,0.35);  }
.cfc-btn-load:hover   { background: rgba(46,204,113,0.35);  box-shadow: 0 0 8px rgba(46,204,113,0.25); }
.cfc-btn-unload:hover { background: rgba(231,76,60,0.35);   box-shadow: 0 0 8px rgba(231,76,60,0.25);  }
.cfc-btn-max:hover    { background: rgba(60,116,255,0.42);  box-shadow: 0 0 8px rgba(60,116,255,0.3);  }
.cfc-btn-half:hover        { background: rgba(155,89,182,0.35);  box-shadow: 0 0 8px rgba(155,89,182,0.25); }
.cfc-btn-max-unload:hover  { background: rgba(230,126,34,0.35);  box-shadow: 0 0 8px rgba(230,126,34,0.25); }

/* Unload All */
.cfc-unload-all-row { display: flex; justify-content: center; margin: 10px 0 4px; }
.cfc-btn-unload-all {
	width: 100%; padding: 8px 16px; border-radius: 8px;
	border: 1px solid rgba(231,76,60,0.5);
	background: rgba(231,76,60,0.12);
	color: #e74c3c; font-weight: 700; font-size: 11px; letter-spacing: 0.06em;
	cursor: pointer; font-family: var(--font-body); transition: all 0.18s;
}
.cfc-btn-unload-all:hover {
	background: rgba(231,76,60,0.28); box-shadow: 0 0 14px rgba(231,76,60,0.25);
}

/* Resource / cargo-storage row */
.cfc-res-row {
	display: flex; gap: 8px; align-items: center;
	padding: 8px; border-radius: 8px;
	background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.07);
}
.cfc-res-select {
	flex: 1; min-width: 0; padding: 5px 8px; border-radius: 6px;
	border: 1px solid rgba(255,255,255,0.15); background: rgba(0,0,0,0.35);
	color: #fff; font-family: var(--font-mono); font-size: 11px; outline: none;
}
.cfc-res-select:focus { border-color: var(--accent); }
.cfc-res-row input[type="number"] {
	width: 90px; padding: 5px 8px; border-radius: 6px;
	border: 1px solid rgba(255,255,255,0.12); background: rgba(0,0,0,0.3);
	color: #fff; font-family: var(--font-mono); font-size: 11px;
	outline: none; transition: border-color 0.2s; flex-shrink: 0;
}
.cfc-res-row input[type="number"]:focus { border-color: var(--accent); }

/* ── Mining Row ─────────────────────────────────────── */
.core-fleet-mining-row {
	display: flex; align-items: center; gap: 10px; margin-top: 8px;
}
.core-fleet-mining-row label {
	min-width: 70px; font-family: var(--font-mono); font-size: 11px; color: var(--text-dim);
}
.core-fleet-mining-row select {
	flex: 1 1 auto; padding: 4px 8px; border-radius: var(--radius);
	border: 1px solid var(--border-dim); background: var(--bg-input);
	color: var(--text-bright); font-family: var(--font-mono); font-size: 11px;
}
.core-fleet-mining-estimate {
	font-size: 11px; color: var(--text-dim); font-family: var(--font-mono);
}
.core-fleet-mining-warning {
	margin-top: 4px; color: #ff8888; font-weight: 700; font-family: var(--font-body);
}

/* ══════════════════════════════════════════════════════════
   FULLSCREEN MAP MODE  (⛶ button – legacy behaviour kept)
   ══════════════════════════════════════════════════════════ */
body.core-body-fs { overflow: hidden !important; }
.core-map3d-wrapper.core-map-fullscreen { z-index: 9990 !important; }
.core-map3d-wrapper.core-map-fullscreen .core-map-controls {
	right: 16px !important; bottom: 16px !important; z-index: 9999 !important;
}

/* ── Fly mode active ───────────────────────────────────── */
.core-map-control-active {
	background: rgba(20, 90, 50, 0.92) !important;
	border-color: var(--green) !important;
	box-shadow: 0 0 14px var(--green-glow) !important;
}

/* ── Fly hint bar ── */
.core-fs-fly-hint {
	display: none; position: fixed;
	bottom: 60px; left: 50%; transform: translateX(-50%);
	background: rgba(3, 9, 24, 0.90);
	border: 1px solid rgba(60, 140, 255, 0.28);
	border-radius: var(--radius); padding: 6px 16px;
	font-family: var(--font-mono); font-size: 10px; color: var(--cyan);
	letter-spacing: 0.04em; z-index: 400; pointer-events: none;
	white-space: nowrap; backdrop-filter: blur(6px);
}

/* ── FS top bar ── */
.core-fs-top-bar {
	display: none; position: fixed;
	top: 0; left: 0; right: 0; height: 36px;
	background: linear-gradient(180deg, rgba(4,8,20,0.92) 0%, rgba(4,8,20,0) 100%);
	z-index: 9997; align-items: center;
	justify-content: space-between; padding: 0 16px; pointer-events: auto;
}
.core-fs-info { font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); }
.core-fs-info strong { color: var(--accent-bright); }
.core-fs-exit-btn {
	padding: 4px 12px; border-radius: var(--radius);
	border: 1px solid var(--red); background: rgba(70,18,18,0.75);
	color: var(--text-bright); font-family: var(--font-mono); font-size: 10px;
	cursor: pointer; transition: all 0.18s;
}
.core-fs-exit-btn:hover {
	background: rgba(110,26,26,0.9); box-shadow: 0 0 12px var(--red-glow);
}

/* ── FS side panels (legacy collapsible) ── */
.core-fs-panel {
	display: none; position: fixed;
	top: 40px; bottom: 60px; width: 280px;
	z-index: 9996; pointer-events: auto; transition: transform 0.3s ease;
}
.core-map3d-wrapper.core-map-fullscreen .core-fs-panel { display: flex; flex-direction: column; }
.core-fs-panel-left  { left: 0;  transform: translateX(-240px); }
.core-fs-panel-right { right: 0; transform: translateX(240px); }
.core-fs-panel-left.core-fs-panel-open  { transform: translateX(0); }
.core-fs-panel-right.core-fs-panel-open { transform: translateX(0); }

.core-fs-panel-toggle {
	cursor: pointer; padding: 8px 12px;
	background: rgba(5, 11, 28, 0.92);
	border: 1px solid var(--border-dim);
	font-family: var(--font-display); font-size: 9px; font-weight: 700;
	letter-spacing: 0.1em; text-transform: uppercase; color: var(--cyan);
	text-align: center; backdrop-filter: blur(8px); transition: background 0.18s; flex-shrink: 0;
}
.core-fs-panel-left  .core-fs-panel-toggle {
	border-radius: 0 var(--radius) var(--radius) 0;
	position: absolute; right: 0; top: 0;
	writing-mode: vertical-rl; transform: translateX(100%); padding: 14px 6px;
}
.core-fs-panel-right .core-fs-panel-toggle {
	border-radius: var(--radius) 0 0 var(--radius);
	position: absolute; left: 0; top: 0;
	writing-mode: vertical-rl; transform: translateX(-100%) rotate(180deg); padding: 14px 6px;
}
.core-fs-panel-toggle:hover { background: rgba(18,32,68,0.95); color: var(--text-bright); }
.core-fs-panel-content {
	flex: 1; overflow-y: auto;
	background: rgba(4,8,20,0.92); border: 1px solid var(--border-dim);
	backdrop-filter: blur(10px); padding: 8px;
}
.core-fs-panel-left  .core-fs-panel-content { border-radius: 0 var(--radius) var(--radius) 0; border-left: none; }
.core-fs-panel-right .core-fs-panel-content { border-radius: var(--radius) 0 0 var(--radius); border-right: none; }
.core-fs-section-title {
	font-family: var(--font-display); font-size: 9px; font-weight: 700;
	letter-spacing: 0.1em; color: var(--accent-bright); padding: 4px 6px; margin-bottom: 4px;
	border-bottom: 1px solid rgba(60,116,255,0.14);
}
.core-fs-item {
	padding: 6px 8px; margin-bottom: 2px; border-radius: 4px;
	cursor: pointer; transition: background 0.14s; border-left: 2px solid transparent;
}
.core-fs-item:hover { background: var(--bg-hover); border-left-color: var(--accent); }
.core-fs-item-name {
	font-family: var(--font-body); font-size: 11px; font-weight: 600;
	color: var(--text-bright); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.core-fs-item-detail { font-family: var(--font-mono); font-size: 10px; color: var(--text-dim); margin-top: 1px; }

/* ── Map Legend ─────────────────────────────────────────── */
.core-map-legend { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; }
.core-map-legend-box { display: inline-block; width: 10px; height: 10px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.12); }
.core-map-legend-friend { background: var(--accent); box-shadow: 0 0 6px var(--border-glow); }
.core-map-legend-enemy  { background: var(--red);    box-shadow: 0 0 6px var(--red-glow); }
.core-map-legend-fleet  { background: var(--green);  box-shadow: 0 0 6px var(--green-glow); }
.core-map-axis-info { font-size: 10px; font-family: var(--font-mono); margin-bottom: 4px; color: var(--text-dim); }
.core-map-fleet-selector-row {
	display: flex; justify-content: space-between; align-items: center;
	padding: 7px 0; border-bottom: 1px solid rgba(28,42,72,0.38);
	font-family: var(--font-mono); font-size: 11px;
}
.core-map-fleet-selector-actions { display: flex; gap: 5px; flex-wrap: wrap; }
.core-map-fleet-selector-row:last-child { border-bottom: none; }

/* ── Legacy 2D map cells ─────────────────────────────── */
.core-map-scroll-wrapper {
	overflow: visible; border: 1px solid var(--border-dim);
	background: radial-gradient(circle at center, #0c1328 0%, #03050d 70%);
	display: inline-block; padding: 6px; border-radius: var(--radius);
}
.core-map-table { border-collapse: collapse; }
.core-map-cell {
	width: 10px; height: 10px;
	border: 1px solid rgba(12,16,32,0.8); background: rgba(5,7,17,0.6);
	position: relative; overflow: visible;
	transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.core-map-cell:hover { transform: scale(1.2); box-shadow: 0 0 8px rgba(120,160,255,0.4); z-index: 2; }
.core-map-cell-friend { background: var(--accent);  box-shadow: 0 0 8px var(--border-glow); }
.core-map-cell-enemy  { background: var(--red);     box-shadow: 0 0 8px var(--red-glow); }
.core-map-cell-fleet  { background: var(--green);   box-shadow: 0 0 8px var(--green-glow); border-color: rgba(50,201,107,0.5); }
.core-map-cell-inner  { position: relative; width: 100%; height: 100%; }
.core-map-sb-menu     { position: absolute; left: -18px; top: 50%; transform: translateY(-50%); display: flex; align-items: center; }
.core-map-sb-inventory {
	width: 16px; height: 16px; border-radius: 3px;
	border: 1px solid var(--accent); background: var(--accent-dim);
	color: var(--text-bright); font-size: 11px; line-height: 1; padding: 0; cursor: pointer;
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */
@media (max-width: 960px) {
	:root { --hud-w: 240px; }
	.core-hud-topbar { left: 0; right: 0; }
}
@media (max-width: 640px) {
	:root { --hud-w: 0px; }
	.core-fleet-block, .core-bases-block { display: none !important; }
	.core-hud-topbar { left: 0; right: 0; }
}

/* ══════════════════════════════════════════════════════════
   AUTOMATION PANEL  (novagrid-auto.js)
   ══════════════════════════════════════════════════════════ */

/* ── Wide popup for automation ─────────────────────────── */
.core-popup-panel--wide {
	width: min(1520px, calc(100vw - var(--hud-w) * 2 - 16px));
	max-width: calc(100vw - var(--hud-w) * 2 - 16px);
	clip-path: none;
	overflow: visible;
}
.core-popup-body--auto {
	padding: 0;
	overflow: visible !important;
	max-height: none !important;
	position: relative;
	min-height: calc(100vh - 220px);
}
.core-popup-body--auto > #core-auto-panel {
	position: relative;
	width: 100%;
	min-width: 0;
	height: 100%;
}

/* ── Root container ─────────────────────────────────────── */
.auto-root {
	display: flex;
	flex-direction: column;
	gap: 0;
	width: 100%;
	min-width: 0;
	font-family: var(--font-mono, 'Courier New', monospace);
	font-size: 13px;
	color: var(--text-main, #a8bbd8);
}

/* ── Controls bar ───────────────────────────────────────── */
.auto-controls {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 16px;
	border-bottom: 1px solid rgba(40, 65, 120, 0.35);
	background: rgba(4, 9, 26, 0.55);
}
.auto-engine-status {
	font-size: 12px;
	letter-spacing: 0.06em;
	color: var(--text-dim, #6a7fa0);
}
.auto-controls.auto-running .auto-engine-status {
	color: #4aff9e;
}

/* ── Buttons ────────────────────────────────────────────── */
.auto-btn {
	padding: 4px 12px;
	border-radius: 4px;
	border: 1px solid rgba(60, 116, 255, 0.35);
	background: rgba(10, 22, 56, 0.75);
	color: var(--text-main, #a8bbd8);
	font-size: 12px;
	font-family: var(--font-mono, 'Courier New', monospace);
	cursor: pointer;
	transition: all 0.14s;
	white-space: nowrap;
}
.auto-btn:hover {
	border-color: var(--accent, #3c74ff);
	color: var(--text-bright, #e4edff);
	box-shadow: 0 0 8px rgba(60, 116, 255, 0.22);
}
.auto-btn-sm { padding: 4px 9px; font-size: 11px; }
.auto-btn-primary {
	border-color: rgba(60, 200, 255, 0.6);
	background: rgba(20, 60, 140, 0.70);
	color: #b8d8ff;
}
.auto-btn-primary:hover { background: rgba(30, 80, 180, 0.80); }
.auto-btn-start {
	border-color: rgba(70, 255, 130, 0.55);
	background: rgba(20, 80, 45, 0.70);
	color: #7affb8;
}
.auto-btn-start:hover { background: rgba(30, 110, 60, 0.80); }
.auto-btn-stop {
	border-color: rgba(255, 80, 80, 0.55);
	background: rgba(80, 20, 20, 0.70);
	color: #ff9999;
}
.auto-btn-stop:hover { background: rgba(110, 30, 30, 0.80); }
.auto-btn-danger {
	border-color: rgba(255, 80, 80, 0.35);
	color: #ff8888;
}
.auto-btn-danger:hover { border-color: #ff4444; color: #ffbbbb; }
.auto-btn-add {
	border-color: rgba(60, 200, 100, 0.45);
	color: #88ffbb;
}
.auto-btn-add:hover { border-color: rgba(60, 200, 100, 0.8); }
.auto-btn-flowchart {
	border-color: rgba(180, 120, 255, 0.45);
	color: #cfa0ff;
}
.auto-btn-flowchart:hover { border-color: rgba(180, 120, 255, 0.8); }

/* ── Fleet list ─────────────────────────────────────────── */
.auto-fleet-list {
	display: flex;
	flex-direction: column;
	max-height: calc(100vh - 250px);
	overflow-y: auto;
}
.auto-empty {
	padding: 24px;
	color: var(--text-dim, #6a7fa0);
	text-align: center;
	font-size: 12px;
}
.auto-fleet-row {
	border-bottom: 1px solid rgba(35, 55, 100, 0.30);
}
.auto-fleet-row:last-child { border-bottom: none; }
.auto-fleet-selected > .auto-fleet-header {
	background: rgba(20, 40, 90, 0.55);
}
.auto-fleet-header {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 16px;
	cursor: pointer;
	transition: background 0.12s;
}
.auto-fleet-header:hover { background: rgba(16, 32, 72, 0.50); }
.auto-fleet-name {
	font-size: 13px;
	font-weight: 600;
	color: var(--text-bright, #e4edff);
	min-width: 120px;
}
.auto-fleet-state {
	font-size: 11px;
	padding: 2px 7px;
	border-radius: 3px;
	border: 1px solid rgba(60, 116, 255, 0.28);
	background: rgba(12, 24, 60, 0.70);
	color: var(--text-dim, #6a7fa0);
}
.auto-fleet-state.auto-state-mineasteroid {
	border-color: rgba(255, 180, 40, 0.5);
	color: #ffd080;
	background: rgba(60, 40, 10, 0.60);
}
.auto-fleet-state.auto-state-idle {
	border-color: rgba(60, 200, 100, 0.4);
	color: #88ffbb;
	background: rgba(15, 50, 25, 0.60);
}
.auto-fleet-state.auto-state-movewarp,
.auto-fleet-state.auto-state-movesubwarp {
	border-color: rgba(80, 180, 255, 0.4);
	color: #80d4ff;
	background: rgba(10, 40, 70, 0.60);
}
.auto-fleet-coords {
	font-size: 11px;
	color: var(--text-dim, #6a7fa0);
	font-family: var(--font-mono, 'Courier New', monospace);
}
.auto-status-badge {
	flex: 1;
	font-size: 12px;
	color: #90acd4;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.auto-fleet-actions {
	display: flex;
	gap: 6px;
	flex-shrink: 0;
}

/* ── Mission list (expanded) ────────────────────────────── */
.auto-mission-list {
	padding: 6px 16px 10px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	background: rgba(4, 10, 28, 0.45);
}
.auto-mission-empty {
	padding: 10px 16px;
	color: var(--text-dim, #6a7fa0);
	font-size: 11px;
	font-style: italic;
	background: rgba(4, 10, 28, 0.45);
}
.auto-mission-row {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 7px 10px;
	border-radius: 5px;
	border: 1px solid rgba(50, 80, 140, 0.35);
	background: rgba(8, 16, 42, 0.60);
	transition: border-color 0.13s;
}
.auto-mission-row:hover { border-color: rgba(60, 116, 255, 0.45); }
.auto-mission-disabled { opacity: 0.42; }
.auto-mission-type {
	font-size: 18px;
	flex-shrink: 0;
	width: 24px;
	text-align: center;
}
.auto-mission-info {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
.auto-mission-title {
	font-size: 12px;
	font-weight: 600;
	color: var(--text-bright, #e4edff);
	letter-spacing: 0.05em;
}
.auto-mission-multiplier {
	display: inline-block;
	margin-left: 6px;
	padding: 1px 6px;
	border-radius: 10px;
	border: 1px solid rgba(180, 120, 255, 0.45);
	background: rgba(60, 30, 100, 0.45);
	color: #cfa0ff;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.04em;
	vertical-align: middle;
}
.auto-mission-detail {
	font-size: 11px;
	color: var(--text-dim, #6a7fa0);
	line-height: 1.45;
}
.auto-mission-repeat {
	font-size: 11px;
	color: #80aae0;
}
.auto-mission-btns {
	display: flex;
	gap: 4px;
	flex-shrink: 0;
}

/* ── Log section ────────────────────────────────────────── */
.auto-log-section {
	border-top: 1px solid rgba(35, 55, 100, 0.35);
	background: rgba(2, 5, 15, 0.60);
}
.auto-log-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 7px 16px 5px;
	font-size: 10px;
	color: var(--text-dim, #6a7fa0);
	border-bottom: 1px solid rgba(35, 55, 100, 0.28);
}
.auto-log-output {
	margin: 0;
	padding: 8px 16px;
	font-size: 11px;
	font-family: var(--font-mono, 'Courier New', monospace);
	color: #708aa8;
	max-height: 120px;
	overflow-y: auto;
	white-space: pre-wrap;
	word-break: break-all;
	line-height: 1.5;
}

/* ── Overlay & Popup base ───────────────────────────────── */
.auto-overlay {
	position: absolute;
	inset: 0;
	z-index: 1100;
	background: rgba(0, 4, 18, 0.75);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	box-sizing: border-box;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	animation: fadeIn 0.15s ease both;
	overflow: auto;
}
@keyframes fadeIn { from { opacity:0 } to { opacity:1 } }

/* ── Inline panels (replace overlay popups inside AUTO list) ────────────── */
.auto-inline-panel {
	padding: 8px 16px 12px;
	background: rgba(4, 10, 28, 0.45);
	border-top: 1px solid rgba(35, 55, 100, 0.30);
}
.auto-inline-panel .auto-popup {
	position: relative;
	margin: 0;
	max-width: 100%;
	width: 100%;
	clip-path: none;
	animation: none;
	box-sizing: border-box;
}
.auto-inline-panel .auto-popup-body {
	padding: 12px;
}
.auto-inline-panel .auto-flowchart-popup,
.auto-inline-panel .auto-edit-popup {
	max-height: none;
	min-height: 0;
}

.auto-popup {
	position: relative;
	margin-left: auto;
	margin-right: auto;
	background: rgba(3, 7, 22, 0.97);
	border: 1px solid rgba(60, 116, 255, 0.45);
	border-radius: 10px;
	box-shadow:
		0 0 0 1px rgba(60, 116, 255, 0.08),
		0 30px 80px rgba(0, 0, 0, 0.70),
		0 0 60px rgba(25, 55, 140, 0.12);
	backdrop-filter: blur(24px) saturate(1.6);
	-webkit-backdrop-filter: blur(24px) saturate(1.6);
	overflow: hidden;
	animation: popupIn 0.20s cubic-bezier(0.22, 1, 0.36, 1) both;
	clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 0 100%);
}
.auto-popup::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0; height: 1px;
	background: linear-gradient(90deg, transparent, var(--accent, #3c74ff) 20%, var(--cyan, #00e5ff) 50%, var(--accent, #3c74ff) 80%, transparent);
	opacity: 0.85; z-index: 2; pointer-events: none;
}
.auto-popup-header {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 16px 9px;
	border-bottom: 1px solid rgba(40, 65, 120, 0.40);
	background: rgba(4, 9, 26, 0.70);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--accent-bright, #7db8ff);
}
.auto-popup-body {
	overflow-y: auto;
	padding: 16px;
}

/* ── Runtime status ─────────────────────────────────────── */
.auto-runtime-status {
	padding: 8px 16px;
	font-size: 12px;
	color: #80aad0;
	border-bottom: 1px solid rgba(40, 65, 120, 0.30);
	background: rgba(4, 10, 30, 0.50);
}
.auto-flow-estimates {
	padding: 8px 10px 4px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	background: rgba(5, 12, 35, 0.36);
	border-bottom: 1px solid rgba(40, 65, 120, 0.24);
}
.auto-flow-estimates .auto-runtime-status {
	margin: 0;
	padding: 8px 10px;
	border: 1px solid rgba(60, 116, 255, 0.26);
	border-radius: 6px;
	background: rgba(10, 20, 52, 0.52);
}
.auto-error { color: #ff7777; }

/* ── Flowchart popup ────────────────────────────────────── */
.auto-flowchart-popup {
	width: min(760px, calc(100% - 24px));
	max-height: calc(100% - 24px);
	min-height: min(62vh, calc(100% - 24px));
	display: flex;
	flex-direction: column;
}
.auto-flowchart-body {
	overflow-y: auto;
	max-height: calc(100% - 100px);
}
.flow-chart {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 16px 8px;
	gap: 0;
}
.flow-node {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 9px 16px;
	border-radius: 7px;
	border: 1px solid rgba(60, 116, 255, 0.32);
	background: rgba(8, 18, 50, 0.75);
	width: 100%;
	max-width: 340px;
	transition: border-color 0.13s;
	position: relative;
}
.flow-node:hover { border-color: rgba(60, 116, 255, 0.60); }
.flow-icon {
	font-size: 20px;
	width: 28px;
	text-align: center;
	flex-shrink: 0;
}
.flow-body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
.flow-label {
	font-size: 12px;
	font-weight: 600;
	color: var(--text-bright, #e4edff);
}
.flow-desc {
	font-size: 10px;
	color: var(--text-dim, #6a7fa0);
	white-space: pre-line;
}
.flow-arrow {
	color: rgba(60, 116, 255, 0.50);
	font-size: 16px;
	padding: 2px 0;
	user-select: none;
}
/* Flow node variants */
.flow-start    { border-color: rgba(60, 200, 100, 0.45); background: rgba(15, 50, 25, 0.60); }
.flow-dock,
.flow-undock   { border-color: rgba(80, 180, 255, 0.38); }
.flow-load,
.flow-unload   { border-color: rgba(255, 190, 60, 0.38); }
.flow-mine,
.flow-stop     { border-color: rgba(255, 160, 40, 0.45); background: rgba(50, 30, 5, 0.65); }
.flow-move     { border-color: rgba(80, 200, 255, 0.38); }
.flow-wait     { border-color: rgba(160, 100, 255, 0.38); }
.flow-repeat   { border-color: rgba(60, 200, 100, 0.38); }
.flow-done     { border-color: rgba(60, 255, 120, 0.55); background: rgba(15, 60, 25, 0.70); }

/* ── Edit / Add mission popup ───────────────────────────── */
.auto-edit-popup {
	width: min(980px, calc(100% - 24px));
	max-height: calc(100% - 24px);
	min-height: min(70vh, calc(100% - 24px));
	display: flex;
	flex-direction: column;
}
.auto-edit-body {
	overflow-y: auto;
	flex: 1;
	padding: 0 20px 20px;
	max-height: calc(100% - 60px);
}
.auto-edit-form {
	display: flex;
	flex-direction: column;
	gap: 0;
}
.auto-form-section-title {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(60, 116, 255, 0.70);
	padding: 14px 0 5px;
	border-bottom: 1px solid rgba(35, 55, 100, 0.35);
	margin-bottom: 4px;
}
.auto-mine-fields {
	margin: 0 0 4px;
	border: 1px solid rgba(50, 80, 140, 0.30);
	border-radius: 6px;
	padding: 4px 12px 10px;
	background: rgba(5, 12, 35, 0.40);
}
.auto-mine-fields legend {
	font-size: 10px;
	color: #80a8d8;
	letter-spacing: 0.06em;
	padding: 0 6px;
}
.auto-form-row {
	display: grid;
	grid-template-columns: 160px 1fr;
	align-items: start;
	gap: 10px;
	padding: 8px 0;
	border-bottom: 1px solid rgba(35, 55, 100, 0.20);
}
.auto-form-row:last-child { border-bottom: none; }
.auto-form-row label {
	font-size: 12px;
	color: var(--text-dim, #6a7fa0);
	padding-top: 6px;
}
.auto-form-row--picker { align-items: start; }
.auto-form-row input[type="text"],
.auto-form-row input[type="number"],
.auto-form-row select {
	padding: 6px 10px;
	background: rgba(5, 12, 38, 0.85);
	border: 1px solid rgba(50, 80, 140, 0.50);
	border-radius: 5px;
	color: var(--text-bright, #e4edff);
	font-size: 13px;
	font-family: var(--font-mono, 'Courier New', monospace);
	width: 100%;
	box-sizing: border-box;
	transition: border-color 0.13s, box-shadow 0.13s;
}

.auto-transport-manifest {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 4px 0 8px;
}
.auto-manifest-head {
	display: grid;
	grid-template-columns: 30px minmax(0, 1fr) 118px 118px;
	align-items: center;
	gap: 8px;
	padding: 4px 0 2px;
	border-bottom: 1px solid rgba(60, 116, 255, 0.22);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.05em;
	color: #9ec0ec;
	text-transform: uppercase;
}
.auto-form-row-manifest {
	grid-template-columns: 30px minmax(0, 1fr) 118px 118px;
	align-items: center;
	gap: 8px;
	padding: 6px 0;
}
.auto-form-row-manifest label {
	padding-top: 0;
	align-self: center;
	text-align: center;
	font-size: 12px;
	color: #9db8de;
}
.auto-manifest-crew-placeholder {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	width: 100%;
	color: #6d84a8;
	font-size: 12px;
}
.auto-manifest-crew-wrap {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.auto-manifest-crew-hint {
	font-size: 10px;
	line-height: 1.2;
	color: #6e8db9;
}
.auto-form-row input:focus,
.auto-form-row select:focus {
	outline: none;
	border-color: rgba(60, 116, 255, 0.75);
	box-shadow: 0 0 0 3px rgba(60, 116, 255, 0.14);
}
.auto-form-row select option { background: #070f2a; }
.auto-edit-actions-row {
	display: flex;
	gap: 10px;
	padding: 16px 0 4px;
	justify-content: flex-end;
}

/* ── Coord field wrap + picker ──────────────────────────── */
.auto-coord-field-wrap {
	position: relative;
	width: 100%;
}
.auto-coord-field-wrap input {
	cursor: pointer;
}
.auto-coord-field-wrap input:focus {
	border-color: rgba(60, 200, 100, 0.65) !important;
	box-shadow: 0 0 0 3px rgba(60, 200, 100, 0.10) !important;
}
.auto-sb-picker {
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	right: 0;
	z-index: 1200;
	background: rgba(4, 10, 30, 0.98);
	border: 1px solid rgba(60, 116, 255, 0.45);
	border-radius: 7px;
	box-shadow: 0 12px 40px rgba(0,0,0,0.65), 0 0 0 1px rgba(60,116,255,0.08);
	overflow: hidden;
	animation: fadeIn 0.12s ease both;
	min-width: 280px;
}
.auto-sb-picker-search {
	width: 100% !important;
	border-radius: 0 !important;
	border: none !important;
	border-bottom: 1px solid rgba(40, 65, 120, 0.40) !important;
	background: rgba(6, 14, 38, 0.95) !important;
	padding: 8px 12px !important;
	font-size: 12px !important;
	color: var(--text-bright, #e4edff) !important;
	box-shadow: none !important;
}
.auto-sb-picker-search:focus {
	outline: none !important;
	border-color: rgba(60, 116, 255, 0.55) !important;
	box-shadow: none !important;
}
.auto-sb-picker-list {
	max-height: 240px;
	overflow-y: auto;
}
.auto-sb-picker-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 8px 12px;
	cursor: pointer;
	transition: background 0.10s;
	border-bottom: 1px solid rgba(30, 50, 90, 0.20);
}
.auto-sb-picker-row:last-child { border-bottom: none; }
.auto-sb-picker-row:hover {
	background: rgba(30, 60, 140, 0.45);
}
.auto-sb-picker-name {
	font-size: 12px;
	color: var(--text-bright, #e4edff);
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.auto-sb-picker-coord {
	font-size: 10px;
	color: var(--text-dim, #6a7fa0);
	font-family: var(--font-mono, 'Courier New', monospace);
	flex-shrink: 0;
	background: rgba(10, 22, 55, 0.70);
	padding: 2px 7px;
	border-radius: 3px;
	border: 1px solid rgba(40, 65, 120, 0.35);
}
.auto-sb-picker-empty {
	padding: 16px 12px;
	color: var(--text-dim, #6a7fa0);
	font-size: 11px;
	text-align: center;
}
