/* HDMI Planets — „Aurora Command Deck": Glas-Panels + Holo-HUD über Phosphor-Basis.
   Modernes Sci-Fi-Cockpit, das den Retro-Terminal-Charme bewahrt. */

:root {
  /* Flächen — tiefes Raum-Marineblau mit Teal-Stich */
  --bg: #060a12;
  --bg-2: #0a121c;
  --bg-panel: #0a121c;          /* Kompatibilität (hilfe.html) */
  --bg-raised: #11202a;
  --glass: rgba(18, 32, 44, 0.62);
  --glass-hi: rgba(30, 50, 64, 0.7);
  --glass-line: rgba(120, 220, 200, 0.14);

  /* Akzente */
  --phos: #45ff88;             /* eigenes Imperium / positiv (deckt sich mit Canvas) */
  --phos-soft: #7bf2b3;
  --phos-dim: #2fae66;
  --phos-faint: rgba(69, 255, 136, 0.12);
  --cyan: #38e0ff;             /* HUD / Scan / Struktur */
  --cyan-faint: rgba(56, 224, 255, 0.12);
  --amber: #ffb347;            /* Warnung / Sekundäraktion */
  --red: #ff5a6e;             /* Feind / Gefahr */
  --violet: #c77dff;

  --text: #cfe6da;
  --text-dim: #6f8c80;
  --border: var(--glass-line);
  --border-cyan: rgba(56, 224, 255, 0.28);
  --track: rgba(120, 200, 170, 0.16);

  --radius: 12px;
  --radius-sm: 8px;

  /* Typografie: Orbitron (Marke/HUD) · Rajdhani (Labels/Buttons) · JetBrains Mono (Daten) */
  --font-display: 'Orbitron', sans-serif;
  --font-ui: 'Rajdhani', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;
  --font-body: var(--font-mono);     /* Kompatibilität (hilfe.html) */
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(56, 224, 255, 0.06), transparent 60%),
    radial-gradient(120% 90% at 0% 110%, rgba(69, 255, 136, 0.05), transparent 55%),
    var(--bg);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 13px;
  overflow: hidden;
}

/* ===== CRT-Overlay: dezenter als zuvor (modern, nur ein Hauch) ===== */
#crt {
  position: fixed; inset: 0; pointer-events: none; z-index: 1000;
  background:
    repeating-linear-gradient(0deg, rgba(0,0,0,.10) 0 1px, transparent 1px 3px),
    radial-gradient(ellipse at center, transparent 62%, rgba(0,0,0,.42) 100%);
  mix-blend-mode: multiply;
  animation: flicker 7s infinite;
}
@keyframes flicker { 0%,100%{opacity:1} 96%{opacity:1} 97%{opacity:.94} 98%{opacity:1} }

.hidden { display: none !important; }
.dim { color: var(--text-dim); }
.amber { color: var(--amber); }
.blink { animation: blink 1.6s step-end infinite; }
@keyframes blink { 50% { opacity: .3; } }
.flex { flex: 1; }
.error { color: var(--red); min-height: 1.2em; margin-top: 6px; font-size: 12px; }

/* ===== Screens ===== */
.screen { position: absolute; inset: 0; display: flex; flex-direction: column; }
#auth-screen, #menu-screen, #lobby-screen { overflow-y: auto; align-items: center; }
#auth-screen { justify-content: center; }
#auth-screen .auth-inner { padding-top: 0; }

/* Statisches Sternenfeld */
.menu-stars {
  position: fixed; inset: 0; z-index: -1;
  background-image:
    radial-gradient(1px 1px at 20% 30%, #9fffc0 50%, transparent 50%),
    radial-gradient(1px 1px at 70% 12%, #fff 50%, transparent 50%),
    radial-gradient(1.5px 1.5px at 45% 70%, #8cd0ff 50%, transparent 50%),
    radial-gradient(1px 1px at 85% 60%, #9fd0ff 50%, transparent 50%),
    radial-gradient(1px 1px at 10% 80%, #fff 50%, transparent 50%),
    radial-gradient(1px 1px at 60% 45%, #cfffe6 50%, transparent 50%),
    radial-gradient(1.5px 1.5px at 33% 15%, #fff 50%, transparent 50%),
    radial-gradient(1px 1px at 92% 88%, #ffd9a0 50%, transparent 50%);
  background-size: 560px 560px;
  opacity: .45;
}
.menu-inner { width: min(920px, 94vw); padding: 5vh 0 7vh; }

.logo {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(40px, 7vw, 76px);
  color: var(--phos);
  text-shadow: 0 0 24px rgba(69,255,136,.45);
  letter-spacing: 6px;
  line-height: 1;
}
.logo span { color: var(--cyan); text-shadow: 0 0 24px rgba(56,224,255,.4); }
.logo.small { font-size: 38px; margin-bottom: 14px; }
.tagline {
  font-family: var(--font-ui); font-weight: 500;
  color: var(--text-dim); margin: 10px 0 30px; letter-spacing: 3px; font-size: 13px;
}
.manual-link {
  font-family: var(--font-ui); font-weight: 600; letter-spacing: 1px;
  color: var(--amber); text-decoration: none; margin-left: 14px;
  border: 1px solid rgba(255,179,71,.4); border-radius: 20px; padding: 3px 14px; font-size: 12px;
  transition: all .15s;
}
.manual-link:hover { background: rgba(255,179,71,.14); box-shadow: 0 0 16px rgba(255,179,71,.2); }

.menu-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 740px) { .menu-cols { grid-template-columns: 1fr; } }

.scenario-row { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 14px; }
.scenario-row button { flex: 1 1 auto; white-space: nowrap; }

/* Glas-Karten */
.box {
  border: 1px solid var(--glass-line);
  border-radius: var(--radius);
  background: var(--glass);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  padding: 20px;
  box-shadow: 0 8px 40px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.04);
}
.box h2 {
  font-family: var(--font-ui); font-weight: 600;
  font-size: 17px; color: var(--phos); margin-bottom: 14px;
  letter-spacing: 2px; text-transform: uppercase;
  display: flex; align-items: center; gap: 9px;
}
.box h2::before { content: ""; width: 4px; height: 16px; background: var(--phos); border-radius: 2px; box-shadow: 0 0 10px var(--phos); }
.box h2 + h2 { margin-top: 22px; }
.box label { display: block; margin-bottom: 12px; color: var(--text-dim); font-family: var(--font-ui); font-weight: 500; letter-spacing: .5px; }
.box .row { display: flex; gap: 12px; }
.box .row label { flex: 1; }
.race-info { color: var(--cyan); min-height: 2.4em; font-size: 12px; margin-bottom: 10px; line-height: 1.5; }

input, select {
  width: 100%;
  background: rgba(4, 10, 14, 0.7);
  border: 1px solid var(--glass-line);
  border-radius: var(--radius-sm);
  color: var(--phos);
  font-family: var(--font-mono);
  font-size: 13px;
  padding: 9px 11px;
  margin-top: 5px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
input:focus, select:focus { border-color: var(--cyan); box-shadow: 0 0 0 3px var(--cyan-faint); }

button {
  font-family: var(--font-ui); font-weight: 600;
  font-size: 14px; letter-spacing: 1.5px; text-transform: uppercase;
  background: rgba(255,255,255,.04);
  color: var(--phos);
  border: 1px solid var(--glass-line);
  border-radius: var(--radius-sm);
  padding: 9px 16px;
  cursor: pointer;
  transition: all .14s;
}
button:hover { background: var(--phos-faint); border-color: var(--phos-dim); box-shadow: 0 0 16px rgba(69,255,136,.18); }
button.primary {
  background: linear-gradient(180deg, rgba(69,255,136,.22), rgba(69,255,136,.1));
  border-color: var(--phos-dim); color: var(--phos-soft); width: 100%; margin-top: 8px;
}
button.primary:hover { background: linear-gradient(180deg, rgba(69,255,136,.32), rgba(69,255,136,.16)); box-shadow: 0 0 22px rgba(69,255,136,.3); }
button.ghost { border-color: var(--glass-line); color: var(--text-dim); }
button.ghost:hover { color: var(--amber); border-color: var(--amber); background: rgba(255,179,71,.08); box-shadow: none; }
button:disabled { opacity: .4; cursor: default; box-shadow: none; }
button.small { font-size: 12px; padding: 5px 10px; letter-spacing: .8px; }

.games-list { max-height: 190px; overflow-y: auto; margin-top: 4px; }
.games-list .game-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 9px 10px; border: 1px solid transparent; border-radius: var(--radius-sm);
  cursor: pointer; transition: all .12s; margin-bottom: 4px;
}
.games-list .game-row:hover { background: var(--phos-faint); border-color: var(--glass-line); }

.resume { margin-top: 18px; border-color: rgba(255,179,71,.35); }
.resume h2 { color: var(--amber); }
.resume h2::before { background: var(--amber); box-shadow: 0 0 10px var(--amber); }

/* U34 — Einladung-kopieren-Button neben der Partie-ID */
#lobby-copy { margin-left: 10px; vertical-align: middle; }
#lobby-copy.copied { color: var(--phos); border-color: var(--phos-dim); box-shadow: 0 0 10px rgba(69,255,136,.18); }
#lobby-players { margin: 16px 0; }
#lobby-players .lp { padding: 8px 4px; border-bottom: 1px solid var(--glass-line); font-family: var(--font-mono); }
.team-block { margin-bottom: 12px; border: 1px solid var(--glass-line); border-radius: var(--radius-sm); padding: 6px 10px; }
.team-head { font-family: var(--font-ui); font-weight: 600; letter-spacing: 1px; color: var(--cyan); margin-bottom: 2px; }
.chkline { display: flex; align-items: center; gap: 8px; color: var(--text-dim); font-family: var(--font-ui); }
.chkline input { width: auto; margin: 0; }
.preset-row label { font-size: 12px; }
#c-team-extra .hintline { color: var(--text-dim); font-size: 11px; margin: 4px 0; }

/* ===== Anmelde-Screen ===== */
.auth-inner { width: min(460px, 94vw); }
.auth-box { margin-top: 8px; }
.auth-tabs { display: flex; gap: 4px; margin-bottom: 16px; border: 1px solid var(--glass-line); border-radius: var(--radius-sm); padding: 3px; }
.auth-tab {
  flex: 1; margin: 0; border: none; background: transparent; color: var(--text-dim);
  border-radius: var(--radius-sm); padding: 8px;
}
.auth-tab.active { background: var(--phos-faint); color: var(--phos); box-shadow: none; }
.auth-tab:hover { box-shadow: none; }
.auth-pane h2 { margin-bottom: 14px; }
.auth-alt { margin-top: 12px; text-align: center; }
.auth-alt a { color: var(--cyan); text-decoration: none; font-family: var(--font-ui); font-weight: 500; }
.auth-alt a:hover { text-decoration: underline; }
.recovery-code {
  font-family: var(--font-mono); font-size: 22px; font-weight: 700; letter-spacing: 3px;
  color: var(--amber); text-align: center; margin: 16px 0;
  padding: 14px; background: rgba(255,179,71,.08); border: 1px dashed rgba(255,179,71,.4);
  border-radius: var(--radius-sm); user-select: all; word-break: break-all;
}

/* Benutzerleiste im Menü */
.user-bar { display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.user-box { display: flex; align-items: center; gap: 12px; font-family: var(--font-ui); }
.user-box strong { font-size: 15px; }
.user-box .manual-link { margin-left: 0; }
#mygames-box { margin: 18px 0; }
#mygames-list .game-row { font-family: var(--font-mono); }

/* ===== Topbar (HUD-Kommandoleiste) ===== */
#topbar {
  display: flex; align-items: center; gap: 11px;
  padding: 8px 14px;
  background: var(--glass);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border-cyan);
  white-space: nowrap; z-index: 10; overflow: hidden;
  box-shadow: 0 2px 24px rgba(0,0,0,.4);
}
/* Marke, Gauge und rechte Buttons bleiben immer sichtbar; Tiles/Spielerchips weichen zuerst */
#topbar .brand, .quota-gauge, .ghost-link,
#topbar #t-submit, #topbar #t-forcehost, #topbar #t-leave { flex-shrink: 0; }
#topbar .tiles { flex-shrink: 1; min-width: 0; overflow: hidden; }
#topbar .players-ready { flex-shrink: 1; min-width: 0; max-width: 260px; }

/* Aktionsknöpfe: eigener horizontaler Scroll-Container, damit auf schmalen Viewports nichts
   unerreichbar hinter #topbars overflow:hidden verschwindet (siehe U-Resp-Kommentar im HTML). */
.topbar-actions {
  display: flex; align-items: center; gap: 11px;
  flex-shrink: 1; min-width: 0;
  overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none;
}
.topbar-actions::-webkit-scrollbar { display: none; }
#topbar .brand {
  font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--phos);
  text-shadow: 0 0 14px rgba(69,255,136,.4); letter-spacing: 2px;
}
#topbar .brand b { color: var(--cyan); font-weight: 700; margin-left: 6px; text-shadow: 0 0 14px rgba(56,224,255,.4); }
#topbar .tiles { display: flex; gap: 10px; }
.tile {
  display: flex; flex-direction: column; line-height: 1.15;
  padding: 3px 12px; border-left: 1px solid var(--glass-line);
}
.tile label { font-family: var(--font-ui); font-weight: 500; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-dim); }
.tile strong, .tile span { font-family: var(--font-mono); font-size: 14px; color: var(--text); font-weight: 500; }
.tile strong { color: var(--phos); }

/* Ring-Gauge für die Siegquote */
.quota-gauge { position: relative; width: 46px; height: 46px; display: flex; align-items: center; justify-content: center; }
.quota-gauge svg { position: absolute; inset: 0; transform: rotate(-90deg); }
.quota-num { text-align: center; line-height: 1; font-family: var(--font-mono); }
.quota-num strong { display: block; color: var(--phos); font-size: 14px; font-weight: 600; }
.quota-num span { display: block; color: var(--text-dim); font-size: 10px; margin-top: 1px; }

/* U-Ready: Zähler "3/8 bereit" bleibt immer lesbar, auch wenn die Chips daneben bei
   vielen Spielern (8-10) zu eng werden — deshalb eigenes Element statt Teil der Chip-Zeile. */
.ready-count { font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); flex-shrink: 0; white-space: nowrap; }
.spectator-badge {
  font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: .5px;
  color: var(--amber); border: 1px solid var(--amber); border-radius: 4px; padding: 3px 8px;
  flex-shrink: 0; white-space: nowrap;
}
/* Zuschauer-Modus: keine eigenen Befehle möglich — Bedienelemente dafür ausblenden statt einzeln zu deaktivieren. */
#game-screen.spectator-mode #t-submit,
#game-screen.spectator-mode #t-undo,
#game-screen.spectator-mode #t-redo,
#game-screen.spectator-mode #t-forcehost,
#game-screen.spectator-mode #t-history,
#game-screen.spectator-mode .chat-composer { display: none !important; }
.players-ready {
  display: flex; gap: 6px;
  overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none;
}
.players-ready::-webkit-scrollbar { display: none; }
.players-ready .pchip {
  font-family: var(--font-ui); font-weight: 500; letter-spacing: .5px;
  padding: 3px 9px; border: 1px solid var(--glass-line); border-radius: 14px;
  font-size: 11px; color: var(--text-dim); flex-shrink: 0;
}
.players-ready .pchip.ready { color: var(--phos); border-color: var(--phos-dim); box-shadow: 0 0 10px rgba(69,255,136,.15); }
.players-ready .pchip.waiting { color: var(--amber); border-color: rgba(255,180,60,.4); }
.players-ready .pchip.me { border-width: 2px; }
.players-ready .pchip.dead { color: var(--red); text-decoration: line-through; opacity: .7; }

.ghost-link {
  font-family: var(--font-display); font-weight: 500; font-size: 15px; color: var(--text-dim);
  border: 1px solid var(--glass-line); border-radius: 50%; width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center; text-decoration: none;
  transition: all .14s;
}
.ghost-link:hover { color: var(--cyan); border-color: var(--cyan); box-shadow: 0 0 14px rgba(56,224,255,.2); }

#topbar #t-submit { width: auto; margin-top: 0; }

/* Schmale Fenster: Info-Tiles und Spielerchips weichen, Befehlsbuttons bleiben */
@media (max-width: 1080px) {
  #topbar .tile:nth-child(1), #topbar .tile:nth-child(3), #topbar .tile:nth-child(4) { display: none; }
}
@media (max-width: 860px) {
  #topbar { gap: 8px; }
  #topbar .players-ready { display: none; }
  #topbar #t-submit { font-size: 12px; padding: 8px 11px; }
  /* Nicht mehr genug Platz für alle Aktionsknöpfe: Runde abschicken & Verlassen zuerst sichtbar,
     Handbuch/Tutorial/Diplomatie/Zeitreise/Host lassen sich seitlich heranscrollen. */
  #topbar #t-submit { order: -2; }
  #topbar #t-leave { order: -1; }
}
@media (max-width: 560px) {
  /* Handy-Breite: Marke+Quote allein reichen der Zeile kaum noch Platz für die Aktionsknöpfe —
     eigene volle Zeile darunter, statt „Runde abschicken" auf ein paar Pixel zusammenzuquetschen. */
  #topbar { flex-wrap: wrap; row-gap: 6px; padding-bottom: 6px; }
  .topbar-actions { flex-basis: 100%; }
}

/* ===== Spielfläche ===== */
#game-main { flex: 1; display: flex; min-height: 0; }

#map-wrap { flex: 1; position: relative; background: radial-gradient(130% 130% at 50% 30%, #0a1622, #050810); min-width: 0; overflow: hidden; touch-action: none; }
/* touch-action: none → Browser fängt Pan/Zoom nicht selbst ab (U32 Pointer Events). */
#map { width: 100%; height: 100%; display: block; cursor: crosshair; touch-action: none; }

/* HUD-Eckklammern */
.hud-corner { position: absolute; width: 26px; height: 26px; border: 0 solid var(--cyan); pointer-events: none; opacity: .5; z-index: 3; }
.hud-corner.tl { top: 12px; left: 12px; border-top-width: 2px; border-left-width: 2px; }
.hud-corner.tr { top: 12px; right: 12px; border-top-width: 2px; border-right-width: 2px; }
.hud-corner.bl { bottom: 12px; left: 12px; border-bottom-width: 2px; border-left-width: 2px; }
.hud-corner.br { bottom: 12px; right: 12px; border-bottom-width: 2px; border-right-width: 2px; }

.map-overlay {
  position: absolute; pointer-events: none;
  font-family: var(--font-mono); font-size: 11px; color: var(--text-dim);
  background: var(--glass); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  padding: 4px 10px; border: 1px solid var(--glass-line); border-radius: var(--radius-sm);
  z-index: 4;
}
#map-coords { left: 14px; bottom: 14px; }
#map-hint {
  top: 16px; left: 50%; transform: translateX(-50%);
  color: var(--cyan); border-color: var(--border-cyan); font-family: var(--font-ui); font-weight: 600;
  letter-spacing: 1px; font-size: 13px; animation: blink 1.6s step-end infinite;
}
#turn-flash {
  position: absolute; top: 40%; left: 50%; transform: translate(-50%,-50%);
  font-family: var(--font-display); font-weight: 700; font-size: 50px; color: var(--phos);
  text-shadow: 0 0 36px rgba(69,255,136,.7); letter-spacing: 4px;
  pointer-events: none; animation: flash 2.2s forwards; z-index: 5;
}
@keyframes flash { 0%{opacity:0} 15%{opacity:1} 75%{opacity:1} 100%{opacity:0} }

/* ===== Seitenpanel ===== */
#panel {
  width: 372px; flex-shrink: 0;
  background: var(--glass);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
  border-left: 1px solid var(--border-cyan);
  overflow-y: auto; padding: 16px;
}
#panel > p { color: var(--text-dim); line-height: 1.7; }

/* U32 — Schmale Viewports (Tablet/Smartphone): Karte oben, Panel darunter stapeln,
   statt das Panel seitlich zu verdrängen. Beide bleiben scroll- und nutzbar. */
@media (max-width: 760px) {
  #game-main { flex-direction: column; }
  #map-wrap { flex: 1 1 55%; min-height: 220px; }
  #panel {
    width: 100%; flex: 1 1 45%; max-height: 50vh;
    border-left: none; border-top: 1px solid var(--border-cyan);
  }
}
#panel h2 {
  font-family: var(--font-ui); font-weight: 600; font-size: 20px; letter-spacing: 1px;
  color: var(--phos); margin-bottom: 3px; text-shadow: 0 0 14px rgba(69,255,136,.25);
}
#panel h2 .sub { color: var(--text-dim); font-size: 14px; font-weight: 500; }
#panel h3 {
  font-family: var(--font-ui); font-weight: 600; font-size: 14px; color: var(--cyan);
  letter-spacing: 1.5px; text-transform: uppercase;
  margin-top: 18px; padding: 8px 0 6px 11px; position: relative;
  border-top: 1px solid var(--glass-line);
}
#panel h3::before { content: ""; position: absolute; left: 0; top: 11px; bottom: 6px; width: 3px; background: var(--cyan); border-radius: 2px; box-shadow: 0 0 8px var(--cyan); }
#panel table { width: 100%; border-collapse: collapse; margin-top: 8px; }
#panel td { padding: 3px 4px; font-family: var(--font-mono); }
#panel td:last-child { text-align: right; color: var(--phos); }
#panel td.warn { color: var(--amber); }
#panel .bar {
  height: 6px; border-radius: 4px; background: var(--track); overflow: hidden;
  position: relative; margin: 3px 0 9px;
}
#panel .bar i { position: absolute; inset: 0; right: auto; background: var(--phos); border-radius: 4px; box-shadow: 0 0 8px rgba(69,255,136,.4); }
#panel .ctl { display: flex; gap: 8px; align-items: center; margin: 8px 0; flex-wrap: wrap; }
#panel .ctl label { color: var(--text-dim); flex: 1; min-width: 92px; font-family: var(--font-ui); font-weight: 500; letter-spacing: .3px; }

/* Statistiken & MVP-Rangliste (Phase 3) */
.stats-table th { text-align: left; color: var(--text-dim); font-family: var(--font-ui); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: .5px; padding: 4px; border-bottom: 1px solid var(--glass-line); }
.stats-table td { text-align: left !important; color: var(--text) !important; }
.stats-table tr.me td { background: rgba(69,255,136,.08); }
#panel .ctl input, #panel .ctl select { width: 84px; margin-top: 0; }
#panel .ctl select.wide { width: 100%; }
#panel .planned { color: var(--cyan); font-size: 12px; margin: 6px 0; padding: 6px 10px; background: var(--cyan-faint); border-radius: var(--radius-sm); border: 1px solid var(--border-cyan); }
#panel .hintline { color: var(--text-dim); font-size: 11px; margin: 5px 0; line-height: 1.5; }
#panel .transfer-grid { display: grid; grid-template-columns: auto 1fr auto 1fr; gap: 5px 9px; align-items: center; margin-top: 8px; }
#panel .transfer-grid input { width: 100%; }
#panel .transfer-grid .stock { color: var(--text-dim); text-align: right; font-size: 12px; font-family: var(--font-mono); }
.loc-bar { display: flex; flex-wrap: wrap; gap: 5px; align-items: center; margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--glass-line); }
.loc-bar-label { font-family: var(--font-ui); font-size: 11px; color: var(--text-dim); letter-spacing: .5px; }
.loc-badge {
  font-family: var(--font-mono); font-size: 11px; margin-top: 0; padding: 2px 8px;
  background: rgba(255,255,255,.03); border: 1px solid var(--border); border-radius: 14px; letter-spacing: 0; text-transform: none;
}
.loc-badge.sel { background: var(--phos-faint); box-shadow: 0 0 8px rgba(69,255,136,.2); }
.loc-toggle { font-size: 13px; margin-top: 0; padding: 2px 8px; border-radius: var(--radius-sm); letter-spacing: 0; }
.loc-filter { width: 100%; margin-top: 6px; padding: 5px 9px; font-size: 12px; }
.loc-list { width: 100%; max-height: 200px; overflow-y: auto; margin-top: 6px; display: flex; flex-direction: column; gap: 2px; }
.loc-row {
  display: flex; align-items: baseline; gap: 8px; width: 100%; text-align: left; margin-top: 0;
  padding: 5px 8px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0; text-transform: none;
  background: rgba(255,255,255,.02); border: 1px solid transparent; border-radius: var(--radius-sm);
}
.loc-row:hover { background: var(--phos-faint); }
.loc-row.sel { background: var(--phos-faint); border-color: var(--phos-dim); }
.loc-row-name { color: var(--text); flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.loc-row-sub { color: var(--text-dim); font-size: 11px; flex-shrink: 0; }

/* Diplomatie */
.diplo-row { border: 1px solid var(--line, rgba(255,255,255,.1)); border-radius: var(--radius-sm); padding: 8px 10px; margin-top: 8px; }
.diplo-name { font-family: var(--font-mono); font-weight: 600; font-size: 13px; }
.diplo-status { font-size: 12px; margin: 3px 0 6px; }
.diplo-row .btnrow { display: flex; flex-wrap: wrap; gap: 6px; }
button.small.danger { color: #ff8090; border-color: rgba(255,85,102,.5); }
button.small.danger:hover { background: rgba(255,85,102,.12); }
#t-diplo.alert { color: var(--amber); border-color: var(--amber); animation: diploPulse 1.6s ease-in-out infinite; }
@keyframes diploPulse { 0%,100% { box-shadow: 0 0 0 rgba(255,200,80,0); } 50% { box-shadow: 0 0 8px rgba(255,200,80,.5); } }

/* Weltgenerierungs-Konfigurator */
.mini-h { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-dim); margin: 14px 0 4px; }
input[type=range] { width: 100%; accent-color: var(--phos); margin-top: 4px; }
.preview-wrap { display: flex; flex-direction: column; align-items: center; gap: 6px; margin: 8px 0; }
#c-preview { width: 240px; height: 240px; background: rgba(0,0,0,.25); border: 1px solid var(--line, rgba(255,255,255,.1)); border-radius: var(--radius-sm); }
#c-preview-info { font-size: 11px; }
#panel button { margin-top: 7px; }
#panel .btnrow { display: flex; gap: 7px; flex-wrap: wrap; }
#panel .btnrow button { flex: 1; }
#panel .tag {
  display: inline-block; padding: 2px 9px; border: 1px solid var(--glass-line); border-radius: 14px;
  color: var(--text-dim); font-family: var(--font-ui); font-weight: 500; font-size: 11px; letter-spacing: .5px;
  margin: 0 4px 4px 0;
}

/* ===== U36 — Seitenleiste „Meine Objekte" (Sprung-/Filterliste) ===== */
.fleet {
  position: absolute; top: 14px; left: 14px; z-index: 6;
  width: 250px; max-width: calc(100% - 28px);
  font-family: var(--font-ui); display: flex; flex-direction: column;
}
.fleet-toggle {
  display: flex; align-items: center; gap: 8px; width: 100%;
  margin-top: 0; padding: 7px 11px; letter-spacing: 1px; font-size: 12px;
  color: var(--cyan);
  background: var(--glass); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border: 1px solid var(--border-cyan); border-radius: var(--radius-sm);
}
.fleet-toggle:hover { color: var(--phos); border-color: var(--phos-dim); background: var(--phos-faint); box-shadow: none; }
.fleet-toggle-ico { font-size: 14px; }
.fleet-toggle-lbl { flex: 1; text-align: left; }
.fleet:not(.collapsed) .fleet-toggle { border-radius: var(--radius-sm) var(--radius-sm) 0 0; border-bottom-color: transparent; }
.fleet-count {
  min-width: 18px; height: 18px; padding: 0 5px; border-radius: 9px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 11px; color: var(--text-dim);
}
.fleet-count.has { background: rgba(255,179,71,.16); color: var(--amber); box-shadow: 0 0 8px rgba(255,179,71,.25); }
.fleet.collapsed .fleet-body { display: none; }
.fleet-body {
  background: var(--glass); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border: 1px solid var(--border-cyan); border-top: none;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  padding: 9px; display: flex; flex-direction: column; gap: 8px;
}
.fleet-search { width: 100%; margin-top: 0; padding: 6px 9px; font-size: 12px; }
.fleet-filters { display: flex; flex-wrap: wrap; gap: 4px; }
.fleet-chip {
  margin-top: 0; padding: 3px 8px; font-size: 11px; letter-spacing: .3px;
  border-radius: 12px; color: var(--text-dim); text-transform: none;
}
.fleet-chip.active { color: var(--phos); border-color: var(--phos-dim); background: var(--phos-faint); box-shadow: none; }
.fleet-chip:hover { box-shadow: none; }
.fleet-list { max-height: 46vh; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.fleet-sec {
  font-family: var(--font-ui); font-weight: 600; font-size: 10px; letter-spacing: 1px; text-transform: uppercase;
  color: var(--text-dim); padding: 6px 2px 2px; display: flex; gap: 6px; align-items: center;
}
.fleet-sec-n { color: var(--cyan); }
.fleet-row {
  display: flex; align-items: center; gap: 8px; width: 100%; text-align: left;
  margin-top: 0; padding: 5px 8px; text-transform: none; letter-spacing: 0;
  background: rgba(255,255,255,.02); border: 1px solid transparent; border-radius: var(--radius-sm);
  font-family: var(--font-mono); font-size: 12px; color: var(--text);
  transition: transform .12s ease, background .12s ease;
}
/* U-Tooltip-Pop (Phase 2): leichtes Herausheben statt reinem Farbwechsel beim Hover. */
.fleet-row:hover { background: var(--phos-faint); border-color: var(--glass-line); box-shadow: none; transform: scale(1.015); }
.fleet-row.sel { background: var(--phos-faint); border-color: var(--phos-dim); }
.fleet-row.noord { border-left: 2px solid var(--amber); }
.fleet-ico { flex-shrink: 0; font-size: 12px; }
.fleet-row-main { flex: 1; min-width: 0; display: flex; flex-direction: column; line-height: 1.25; }
.fleet-row-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fleet-id { color: var(--text-dim); font-size: 10px; }
.fleet-row-sub { color: var(--text-dim); font-size: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fleet-warn { color: var(--amber); }
.fleet-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--amber); box-shadow: 0 0 6px var(--amber); flex-shrink: 0; }
.fleet-empty, .fleet-hint { color: var(--text-dim); font-size: 11px; padding: 4px 2px; line-height: 1.4; }
.fleet-hint { border-top: 1px solid var(--glass-line); padding-top: 7px; margin-top: 2px; }
@media (max-width: 760px) { .fleet { width: 208px; } .fleet-list { max-height: 32vh; } }

/* ===== Log ===== */
#log {
  height: 158px; flex-shrink: 0;
  background: var(--glass);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
  border-top: 1px solid var(--border-cyan);
  display: flex; flex-direction: column;
}
.log-tabs { display: flex; gap: 4px; padding: 6px 8px 0; border-bottom: 1px solid var(--glass-line); }
.log-tabs button {
  font-family: var(--font-ui); font-weight: 600; letter-spacing: 1px;
  font-size: 12px; padding: 6px 16px; border: 1px solid transparent; border-bottom: none;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  background: transparent; color: var(--text-dim); text-transform: uppercase;
}
.log-tabs button.active { color: var(--cyan); background: var(--cyan-faint); border-color: var(--glass-line); }
.log-tabs .log-export { margin-left: auto; border: 1px solid var(--glass-line); border-radius: var(--radius-sm); }
#log-content { flex: 1; overflow-y: auto; padding: 8px 14px; font-family: var(--font-mono); }
#log-content .entry { padding: 3px 0; border-bottom: 1px solid rgba(120,200,170,.06); line-height: 1.5; }
#log-content .entry.battle { color: var(--amber); }
#log-content .entry.victory { color: var(--phos); text-shadow: 0 0 8px rgba(69,255,136,.35); }
#log-content .entry.defeat { color: var(--red); }
#log-content .entry.diplomacy { color: var(--cyan); border-left: 2px solid var(--border-cyan); padding-left: 6px; }
#log-content .entry.resource { color: var(--amber); }
#log-content .entry.chat { color: var(--text); }
#log-content .entry.chat .chat-name { color: var(--cyan); font-weight: 600; }
#log-content .entry.chat .chat-team { color: var(--amber); }
.chat-composer { display: flex; gap: 6px; padding: 6px 8px; border-top: 1px solid var(--glass-line); flex-shrink: 0; }
.chat-composer.hidden { display: none; }
.chat-composer select { flex: 0 0 auto; }
.chat-composer input { flex: 1; min-width: 0; }

/* ===== Scrollbars ===== */
::-webkit-scrollbar { width: 9px; height: 9px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(56,224,255,.18); border-radius: 6px; }
::-webkit-scrollbar-thumb:hover { background: rgba(56,224,255,.35); }

/* ===== U25 — Ladezustand für Buttons (Doppel-Submit-Schutz) =====
   .btn-busy blendet die Beschriftung aus und zeigt einen kleinen Spinner. Der
   Button-Text bleibt im DOM erhalten (nur transparent), damit Re-Renderings ihn
   nicht verlieren. */
button.btn-busy { position: relative; color: transparent !important; pointer-events: none; }
button.btn-busy:disabled { opacity: .85; }   /* Spinner sichtbar, trotz disabled */
button.btn-busy::after {
  content: ""; position: absolute; top: 50%; left: 50%;
  width: 15px; height: 15px; margin: -8px 0 0 -8px;
  border: 2px solid rgba(69,255,136,.28); border-top-color: var(--phos);
  border-radius: 50%; animation: btn-spin .7s linear infinite;
}
@keyframes btn-spin { to { transform: rotate(360deg); } }

/* ===== U27 — Toasts (Ersatz für alert()) ===== */
#toast-host {
  position: fixed; z-index: 1200; left: 50%; bottom: 22px; transform: translateX(-50%);
  display: flex; flex-direction: column; gap: 8px; align-items: center;
  width: min(420px, 92vw); pointer-events: none;
}
.toast {
  width: 100%; pointer-events: auto; cursor: pointer;
  font-family: var(--font-ui); font-weight: 500; font-size: 13px; letter-spacing: .3px; line-height: 1.45;
  color: var(--text); background: var(--glass-hi);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border: 1px solid var(--glass-line); border-left: 3px solid var(--cyan);
  border-radius: var(--radius-sm); padding: 11px 14px;
  box-shadow: 0 8px 30px rgba(0,0,0,.45);
  opacity: 0; transform: translateY(12px); transition: opacity .25s, transform .25s;
}
.toast.show { opacity: 1; transform: translateY(0); }
.toast-error { border-left-color: var(--red); }
.toast-success { border-left-color: var(--phos); }
.toast-info { border-left-color: var(--cyan); }
/* U-1-Klick-Fix (Phase 2): optionaler Aktions-Button innerhalb des Toasts. */
.toast-action {
  display: block; margin: 8px 0 0; width: auto; padding: 5px 12px; font-size: 12px;
  color: var(--phos); border-color: var(--phos-dim); background: var(--phos-faint);
}

/* ===== U27 — Bestätigungs-Dialog (Ersatz für confirm()) ===== */
.modal-overlay {
  position: fixed; inset: 0; z-index: 1300; padding: 20px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(3, 7, 12, .6); -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  opacity: 0; transition: opacity .18s;
}
.modal-overlay.show { opacity: 1; }
.modal-box {
  width: min(440px, 94vw);
  background: var(--glass); -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px);
  border: 1px solid var(--border-cyan); border-radius: var(--radius);
  padding: 22px; box-shadow: 0 20px 60px rgba(0,0,0,.55);
  transform: translateY(10px) scale(.98); transition: transform .18s;
}
.modal-overlay.show .modal-box { transform: translateY(0) scale(1); }
.modal-msg { color: var(--text); font-family: var(--font-ui); font-size: 15px; line-height: 1.55; margin-bottom: 18px; }
.modal-btnrow { display: flex; gap: 10px; justify-content: flex-end; flex-wrap: wrap; }
.modal-btnrow button { width: auto; margin-top: 0; min-width: 120px; }
button.primary.danger {
  background: linear-gradient(180deg, rgba(255,90,110,.26), rgba(255,90,110,.13));
  border-color: rgba(255,90,110,.6); color: #ffd7dc;
}
button.primary.danger:hover {
  background: linear-gradient(180deg, rgba(255,90,110,.38), rgba(255,90,110,.2));
  box-shadow: 0 0 22px rgba(255,90,110,.3);
}

/* ===== U26 — Verbindungs-Banner bei Polling-Fehlern ===== */
.conn-banner {
  position: fixed; z-index: 1100; top: 58px; left: 50%; transform: translateX(-50%);
  display: flex; align-items: center; gap: 9px;
  font-family: var(--font-ui); font-weight: 600; font-size: 12px; letter-spacing: .5px;
  color: var(--amber); background: var(--glass-hi);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border: 1px solid rgba(255,179,71,.45); border-radius: 18px;
  padding: 7px 15px; box-shadow: 0 6px 24px rgba(0,0,0,.4);
}
.conn-dot {
  width: 9px; height: 9px; border-radius: 50%; background: var(--amber);
  box-shadow: 0 0 8px var(--amber); animation: conn-pulse 1.3s ease-in-out infinite; flex-shrink: 0;
}
@keyframes conn-pulse { 0%,100% { opacity: 1; } 50% { opacity: .25; } }

/* ===== U28 — Katalog-/Boot-Fehler mit Retry ===== */
.boot-error {
  position: fixed; inset: 0; z-index: 1400; padding: 24px;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(130% 130% at 50% 30%, #0a1622, #050810);
}
.boot-error-box {
  width: min(460px, 94vw); text-align: center;
  background: var(--glass); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
  border: 1px solid var(--border-cyan); border-radius: var(--radius);
  padding: 30px 26px; box-shadow: 0 18px 60px rgba(0,0,0,.5);
}
.boot-error-icon { font-size: 40px; color: var(--amber); margin-bottom: 8px; line-height: 1; }
.boot-error-box h2 {
  font-family: var(--font-ui); font-weight: 600; font-size: 20px; letter-spacing: 1px;
  color: var(--phos); text-transform: uppercase; margin-bottom: 12px;
}
.boot-error-box p { color: var(--text-dim); line-height: 1.6; font-size: 13px; margin-bottom: 6px; }
.boot-error-box code { color: var(--cyan); font-family: var(--font-mono); background: rgba(56,224,255,.08); padding: 1px 6px; border-radius: 4px; }
.boot-error-box button.primary { max-width: 240px; margin: 18px auto 0; }
.boot-error-hint { color: var(--red) !important; min-height: 1.2em; margin-top: 10px; }

/* ===== U39 — Umschalter „Einfach / Erweitert" im Erstellen-Dialog ===== */
.create-mode {
  display: flex; gap: 4px; margin-bottom: 14px;
  border: 1px solid var(--glass-line); border-radius: var(--radius-sm); padding: 3px;
}
.cmode-btn {
  flex: 1; margin: 0; border: none; background: transparent; color: var(--text-dim);
  border-radius: var(--radius-sm); padding: 7px; font-size: 12px;
}
.cmode-btn.active { background: var(--phos-faint); color: var(--phos); box-shadow: none; }
.cmode-btn:hover { box-shadow: none; color: var(--phos-soft); }
/* Detailgruppe: dezenter Trenner, wenn sie im Erweitert-Modus sichtbar wird */
.c-advanced { border-top: 1px dashed var(--glass-line); margin-top: 4px; padding-top: 12px; }

/* ===== U40 — Onboarding-Overlay (geführte Ersteinführung) ===== */
.onboard-overlay {
  position: fixed; inset: 0; z-index: 1350; padding: 20px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(3, 7, 12, .62); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  opacity: 0; transition: opacity .2s;
}
.onboard-overlay.show { opacity: 1; }
.onboard-box {
  position: relative; width: min(520px, 94vw); max-height: 88vh; overflow-y: auto;
  background: var(--glass); -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px);
  border: 1px solid var(--border-cyan); border-radius: var(--radius);
  padding: 26px 26px 22px; box-shadow: 0 20px 60px rgba(0,0,0,.55);
  transform: translateY(10px) scale(.98); transition: transform .2s;
}
.onboard-overlay.show .onboard-box { transform: translateY(0) scale(1); }
.onboard-box h2 {
  font-family: var(--font-ui); font-weight: 600; font-size: 21px; letter-spacing: 1px;
  color: var(--phos); text-transform: uppercase; text-shadow: 0 0 14px rgba(69,255,136,.3);
  margin-bottom: 8px;
}
.onboard-lead { color: var(--text-dim); line-height: 1.6; margin-bottom: 14px; font-size: 13px; }
.onboard-steps { list-style: none; counter-reset: step; margin: 0 0 12px; padding: 0; }
.onboard-steps li {
  position: relative; counter-increment: step;
  padding: 9px 12px 9px 46px; margin-bottom: 8px; line-height: 1.5;
  background: rgba(255,255,255,.03); border: 1px solid var(--glass-line);
  border-left: 3px solid var(--cyan); border-radius: var(--radius-sm);
  color: var(--text); font-size: 13px;
}
.onboard-steps li::before {
  content: counter(step); position: absolute; left: 11px; top: 9px;
  width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 700; font-size: 12px;
  color: var(--cyan); background: var(--cyan-faint); border: 1px solid var(--border-cyan);
}
.onboard-steps b { color: var(--phos-soft); font-weight: 600; }
.onboard-tip { color: var(--text-dim); font-size: 12px; margin-bottom: 16px; }
.onboard-btnrow { display: flex; gap: 12px; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.onboard-manual {
  font-family: var(--font-ui); font-weight: 600; letter-spacing: .5px; color: var(--amber);
  text-decoration: none; border: 1px solid rgba(255,179,71,.4); border-radius: 20px;
  padding: 8px 16px; font-size: 12px; transition: all .15s;
}
.onboard-manual:hover { background: rgba(255,179,71,.14); box-shadow: 0 0 16px rgba(255,179,71,.2); }
.onboard-ok { width: auto; margin-top: 0; min-width: 150px; flex: 1; }
.onboard-close {
  position: absolute; top: 12px; right: 12px; width: 30px; height: 30px; padding: 0;
  border-radius: 50%; color: var(--text-dim); border-color: var(--glass-line);
  display: flex; align-items: center; justify-content: center; font-size: 15px;
}
.onboard-close:hover { color: var(--red); border-color: var(--red); background: rgba(255,90,110,.1); box-shadow: none; }

/* ===== U41 — Kontextsensitiver Schritt-Hinweis (erste Runden) ===== */
.coach {
  position: absolute; left: 50%; bottom: 14px; transform: translateX(-50%);
  z-index: 6; display: flex; align-items: center; gap: 10px;
  width: min(560px, calc(100% - 28px));
  font-family: var(--font-ui);
  background: var(--glass-hi); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border: 1px solid var(--border-cyan); border-left: 3px solid var(--amber);
  border-radius: var(--radius-sm); padding: 9px 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,.4);
}
.coach-ico { font-size: 17px; flex-shrink: 0; line-height: 1; }
.coach-main { flex: 1; min-width: 0; display: flex; flex-direction: column; line-height: 1.35; }
.coach-label {
  font-family: var(--font-ui); font-weight: 600; font-size: 10px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--amber);
}
.coach-text { color: var(--text); font-size: 12.5px; }
.coach-go { flex-shrink: 0; margin-top: 0; }
.coach-hide {
  flex-shrink: 0; margin-top: 0; padding: 4px 9px; color: var(--text-dim);
  border-color: var(--glass-line); font-size: 13px;
}
.coach-hide:hover { color: var(--red); border-color: var(--red); background: rgba(255,90,110,.1); box-shadow: none; }
@media (max-width: 760px) {
  .coach { bottom: 8px; width: calc(100% - 16px); gap: 7px; padding: 7px 9px; }
  .coach-go { display: none; }   /* schmale Screens: Platz sparen, „✕" bleibt */
}

/* ===== Atmende Neon-Ränder =====
   Sanftes Auf-/Abblenden der Rahmenfarbe an den drei Hauptflächen — reine Randfarbe,
   nicht box-shadow, damit bestehende Schatten (#topbar) unangetastet bleiben. */
@keyframes neonBreathe {
  0%, 100% { border-color: var(--border-cyan); }
  50% { border-color: rgba(56, 224, 255, 0.65); }
}
#topbar, #panel, .fleet { animation: neonBreathe 4s ease-in-out infinite; }

/* ===== Bewegungsreduktion (prefers-reduced-motion) =====
   Respektiert die System-Einstellung und schaltet die dauerhaft laufenden
   Flacker-/Blink-/Puls-Endlosschleifen ab. Kurze funktionale Übergänge
   (hover/focus-transitions) bleiben bewusst erhalten. */
@media (prefers-reduced-motion: reduce) {
  /* CRT-Flackern des Overlays */
  #crt { animation: none; }
  /* Blinkende Hinweise (u. a. Lobby-Status, #map-hint) */
  .blink, #map-hint { animation: none; }
  /* Diplomatie-Hinweis: Puls aus, Aufmerksamkeit über statische
     Randfarbe + statischen Schein statt Bewegung. */
  #t-diplo.alert { animation: none; box-shadow: 0 0 8px rgba(255,200,80,.5); }
  /* Atmende Neon-Ränder: statische Randfarbe statt Puls */
  #topbar, #panel, .fleet { animation: none; }
}
