/* ============================================================
   WAR OF GALAXY: REBORN — Stylesheet
   Perry Rhodan Sci-Fi Terminal Aesthetic
   Fonts: Orbitron (Headings), Share Tech Mono (Data), Exo 2 (Body)
   ============================================================ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
    --bg-deep:       #030810;
    --bg-panel:      rgba(0, 12, 28, 0.88);
    --bg-panel-alt:  rgba(0, 20, 45, 0.75);
    --blue:          #00AAFF;
    --blue-dim:      #005577;
    --blue-glow:     rgba(0, 170, 255, 0.25);
    --amber:         #F5A623;
    --amber-dim:     rgba(245, 166, 35, 0.6);
    --green:         #00FF88;
    --green-dim:     rgba(0, 255, 136, 0.7);
    --red:           #FF3344;
    --red-dim:       rgba(255, 51, 68, 0.7);
    --border:        rgba(0, 170, 255, 0.28);
    --border-bright: rgba(0, 170, 255, 0.6);
    --text:          #C8E0F0;
    --text-dim:      #6A8FA8;
    --text-bright:   #E8F4FF;
    --font-hud:      'Orbitron', monospace;
    --font-mono:     'Share Tech Mono', monospace;
    --font-body:     'Exo 2', sans-serif;
    --radius:        4px;
    --shadow-glow:   0 0 12px rgba(0, 170, 255, 0.35);
}

/* ── Reset & Base ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 14px; scroll-behavior: smooth; }

body {
    background: radial-gradient(ellipse at 20% 50%, #04122a 0%, #020810 60%, #000206 100%);
    color: var(--text);
    font-family: var(--font-body);
    min-height: 100vh;
    overflow-x: hidden;
}

a { color: var(--blue); text-decoration: none; transition: color .2s; }
a:hover { color: #fff; text-shadow: 0 0 8px var(--blue); }

/* ── Sternfeld ─────────────────────────────────────────────── */
.starfield {
    position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden;
}
.star {
    position: absolute; background: #fff; border-radius: 50%;
    animation: twinkle linear infinite;
}
@keyframes twinkle {
    0%,100% { opacity: 0.15; } 50% { opacity: 1; }
}

/* ── Rahmen ────────────────────────────────────────────────── */
.frame-top, .frame-bottom {
    position: relative; z-index: 10; display: flex; align-items: center;
    padding: 4px 8px; gap: 8px;
    border-bottom: 1px solid var(--border);
    background: rgba(0,8,20,0.9);
}
.frame-bottom { border-top: 1px solid var(--border); border-bottom: none; }
.frame-corner { color: var(--blue); font-size: 1.1rem; line-height: 1; }
.frame-line   { flex: 1; height: 1px; background: var(--border); }
.frame-label  { font-family: var(--font-hud); font-size: .6rem; color: var(--blue); letter-spacing: .12em; white-space: nowrap; }

/* ── Ressourcenleiste ─────────────────────────────────────── */
.resource-bar {
    display: flex; align-items: center; gap: 4px; padding: 4px 12px;
    background: rgba(0,10,22,0.95);
    border-bottom: 1px solid var(--border);
    position: relative; z-index: 9;
    flex-wrap: wrap;
}
.res-item { display: flex; align-items: center; gap: 5px; }
.res-icon  { font-size: .9rem; }
.res-label { font-family: var(--font-hud); font-size: .55rem; color: var(--blue); letter-spacing: .1em; }
.res-value { font-family: var(--font-mono); font-size: .85rem; color: var(--text-bright); }
.res-rate  { font-family: var(--font-mono); font-size: .7rem; color: var(--green-dim); }
.res-sep   { color: var(--border-bright); padding: 0 4px; }

/* ── Top Bar ─────────────────────────────────────────────── */
.top-bar {
    display: flex; align-items: center; justify-content: space-between; padding: 4px 12px;
    background: rgba(0,8,18,0.92);
    border-bottom: 1px solid var(--border);
    gap: 10px; flex-wrap: wrap;
    position: relative; z-index: 9;
}
.planet-form, .planet-label { display: flex; align-items: center; gap: 6px; }
.planet-label { font-family: var(--font-hud); font-size: .6rem; color: var(--blue); letter-spacing: .1em; }
.planet-select {
    background: rgba(0,20,40,0.9); color: var(--text-bright);
    border: 1px solid var(--border); border-radius: var(--radius);
    font-family: var(--font-mono); font-size: .8rem;
    padding: 3px 8px; cursor: pointer;
}
.planet-select:focus { outline: none; border-color: var(--blue); box-shadow: var(--shadow-glow); }
.user-info  { display: flex; align-items: center; gap: 8px; }
.alliance-tag { font-family: var(--font-hud); color: var(--amber); font-size: .75rem; }
.username   { font-family: var(--font-mono); color: var(--text-bright); }
.msg-btn    { font-family: var(--font-mono); font-size: .8rem; padding: 2px 8px; border: 1px solid var(--border); border-radius: var(--radius); }
.msg-btn.has-unread { border-color: var(--amber); color: var(--amber); box-shadow: 0 0 6px var(--amber-dim); }
.logout-btn { font-family: var(--font-hud); font-size: .55rem; padding: 3px 8px; border: 1px solid var(--border); border-radius: var(--radius); letter-spacing: .05em; }
.logout-btn:hover { border-color: var(--red); color: var(--red); }

/* ── Navigation ─────────────────────────────────────────────── */
.main-nav {
    display: flex; background: rgba(0,6,16,0.95);
    border-bottom: 2px solid var(--blue-dim);
    position: relative; z-index: 9; overflow-x: auto;
}
.nav-item {
    display: flex; flex-direction: column; align-items: center;
    padding: 6px 14px; gap: 2px;
    font-family: var(--font-hud); font-size: .5rem; letter-spacing: .08em;
    color: var(--text-dim); border-right: 1px solid var(--border);
    transition: all .2s; position: relative; white-space: nowrap;
}
.nav-item:hover, .nav-item.active {
    color: var(--blue); background: rgba(0,170,255,0.07);
    text-shadow: 0 0 8px var(--blue);
}
.nav-item.active { border-bottom: 2px solid var(--blue); }
.nav-icon { font-size: 1rem; }
.nav-badge {
    position: absolute; top: 4px; right: 4px;
    background: var(--amber); color: #000; border-radius: 50%;
    font-size: .55rem; width: 14px; height: 14px;
    display: flex; align-items: center; justify-content: center;
    font-weight: bold;
}

/* ── Content ─────────────────────────────────────────────── */
.content-area {
    max-width: 1400px; margin: 0 auto;
    padding: 16px 12px;
    position: relative; z-index: 1;
}

/* ── Flash Messages ──────────────────────────────────────── */
.flash-container { max-width: 1400px; margin: 8px auto; padding: 0 12px; }
.flash {
    padding: 8px 16px; border-radius: var(--radius); margin-bottom: 6px;
    font-family: var(--font-mono); font-size: .85rem;
}
.flash-success { background: rgba(0,255,136,0.1); border: 1px solid var(--green); color: var(--green); }
.flash-error   { background: rgba(255,51,68,0.1);  border: 1px solid var(--red);  color: var(--red); }
.flash-info    { background: rgba(0,170,255,0.1); border: 1px solid var(--blue); color: var(--blue); }

/* ── Page Header ─────────────────────────────────────────── */
.page-header { margin-bottom: 16px; }
.page-title {
    font-family: var(--font-hud); font-size: 1.4rem; color: var(--blue);
    text-shadow: 0 0 16px rgba(0,170,255,0.5);
    letter-spacing: .06em;
}
.page-subtitle { font-family: var(--font-mono); color: var(--text-dim); font-size: .85rem; margin-top: 4px; }
.planet-coords { font-family: var(--font-mono); color: var(--text-dim); font-size: .85rem; margin-top: 4px; }
.coords { color: var(--amber); margin-left: 6px; }
.homeworld-badge {
    font-family: var(--font-hud); font-size: .6rem; color: var(--amber);
    border: 1px solid var(--amber); padding: 2px 6px; border-radius: var(--radius);
    margin-left: 8px;
}
.shield-badge {
    font-family: var(--font-hud); font-size: .6rem; color: var(--green);
    border: 1px solid var(--green); padding: 2px 6px; border-radius: var(--radius);
    margin-left: 6px; animation: pulse-glow 2s ease-in-out infinite;
}
@keyframes pulse-glow {
    0%,100% { box-shadow: 0 0 4px var(--green); }
    50%      { box-shadow: 0 0 12px var(--green); }
}

/* ── Panels ──────────────────────────────────────────────── */
.panel {
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 14px;
    backdrop-filter: blur(6px);
}
.panel-header {
    font-family: var(--font-hud); font-size: .65rem; letter-spacing: .1em;
    color: var(--blue); padding: 8px 14px;
    border-bottom: 1px solid var(--border);
    background: rgba(0,170,255,0.05);
}
.panel-body { padding: 12px 14px; }
.empty-state { color: var(--text-dim); font-family: var(--font-mono); font-size: .85rem; text-align: center; padding: 12px; }

/* ── Alerts ──────────────────────────────────────────────── */
.alert {
    padding: 10px 16px; border-radius: var(--radius); margin-bottom: 12px;
    font-family: var(--font-mono); font-size: .85rem;
}
.alert-danger  { background: rgba(255,51,68,0.12);  border: 1px solid var(--red);   color: var(--red); }
.alert-warning { background: rgba(245,166,35,0.12); border: 1px solid var(--amber); color: var(--amber); }
.alert-info    { background: rgba(0,170,255,0.08);  border: 1px solid var(--blue);  color: var(--blue); }

/* ── Overview Grid ───────────────────────────────────────── */
.overview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 14px;
}

/* ── Ressourcenbalken ────────────────────────────────────── */
.res-row {
    display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
    font-family: var(--font-mono);
}
.res-icon-l { font-size: 1rem; width: 1.5rem; }
.res-name   { color: var(--text-dim); font-size: .75rem; width: 100px; }
.res-bar-wrap { flex: 1; height: 6px; background: rgba(255,255,255,0.08); border-radius: 3px; overflow: hidden; }
.res-bar { height: 100%; background: linear-gradient(90deg, var(--blue-dim), var(--blue)); border-radius: 3px; }
.res-amount { font-size: .85rem; color: var(--text-bright); width: 70px; text-align: right; }
.res-rate-sm { font-size: .75rem; width: 70px; }
.res-rate-sm.pos { color: var(--green-dim); }
.res-rate-sm.neg { color: var(--red-dim); }

/* ── Build Progress ──────────────────────────────────────── */
.build-progress {
    display: flex; justify-content: space-between; align-items: center;
    padding: 8px 10px; margin-bottom: 6px;
    border: 1px solid var(--border); border-radius: var(--radius);
    background: rgba(0,170,255,0.04);
}
.build-progress.research { border-color: var(--amber-dim); }
.build-progress.ships    { border-color: rgba(0,255,136,0.2); }
.build-name  { font-family: var(--font-mono); font-size: .85rem; }
.build-timer { font-family: var(--font-mono); font-size: .8rem; color: var(--amber); }
[data-countdown] { font-family: var(--font-mono); color: var(--amber); }
[data-countdown].done { color: var(--green); animation: blink .5s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }

/* ── Gebäude-Liste ───────────────────────────────────────── */
.building-list { display: flex; flex-direction: column; gap: 4px; }
.building-row {
    display: flex; align-items: center; gap: 8px; padding: 4px 8px;
    border-radius: var(--radius); font-family: var(--font-mono); font-size: .8rem;
}
.building-row.building-active { background: rgba(0,170,255,0.06); }
.b-icon  { font-size: 1rem; }
.b-name  { flex: 1; color: var(--text); }
.b-level { color: var(--blue); font-size: .75rem; white-space: nowrap; }
.b-timer { color: var(--amber); font-size: .75rem; }

/* ── Flottenliste ────────────────────────────────────────── */
.fleet-row {
    display: flex; gap: 10px; align-items: center; padding: 6px 8px;
    border-radius: var(--radius); margin-bottom: 4px; font-family: var(--font-mono); font-size: .8rem;
}
.fleet-row.outgoing { border-left: 3px solid var(--red); background: rgba(255,51,68,0.04); }
.fleet-row.returning { border-left: 3px solid var(--green); background: rgba(0,255,136,0.04); }
.fleet-mission { font-family: var(--font-hud); font-size: .6rem; letter-spacing: .08em; color: var(--blue); width: 100px; }
.fleet-target  { flex: 1; color: var(--text); }
.fleet-timer   { color: var(--amber); white-space: nowrap; }

/* ── Eingehende Flotten ──────────────────────────────────── */
.incoming-fleet { font-family: var(--font-mono); font-size: .85rem; margin-top: 6px; color: var(--red); }

/* ── Stats / Rankings ────────────────────────────────────── */
.stat-row, .ranking-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 5px 0; border-bottom: 1px solid rgba(255,255,255,0.04);
    font-family: var(--font-mono); font-size: .82rem;
}
.stat-row span:first-child { color: var(--text-dim); }
.ranking-row .rank-pos  { color: var(--text-dim); width: 22px; }
.ranking-row .rank-tag  { color: var(--amber); font-size: .8rem; }
.ranking-row .rank-name { flex: 1; padding: 0 6px; }
.ranking-row .rank-pts  { color: var(--blue); }
.ranking-row.own-row    { background: rgba(0,170,255,0.08); border-radius: var(--radius); }
.ranking-list { display: flex; flex-direction: column; }

/* ── Gebäude Kategorien & Karten ─────────────────────────── */
.building-category { margin-bottom: 24px; }
.category-title {
    font-family: var(--font-hud); font-size: .8rem; color: var(--amber);
    letter-spacing: .12em; padding: 0 0 8px; border-bottom: 1px solid var(--border);
    margin-bottom: 12px;
}
.building-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; }

.building-card {
    background: var(--bg-panel); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 14px; display: flex; gap: 12px;
    transition: border-color .2s, box-shadow .2s;
}
.building-card:hover { border-color: var(--border-bright); box-shadow: var(--shadow-glow); }
.building-card--active { border-color: var(--amber-dim); box-shadow: 0 0 8px var(--amber-dim); }
.building-card--locked { opacity: 0.55; }

.card-icon   { font-size: 2rem; flex-shrink: 0; }
.card-body   { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.card-name   { font-family: var(--font-hud); font-size: .75rem; color: var(--text-bright); letter-spacing: .05em; }
.card-level  { font-family: var(--font-mono); font-size: .75rem; color: var(--blue); }
.level-num   { font-size: 1rem; color: var(--amber); }
.card-desc   { font-size: .78rem; color: var(--text-dim); line-height: 1.5; }
.card-prod   { display: flex; gap: 6px; flex-wrap: wrap; }
.prod-badge  { font-family: var(--font-mono); font-size: .72rem; padding: 2px 6px; border-radius: 3px; }
.prod-badge.pos { background: rgba(0,255,136,0.1); color: var(--green); border: 1px solid rgba(0,255,136,0.3); }
.prod-badge.neg { background: rgba(255,51,68,0.1); color: var(--red); border: 1px solid rgba(255,51,68,0.3); }
.card-costs  { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.cost-item   { font-family: var(--font-mono); font-size: .72rem; padding: 2px 6px; border-radius: 3px; }
.cost-ok     { background: rgba(0,255,136,0.08); color: var(--green-dim); }
.cost-miss   { background: rgba(255,51,68,0.1); color: var(--red-dim); }
.cost-time   { font-family: var(--font-mono); font-size: .72rem; color: var(--text-dim); }
.card-maxed  { font-family: var(--font-mono); font-size: .75rem; color: var(--green); }
.card-locked { font-family: var(--font-mono); font-size: .75rem; color: var(--text-dim); }
.card-building-info { font-family: var(--font-mono); font-size: .75rem; color: var(--amber); }

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--font-hud); font-size: .6rem; letter-spacing: .08em;
    padding: 7px 16px; border-radius: var(--radius);
    border: 1px solid var(--blue); color: var(--blue);
    background: rgba(0,170,255,0.08); cursor: pointer;
    transition: all .2s; white-space: nowrap;
}
.btn:hover:not(:disabled) { background: rgba(0,170,255,0.18); box-shadow: var(--shadow-glow); color: #fff; }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }

.btn-build   { border-color: var(--blue); }
.btn-research{ border-color: var(--amber); color: var(--amber); background: rgba(245,166,35,0.08); }
.btn-research:hover:not(:disabled) { background: rgba(245,166,35,0.18); }
.btn-ship    { border-color: var(--green); color: var(--green); background: rgba(0,255,136,0.06); }
.btn-ship:hover:not(:disabled) { background: rgba(0,255,136,0.14); }
.btn-defense { border-color: var(--blue-dim); }
.btn-launch  { border-color: var(--red); color: var(--red); background: rgba(255,51,68,0.08); font-size: .7rem; padding: 10px 20px; }
.btn-launch:hover:not(:disabled) { background: rgba(255,51,68,0.18); box-shadow: 0 0 12px rgba(255,51,68,0.3); }
.btn-attack  { border-color: var(--red); color: var(--red); }
.btn-spy     { border-color: var(--amber); color: var(--amber); }
.btn-colonize{ border-color: var(--green); color: var(--green); }
.btn-scan    { font-family: var(--font-hud); font-size: .6rem; padding: 6px 14px; border: 1px solid var(--blue); color: var(--blue); background: rgba(0,170,255,0.08); border-radius: var(--radius); cursor: pointer; }
.btn-send    { border-color: var(--green); color: var(--green); padding: 10px 24px; }
.btn-trade   { border-color: var(--amber); color: var(--amber); background: rgba(245,166,35,0.08); }
.btn-trade:hover { background: rgba(245,166,35,0.18); }
.btn-alliance{ border-color: var(--amber); color: var(--amber); padding: 10px 24px; }
.btn-danger  { border-color: var(--red); color: var(--red); background: rgba(255,51,68,0.08); }
.btn-danger:hover { background: rgba(255,51,68,0.2); }
.btn-sm {
    display: inline-flex; align-items: center; gap: 4px;
    font-family: var(--font-hud); font-size: .55rem; letter-spacing: .06em;
    padding: 4px 10px; border-radius: var(--radius);
    border: 1px solid var(--border); color: var(--text-dim);
    background: rgba(0,12,28,0.6); cursor: pointer; transition: all .2s;
}
.btn-sm:hover { border-color: var(--blue); color: var(--blue); }
.btn-sm.btn-attack:hover  { border-color: var(--red); color: var(--red); }
.btn-sm.btn-spy:hover     { border-color: var(--amber); color: var(--amber); }
.btn-sm.btn-danger:hover  { border-color: var(--red); color: var(--red); }
.btn-sm.btn-trade:hover   { border-color: var(--amber); color: var(--amber); }

/* ── Forschung ───────────────────────────────────────────── */
.active-research-banner {
    display: flex; align-items: center; gap: 12px; padding: 8px 16px;
    background: rgba(245,166,35,0.08); border: 1px solid var(--amber-dim);
    border-radius: var(--radius); margin-bottom: 16px;
    font-family: var(--font-mono);
}
.ar-label { font-family: var(--font-hud); font-size: .6rem; color: var(--amber); letter-spacing: .08em; }
.ar-name  { flex: 1; color: var(--text-bright); }
.ar-timer { color: var(--amber); font-size: .85rem; }

.research-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 12px; }

.research-card {
    background: var(--bg-panel); border: 1px solid var(--border); border-radius: var(--radius);
    padding: 14px; display: flex; gap: 12px; transition: border-color .2s;
}
.research-card:hover { border-color: var(--border-bright); }
.research-card.researching { border-color: var(--amber-dim); }
.research-card.locked { opacity: .5; }
.rc-icon { font-size: 2rem; flex-shrink: 0; }
.rc-body { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.rc-name { font-family: var(--font-hud); font-size: .72rem; color: var(--text-bright); }
.rc-level { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: .72rem; color: var(--text-dim); }
.level-bar { display: flex; gap: 2px; }
.level-pip { width: 10px; height: 4px; background: rgba(255,255,255,0.1); border-radius: 2px; transition: background .3s; }
.level-pip.filled { background: var(--blue); }
.rc-desc   { font-size: .78rem; color: var(--text-dim); line-height: 1.5; }
.rc-effect { display: flex; gap: 6px; flex-wrap: wrap; }
.effect-tag { font-family: var(--font-mono); font-size: .7rem; padding: 2px 6px; background: rgba(0,170,255,0.1); border: 1px solid var(--border); border-radius: 3px; color: var(--blue); }
.rc-active  { font-family: var(--font-mono); font-size: .75rem; color: var(--amber); }
.rc-maxed   { font-family: var(--font-mono); font-size: .75rem; color: var(--green); }
.rc-locked  { font-family: var(--font-mono); font-size: .75rem; color: var(--text-dim); }

/* ── Schiffe / Werft ─────────────────────────────────────── */
.section-title {
    font-family: var(--font-hud); font-size: .8rem; color: var(--amber);
    letter-spacing: .12em; margin: 16px 0 10px;
    border-bottom: 1px solid var(--border); padding-bottom: 6px;
}
.ship-cards, .defense-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-bottom: 14px; }
.ship-queue-panel { margin-bottom: 14px; }
.queue-list { display: flex; flex-direction: column; gap: 6px; }
.queue-row { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: .82rem; }
.q-timer { color: var(--amber); margin-left: auto; }

.ship-card {
    background: var(--bg-panel); border: 1px solid var(--border); border-radius: var(--radius);
    padding: 14px; display: flex; flex-direction: column; gap: 8px;
    transition: border-color .2s, box-shadow .2s;
}
.ship-card:hover { border-color: var(--border-bright); box-shadow: var(--shadow-glow); }
.ship-card.ship-locked { opacity: .5; }
.ship-header { display: flex; align-items: center; gap: 10px; }
.ship-icon   { font-size: 1.8rem; }
.ship-name   { font-family: var(--font-hud); font-size: .72rem; color: var(--text-bright); }
.ship-class  { font-size: .7rem; color: var(--text-dim); font-family: var(--font-mono); }
.ship-count-badge {
    margin-left: auto; font-family: var(--font-hud); font-size: .75rem;
    color: var(--amber); background: rgba(245,166,35,0.1);
    border: 1px solid var(--amber-dim); padding: 2px 8px; border-radius: var(--radius);
}
.ship-stats { display: flex; gap: 8px; flex-wrap: wrap; font-family: var(--font-mono); font-size: .75rem; color: var(--text-dim); }
.ship-stats span { white-space: nowrap; }
.special-tag { color: var(--amber); font-size: .68rem; }
.ship-desc { font-size: .76rem; color: var(--text-dim); line-height: 1.5; }
.ship-costs { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.ship-req   { font-family: var(--font-mono); font-size: .75rem; color: var(--text-dim); }
.ship-form  { display: flex; gap: 6px; align-items: center; }
.count-input {
    width: 70px; font-family: var(--font-mono); font-size: .85rem;
    background: rgba(0,20,40,0.8); color: var(--text-bright);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 4px 8px;
}
.count-input:focus { outline: none; border-color: var(--blue); }
.btn-all {
    font-family: var(--font-hud); font-size: .55rem; padding: 4px 8px;
    border: 1px solid var(--border); border-radius: var(--radius);
    background: rgba(0,170,255,0.06); color: var(--text-dim); cursor: pointer;
}
.btn-all:hover { border-color: var(--blue); color: var(--blue); }

/* ── Tabellen ────────────────────────────────────────────── */
.wog-table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: .8rem; }
.wog-table th {
    text-align: left; font-family: var(--font-hud); font-size: .6rem; letter-spacing: .08em;
    color: var(--blue); padding: 8px 10px; border-bottom: 1px solid var(--border);
    background: rgba(0,170,255,0.04);
}
.wog-table td { padding: 7px 10px; border-bottom: 1px solid rgba(255,255,255,0.04); }
.wog-table tr:hover td { background: rgba(0,170,255,0.04); }
.row-own td { background: rgba(0,170,255,0.06) !important; }
.row-return td { background: rgba(0,255,136,0.04); }
.row-outgoing td { }
.row-unread { font-weight: bold; }
.row-empty td { color: var(--text-dim); font-style: italic; }
.row-destroyed td { opacity: .5; }
.mission-tag {
    font-family: var(--font-hud); font-size: .6rem; padding: 2px 6px;
    border-radius: 3px; letter-spacing: .05em;
}
.mission-attack  { background: rgba(255,51,68,0.15); color: var(--red); border: 1px solid rgba(255,51,68,0.3); }
.mission-transport { background: rgba(0,255,136,0.08); color: var(--green); border: 1px solid rgba(0,255,136,0.2); }
.mission-espionage { background: rgba(245,166,35,0.1); color: var(--amber); border: 1px solid var(--amber-dim); }
.mission-colonize  { background: rgba(0,170,255,0.1); color: var(--blue); border: 1px solid var(--border); }
.ship-summary { font-size: .72rem; color: var(--text-dim); max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tag-success { color: var(--green); }
.tag-fail    { color: var(--red); }

/* ── Flotte ──────────────────────────────────────────────── */
.fleet-overview { margin-bottom: 14px; }
.fleet-dispatch .panel-body { display: flex; flex-direction: column; gap: 14px; }
.target-search { display: flex; flex-direction: column; gap: 10px; }
.target-form   { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.target-form label { font-family: var(--font-hud); font-size: .6rem; color: var(--blue); }
.coord-input {
    font-family: var(--font-mono); font-size: .9rem;
    background: rgba(0,20,40,0.8); color: var(--text-bright);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 6px 12px; width: 160px;
}
.coord-input:focus { outline: none; border-color: var(--blue); box-shadow: var(--shadow-glow); }
.target-info {
    display: flex; gap: 12px; align-items: center;
    padding: 8px 12px; background: rgba(0,170,255,0.06); border: 1px solid var(--border); border-radius: var(--radius);
}
.t-coords { font-family: var(--font-mono); color: var(--amber); }
.t-name   { font-family: var(--font-hud); font-size: .72rem; color: var(--text-bright); }
.t-owner  { font-family: var(--font-mono); font-size: .75rem; color: var(--text-dim); }
.unowned  { color: var(--green-dim); }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-label { font-family: var(--font-hud); font-size: .6rem; color: var(--blue); letter-spacing: .08em; }
.mission-buttons { display: flex; gap: 8px; flex-wrap: wrap; }
.mission-btn { cursor: pointer; }
.mission-btn input { display: none; }
.mission-btn span {
    display: inline-flex; align-items: center; gap: 4px; padding: 5px 12px;
    border: 1px solid var(--border); border-radius: var(--radius);
    font-family: var(--font-hud); font-size: .6rem; color: var(--text-dim);
    transition: all .2s; letter-spacing: .05em;
}
.mission-btn input:checked + span { border-color: var(--blue); color: var(--blue); background: rgba(0,170,255,0.12); }
.ship-select-grid { display: flex; flex-direction: column; gap: 4px; }
.ship-select-row { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: .82rem; }
.ss-icon  { font-size: 1.1rem; }
.ss-name  { flex: 1; color: var(--text); }
.ss-avail { color: var(--text-dim); font-size: .72rem; }
.ss-count { width: 80px; }
.cargo-group .cargo-inputs { display: flex; gap: 12px; flex-wrap: wrap; }
.cargo-inputs label { font-family: var(--font-mono); font-size: .8rem; color: var(--text-dim); display: flex; flex-direction: column; gap: 4px; }
.cargo-input { width: 120px; font-family: var(--font-mono); font-size: .85rem; background: rgba(0,20,40,0.8); color: var(--text-bright); border: 1px solid var(--border); border-radius: var(--radius); padding: 4px 8px; }
.action-cell { white-space: nowrap; display: flex; gap: 4px; }
.own-badge, .cant-afford { font-family: var(--font-mono); font-size: .72rem; color: var(--text-dim); }

/* ── Galaxie ─────────────────────────────────────────────── */
.galaxy-nav { display: flex; gap: 4px; margin-bottom: 12px; flex-wrap: wrap; }
.galaxy-tab {
    font-family: var(--font-hud); font-size: .6rem; letter-spacing: .06em;
    padding: 6px 14px; border: 1px solid var(--border); border-radius: var(--radius);
    color: var(--text-dim); transition: all .2s;
}
.galaxy-tab.active { border-color: var(--blue); color: var(--blue); background: rgba(0,170,255,0.1); }
.bonus-tag { font-size: .55rem; color: var(--green-dim); margin-left: 4px; }
.galaxy-layout { display: grid; grid-template-columns: 160px 1fr; gap: 12px; }
.system-list-panel { background: var(--bg-panel); border: 1px solid var(--border); border-radius: var(--radius); }
.system-scroll { max-height: 600px; overflow-y: auto; }
.system-entry {
    display: flex; gap: 8px; align-items: center; padding: 5px 10px;
    border-bottom: 1px solid rgba(255,255,255,0.03);
    font-family: var(--font-mono); font-size: .75rem; cursor: pointer; transition: background .15s;
}
.system-entry:hover, .system-entry.selected { background: rgba(0,170,255,0.1); color: var(--text-bright); }
.sys-num { color: var(--blue); font-size: .7rem; }
.sys-planets { color: var(--text-dim); font-size: .65rem; letter-spacing: .1em; }
.system-detail { background: var(--bg-panel); border: 1px solid var(--border); border-radius: var(--radius); }

/* Solar System Visual */
.solar-system {
    position: relative; height: 180px; display: flex; align-items: center;
    padding: 0 20px; overflow: hidden; background: rgba(0,5,15,0.5);
}
.star { position: absolute; left: 20px; font-size: 1.8rem; color: #FFD700; text-shadow: 0 0 20px #FF8800; }
.planet-dot {
    width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center;
    justify-content: center; font-size: .55rem; font-family: var(--font-mono); cursor: pointer;
    transition: transform .2s; position: absolute;
}
.planet-dot:hover { transform: scale(1.4); }
.orbit { position: absolute; left: 40px; top: 50%; transform: translateY(-50%); }
.orbit:nth-child(n) { left: calc(40px + (var(--orbit) - 1) * 74px); }
.planet-own    { background: var(--blue); box-shadow: 0 0 8px var(--blue); color: #000; }
.planet-enemy  { background: var(--red); box-shadow: 0 0 6px var(--red); color: #fff; }
.planet-empty  { background: rgba(100,180,255,0.3); color: var(--text-dim); }
.planet-none   { background: transparent; color: var(--text-dim); font-size: .9rem; }
.galaxy-table .player-link { color: var(--text); }
.galaxy-table .player-link:hover { color: var(--blue); }

/* ── Spionage ────────────────────────────────────────────── */
.spy-info-box { display: flex; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.spy-info-item {
    flex: 1; min-width: 180px; background: var(--bg-panel);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 14px;
}
.si-label { font-family: var(--font-hud); font-size: .55rem; color: var(--text-dim); letter-spacing: .08em; display: block; margin-bottom: 4px; }
.si-value { font-family: var(--font-mono); font-size: .9rem; color: var(--blue); }
.spy-launch-info p { font-family: var(--font-mono); font-size: .82rem; color: var(--text); margin-bottom: 6px; line-height: 1.6; }
.spy-report-detail { margin-bottom: 14px; }
.report-success { color: var(--green); font-family: var(--font-hud); font-size: .7rem; margin-bottom: 10px; }
.report-fail    { color: var(--red); font-family: var(--font-hud); font-size: .7rem; }
.report-section { font-family: var(--font-hud); font-size: .65rem; color: var(--amber); margin: 10px 0 6px; letter-spacing: .08em; }
.report-res, .report-buildings, .report-ships, .report-research { display: flex; gap: 8px; flex-wrap: wrap; }
.report-res span, .rb-item, .rs-item, .rr-item {
    font-family: var(--font-mono); font-size: .78rem; padding: 3px 8px;
    background: rgba(0,170,255,0.08); border: 1px solid var(--border); border-radius: 3px;
}
.report-actions { display: flex; gap: 8px; margin-top: 12px; }

/* ── Handel ──────────────────────────────────────────────── */
.trade-layout { display: flex; flex-direction: column; gap: 14px; }
.create-offer-panel, .my-offers-panel, .market-panel { }
.trade-form { display: flex; flex-direction: column; gap: 10px; }
.trade-row  { display: flex; align-items: flex-end; gap: 16px; flex-wrap: wrap; }
.trade-field { display: flex; flex-direction: column; gap: 6px; flex: 1; min-width: 180px; }
.trade-field label { font-family: var(--font-hud); font-size: .6rem; color: var(--blue); }
.trade-select {
    background: rgba(0,20,40,0.85); color: var(--text-bright);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 6px 10px;
    font-family: var(--font-mono); font-size: .85rem; cursor: pointer;
}
.trade-amount {
    font-family: var(--font-mono); font-size: .85rem;
    background: rgba(0,20,40,0.85); color: var(--text-bright);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 6px 10px; width: 100%;
}
.trade-arrow { font-size: 1.4rem; color: var(--border-bright); padding-bottom: 8px; }
.trade-note  { font-family: var(--font-mono); font-size: .72rem; color: var(--text-dim); }
.market-filter { display: flex; gap: 6px; margin-bottom: 10px; flex-wrap: wrap; }
.filter-btn {
    font-family: var(--font-hud); font-size: .58rem; letter-spacing: .06em;
    padding: 4px 10px; border: 1px solid var(--border); border-radius: var(--radius);
    color: var(--text-dim); background: rgba(0,12,28,0.6); cursor: pointer; transition: all .2s;
}
.filter-btn.active { border-color: var(--amber); color: var(--amber); background: rgba(245,166,35,0.1); }
.res-amount-display { font-family: var(--font-mono); }
.rate-cell { color: var(--text-dim); font-size: .75rem; }

/* ── Allianz ─────────────────────────────────────────────── */
.alli-choice { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 14px; margin-bottom: 14px; }
.alli-layout { display: flex; flex-direction: column; gap: 14px; }
.alli-name-big { font-family: var(--font-hud); font-size: 1.1rem; color: var(--text-bright); margin-bottom: 10px; }
.alli-stats { margin-bottom: 10px; }
.as-row { display: flex; justify-content: space-between; padding: 5px 0; border-bottom: 1px solid rgba(255,255,255,0.04); font-family: var(--font-mono); font-size: .82rem; }
.as-row span:first-child { color: var(--text-dim); }
.alli-desc { font-family: var(--font-mono); font-size: .8rem; color: var(--text); line-height: 1.6; margin-top: 8px; padding: 8px; background: rgba(0,170,255,0.04); border-radius: var(--radius); }
.leave-form { margin-top: 12px; }
.rank-badge { font-family: var(--font-hud); font-size: .6rem; padding: 2px 6px; border-radius: 3px; letter-spacing: .05em; }
.rank-leader  { background: rgba(245,166,35,0.2); color: var(--amber); border: 1px solid var(--amber-dim); }
.rank-officer { background: rgba(0,170,255,0.1); color: var(--blue); border: 1px solid var(--border); }
.rank-member  { background: rgba(100,120,140,0.15); color: var(--text-dim); border: 1px solid rgba(100,120,140,0.3); }
.dip-badge { font-family: var(--font-hud); font-size: .62rem; padding: 3px 8px; border-radius: 3px; letter-spacing: .05em; }
.dip-nap    { background: rgba(0,255,136,0.1); color: var(--green); border: 1px solid rgba(0,255,136,0.3); }
.dip-bund   { background: rgba(0,170,255,0.1); color: var(--blue); border: 1px solid var(--border); }
.dip-krieg  { background: rgba(255,51,68,0.15); color: var(--red); border: 1px solid rgba(255,51,68,0.3); }
.dip-pending_nap, .dip-pending_bund { background: rgba(245,166,35,0.1); color: var(--amber); border: 1px solid var(--amber-dim); }
.dip-form { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-top: 10px; }
.wog-select, .wog-input {
    background: rgba(0,20,40,0.85); color: var(--text-bright);
    border: 1px solid var(--border); border-radius: var(--radius);
    font-family: var(--font-mono); font-size: .85rem; padding: 6px 10px;
}
.wog-select:focus, .wog-input:focus, .trade-amount:focus, .trade-select:focus {
    outline: none; border-color: var(--blue); box-shadow: var(--shadow-glow);
}
.alli-tag { color: var(--amber); }
.inline-form { display: inline; }
.mt-2 { margin-top: 16px; }

/* ── Nachrichten ─────────────────────────────────────────── */
.msg-layout { display: grid; grid-template-columns: 280px 1fr; gap: 12px; }
.msg-sidebar { background: var(--bg-panel); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.msg-tabs { display: flex; flex-direction: column; border-bottom: 1px solid var(--border); }
.msg-tab {
    padding: 10px 14px; font-family: var(--font-hud); font-size: .62rem; letter-spacing: .06em;
    color: var(--text-dim); border-bottom: 1px solid var(--border); transition: all .2s;
    display: flex; align-items: center; gap: 6px;
}
.msg-tab:hover, .msg-tab.active { color: var(--blue); background: rgba(0,170,255,0.08); }
.badge-unread {
    margin-left: auto; background: var(--amber); color: #000;
    border-radius: 50%; font-size: .6rem; width: 16px; height: 16px;
    display: flex; align-items: center; justify-content: center; font-weight: bold;
}
.msg-list { overflow-y: auto; max-height: 500px; }
.msg-list-actions { padding: 4px 8px; border-bottom: 1px solid rgba(255,255,255,0.04); }
.msg-item {
    display: flex; flex-direction: column; gap: 2px; padding: 8px 12px;
    border-bottom: 1px solid rgba(255,255,255,0.04); cursor: pointer; transition: background .15s;
}
.msg-item:hover, .msg-item.msg-selected { background: rgba(0,170,255,0.08); }
.msg-item.msg-unread .mi-subject { color: var(--text-bright); font-weight: bold; }
.mi-from    { font-family: var(--font-hud); font-size: .58rem; color: var(--blue); letter-spacing: .05em; }
.mi-subject { font-family: var(--font-mono); font-size: .78rem; color: var(--text); }
.mi-date    { font-size: .68rem; color: var(--text-dim); }
.msg-main { background: var(--bg-panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; }
.compose-title { font-family: var(--font-hud); font-size: .8rem; color: var(--amber); margin-bottom: 12px; letter-spacing: .08em; }
.compose-form  { display: flex; flex-direction: column; gap: 10px; }
.compose-form .form-group label { font-family: var(--font-hud); font-size: .58rem; color: var(--blue); display: block; margin-bottom: 4px; }
.wog-textarea {
    font-family: var(--font-mono); font-size: .82rem;
    background: rgba(0,20,40,0.85); color: var(--text-bright);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 8px 12px;
    width: 100%; resize: vertical;
}
.wog-textarea:focus { outline: none; border-color: var(--blue); }
.msg-detail { }
.md-header { border-bottom: 1px solid var(--border); padding-bottom: 10px; margin-bottom: 12px; }
.md-subject { font-family: var(--font-hud); font-size: .9rem; color: var(--text-bright); margin-bottom: 4px; }
.md-meta    { font-family: var(--font-mono); font-size: .75rem; color: var(--text-dim); }
.md-body    { font-family: var(--font-mono); font-size: .82rem; color: var(--text); line-height: 1.7; white-space: pre-wrap; }
.md-actions { display: flex; gap: 8px; margin-top: 14px; }

/* ── Footer ──────────────────────────────────────────────── */
.main-footer { padding: 8px 12px; position: relative; z-index: 9; }
.footer-line { display: flex; align-items: center; gap: 12px; justify-content: center; flex-wrap: wrap; }
.footer-text { font-family: var(--font-hud); font-size: .55rem; color: var(--text-dim); letter-spacing: .06em; }
.footer-sep  { color: var(--border-bright); }

/* ── Login-Seite ─────────────────────────────────────────── */
.login-page { display: flex; justify-content: center; align-items: center; min-height: 100vh; }
.login-container { width: 100%; max-width: 460px; padding: 20px; position: relative; z-index: 1; }
.login-box {
    background: rgba(0,8,20,0.92);
    border: 1px solid var(--border);
    border-radius: 6px; padding: 32px;
    box-shadow: 0 0 40px rgba(0,100,200,0.2), 0 0 2px var(--border);
}
.login-logo { text-align: center; margin-bottom: 24px; }
.logo-emblem { font-size: 2.5rem; margin-bottom: 8px; }
.logo-title {
    font-family: var(--font-hud); font-size: 1.6rem; color: var(--blue);
    text-shadow: 0 0 20px rgba(0,170,255,0.6); letter-spacing: .12em; margin-bottom: 4px;
}
.logo-subtitle { font-family: var(--font-mono); font-size: .7rem; color: var(--text-dim); letter-spacing: .1em; }
.logo-round { font-family: var(--font-hud); font-size: .6rem; color: var(--amber); margin-top: 6px; letter-spacing: .08em; }
.login-msg   { font-family: var(--font-mono); font-size: .82rem; color: var(--blue); text-align: center; margin-bottom: 12px; }
.login-error { font-family: var(--font-mono); font-size: .82rem; color: var(--red); text-align: center; margin-bottom: 12px; padding: 8px; background: rgba(255,51,68,0.08); border: 1px solid rgba(255,51,68,0.3); border-radius: var(--radius); }
.login-form  { display: flex; flex-direction: column; gap: 14px; }
.login-field { display: flex; flex-direction: column; gap: 4px; }
.login-label { font-family: var(--font-hud); font-size: .58rem; color: var(--blue); letter-spacing: .1em; }
.login-input {
    font-family: var(--font-mono); font-size: .95rem;
    background: rgba(0,20,45,0.9); color: var(--text-bright);
    border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 14px;
    transition: border-color .2s, box-shadow .2s;
}
.login-input:focus { outline: none; border-color: var(--blue); box-shadow: var(--shadow-glow); }
.login-btn {
    font-family: var(--font-hud); font-size: .7rem; letter-spacing: .12em;
    padding: 12px; border: 1px solid var(--blue); color: var(--blue);
    background: rgba(0,170,255,0.08); border-radius: var(--radius); cursor: pointer;
    transition: all .3s; margin-top: 4px;
}
.login-btn:hover {
    background: rgba(0,170,255,0.2); box-shadow: 0 0 18px rgba(0,170,255,0.4);
    color: #fff; letter-spacing: .15em;
}
.login-footer { text-align: center; margin-top: 16px; }
.register-link { font-family: var(--font-mono); font-size: .8rem; color: var(--amber); }
.register-link:hover { color: #fff; }
.login-tos { font-family: var(--font-mono); font-size: .72rem; color: var(--text-dim); text-align: center; line-height: 1.5; }
.login-lore {
    margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border);
    font-family: var(--font-mono); font-size: .75rem; color: var(--text-dim);
    text-align: center; line-height: 1.7;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 900px) {
    .galaxy-layout  { grid-template-columns: 1fr; }
    .msg-layout     { grid-template-columns: 1fr; }
    .overview-grid  { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .main-nav .nav-label { display: none; }
    .nav-item { padding: 8px; }
    .resource-bar { font-size: .75rem; }
    .building-cards { grid-template-columns: 1fr; }
    .research-grid  { grid-template-columns: 1fr; }
    .ship-cards, .defense-cards { grid-template-columns: 1fr; }
}

/* ── Scrollbar ───────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: rgba(0,10,20,0.5); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--blue); }
