/* ============================================================
   GLASSMORPHISM LIGHT DESIGN SYSTEM
   Hellgraues Design wie im Referenz-Screenshot
   ============================================================ */

/* ---- FONT ---- */
/* Inter wird per <link> im Header geladen */

/* ---- GLOBAL BASE ---- */

*, *::before, *::after {
  box-sizing: border-box;
  text-shadow: none !important;
}

body.ui-reboot,
body.ui-reboot.ng-shell {
  background: #e8e9ec !important;
  color: #1a202c !important;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  -webkit-font-smoothing: antialiased;
}

/* Kill alle Terminal/CRT/Scanline/Noise-Effekte */
.hud-scanlines::before,
.hud-scanlines::after,
.ng-crt-surface::before,
.ng-crt-surface::after,
.ng-crt-curved::before,
.ng-crt-curved::after,
.ng-demo1-surface .noise,
.ng-demo1-surface .overlay,
.ng-radar-scanline,
.ng-preloader-gear {
  display: none !important;
}

/* Kill CRT-Animationen */
.header-avatar.ng-crt-avatar,
.ng-crt-surface,
.ng-crt-curved {
  animation: none !important;
}

/* ============================================================
   SIDEBAR / LEFT PANEL
   ============================================================ */

/* Shell-Grid: immer 70px Sidebar + Rest */
.ui-shell,
.ui-shell.ui-shell--modules,
.ui-shell.ui-shell--modules.panel-left-collapsed,
.ui-shell.ui-shell--modules.panel-left-visible {
  grid-template-columns: 70px 1fr !important;
  --panel-left-width: 70px !important;
  gap: 0 !important;
}

/* Panel immer sichtbar */
.ui-panel-left {
  grid-area: left !important;
  width: 70px !important;
  min-width: 70px !important;
  max-width: 70px !important;
  background: rgba(255, 255, 255, 0.5) !important;
  border-right: 1px solid rgba(0, 0, 0, 0.07) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  overflow: visible !important;
  z-index: 200 !important;
}

/* Collapsed-State: Panel trotzdem sichtbar */
.ui-shell.panel-left-collapsed .ng-left-panel,
.ui-shell.panel-left-collapsed .ui-panel-left,
.ui-shell.panel-left-visible .ng-left-panel,
.ui-shell.panel-left-visible .ui-panel-left {
  width: 70px !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  display: flex !important;
  transform: none !important;
}

.ng-left-panel {
  width: 70px !important;
  min-width: 70px !important;
  max-width: 70px !important;
  height: 100vh !important;
  position: sticky !important;
  top: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 12px 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

.ng-left-content {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  padding: 0 !important;
}

.ng-left-panel .ng-left-section {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.ng-left-panel .ng-left-section::before,
.ng-left-panel .ng-left-section::after,
.ng-left-panel .hud-title-bar,
.ng-left-panel .hud-divider {
  display: none !important;
}

.ng-left-panel .ui-frame__body {
  padding: 0 !important;
}

/* Nav-Liste: Icons zentriert */
.ng-left-nav-list {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}

.ng-left-nav-list li {
  width: 46px !important;
  height: 46px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Icon-Links: kein Border, kein Hintergrund */
.ng-left-nav-list li .ng-left-link {
  width: 44px !important;
  height: 44px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 12px !important;
  background: transparent !important;
  border: none !important;
  color: rgba(0, 0, 0, 0.4) !important;
  transition: all 0.15s ease !important;
  cursor: pointer !important;
  text-decoration: none !important;
}

.ng-left-nav-list li .ng-left-link i {
  font-size: 22px !important;
  line-height: 1 !important;
  color: inherit !important;
}

.ng-left-nav-list li .ng-left-link:hover {
  background: rgba(0, 0, 0, 0.06) !important;
  color: rgba(0, 0, 0, 0.75) !important;
}

/* Logout ganz unten */
.ng-left-logout {
  margin-top: auto !important;
  width: 46px !important;
  height: 46px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.ng-left-logout .ng-left-link {
  background: transparent !important;
  border: none !important;
  color: rgba(220, 38, 38, 0.55) !important;
}

.ng-left-logout .ng-left-link:hover {
  background: rgba(220, 38, 38, 0.08) !important;
  color: #dc2626 !important;
}

.ng-left-logout .ng-left-link i {
  font-size: 22px !important;
  color: inherit !important;
}

/* Sidebar-Sektionen die nicht passen ausblenden */
.ng-left-panel .ng-left-section[data-section="city-stats"],
.ng-left-panel .ng-left-section[data-section="resource-diagnostics"] {
  display: none !important;
}

/* ============================================================
   HEADER
   ============================================================ */

/* Basis-Header-Styles */
.ui-shell-header,
.ui-shell-header.ui-panel-header {
  grid-area: header !important;
  height: 56px !important;
  min-height: 56px !important;
  max-height: 56px !important;
  z-index: 1000 !important;
}

/* Alle Pseudo-Elemente des Headers entfernen */
.ui-shell-header::before,
.ui-shell-header::after {
  display: none !important;
}

/* Avatar komplett ausblenden */
.ng-header-top-left,
body.ui-reboot .ui-shell-header.ui-panel-header > .ng-header-top-left {
  display: none !important;
}

.header-avatar,
.header-avatar.ng-crt-avatar {
  display: none !important;
}

.header-avatar::before,
.header-avatar::after,
.header-avatar.ng-crt-avatar::before,
.header-avatar.ng-crt-avatar::after {
  display: none !important;
  content: none !important;
}

/* Username/Meta ausblenden */
.ui-hud-meta,
.ui-hud-name,
.personal-symbols,
.panel-toggle-btn--left {
  display: none !important;
}

/* Header-Mitte: Tabs */
.ng-header-middle,
body.ui-reboot .ui-shell-header.ui-panel-header > .ng-header-middle {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  padding-left: 4px !important;
}

/* Comm-Tabs Container */
.ui-hud-comm-tabs {
  background: transparent !important;
  border: none !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
}

.ng-header-comm-wrap {
  display: flex !important;
  align-items: center !important;
  height: 100% !important;
  width: 100% !important;
  flex-direction: row !important;
  gap: 4px !important;
}

.ng-header-city-switcher-slot {
  display: none !important;
}

.ng-header-comm-row {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
}

/* Tab-Buttons */
.ng-header-comm-row .tab,
.ng-header-comm-row .ng-comm-tab-btn,
.ng-sections-tabs .tab,
.ng-sections-tabs .tab-group__item {
  height: 34px !important;
  padding: 0 14px !important;
  border-radius: 10px !important;
  background: transparent !important;
  border: none !important;
  color: rgba(0, 0, 0, 0.5) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: all 0.15s ease !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  white-space: nowrap !important;
  line-height: 1 !important;
}

.ng-header-comm-row .tab:hover,
.ng-header-comm-row .ng-comm-tab-btn:hover,
.ng-sections-tabs .tab:hover {
  background: rgba(0, 0, 0, 0.06) !important;
  color: rgba(0, 0, 0, 0.8) !important;
}

.ng-header-comm-row .tab.is-active,
.ng-header-comm-row .ng-comm-tab-btn.is-active,
.ng-sections-tabs .tab.is-active,
.ng-sections-tabs .tab-group__item.is-active {
  background: rgba(59, 130, 246, 0.12) !important;
  color: #2563eb !important;
  font-weight: 600 !important;
}

.ng-sections-tabs {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
}

.tab-group {
  display: contents !important;
}

/* Job-Indikatoren auf Tabs */
.tab.is-build-active::after,
.tab.is-tech-active::after,
.tab.is-defense-active::after,
.tab.is-hangar-active::after {
  content: '' !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: #3b82f6 !important;
  flex-shrink: 0 !important;
  animation: none !important;
  box-shadow: none !important;
}

/* Header-Rechts: City-Switcher + Ressourcen */
.ng-header-top-right,
body.ui-reboot .ui-shell-header.ui-panel-header > .ng-header-top-right {
  flex: 0 0 auto !important;
  width: auto !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding-right: 0 !important;
}

.ui-hud-block--center,
body.ui-reboot .ui-shell-header.ui-panel-header > .ng-header-top-right .ui-hud-block.ui-hud-block--center {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  height: 100% !important;
  padding: 0 !important;
  width: auto !important;
}

.ui-hud-top-row {
  display: flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  height: 100% !important;
}

/* City-Switcher-Actions */
.ng-city-switcher-actions {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
}

.ng-city-switcher {
  position: relative !important;
}

/* City-Switcher */
.ng-city-switcher-btn {
  height: 34px !important;
  padding: 0 10px !important;
  border-radius: 10px !important;
  background: rgba(0, 0, 0, 0.05) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  color: #1a202c !important;
  font-size: 12px !important;
  font-family: 'Inter', sans-serif !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  white-space: nowrap !important;
}

.ng-city-switcher-btn:hover {
  background: rgba(0, 0, 0, 0.08) !important;
}

.ng-city-switcher-dropdown {
  background: rgba(255, 255, 255, 0.95) !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12) !important;
  backdrop-filter: blur(20px) !important;
}

/* Ressourcen-Anzeige im Header – kompakt für 56px-Header */
.ui-hud-micro,
body.ui-reboot .ui-shell-header.ui-panel-header > .ng-header-top-right .ui-hud-block.ui-hud-block--center > .ui-hud-micro {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 6px !important;
  font-family: 'Inter', sans-serif !important;
  flex-wrap: nowrap !important;
  height: auto !important;
  width: auto !important;
  grid-template-columns: unset !important;
}

.ui-hud-micro-group,
body.ui-reboot .ui-shell-header.ui-panel-header > .ng-header-top-right .ui-hud-block.ui-hud-block--center .ui-hud-micro-group[data-group="depot"],
body.ui-reboot .ui-shell-header.ui-panel-header > .ng-header-top-right .ui-hud-block.ui-hud-block--center .ui-hud-micro-group[data-group="oxygen"] {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 4px 10px !important;
  border-radius: 10px !important;
  background: rgba(0, 0, 0, 0.05) !important;
  border: 1px solid rgba(0, 0, 0, 0.07) !important;
  flex-shrink: 0 !important;
  height: 36px !important;
  grid-template-columns: unset !important;
}

.ui-hud-micro-item,
body.ui-reboot .ui-shell-header.ui-panel-header > .ng-header-top-right .ui-hud-block.ui-hud-block--center .ui-hud-micro-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 1px !important;
  font-size: 11px !important;
  white-space: nowrap !important;
  padding: 0 !important;
  min-width: 0 !important;
  width: auto !important;
}

.ui-hud-micro-item .k,
.ui-hud-block--center .ui-hud-micro-item .k {
  color: rgba(0, 0, 0, 0.4) !important;
  font-size: 9px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
  line-height: 1 !important;
}

.ui-hud-micro-item .v,
.ui-hud-block--center .ui-hud-micro-item .v {
  color: #1a202c !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  line-height: 1 !important;
}

/* Produktionsrate ausblenden – zu wenig Platz */
.ui-hud-prod {
  display: none !important;
}

/* Ressourcen-Meter im Header ausblenden – zu wenig Platz */
.ui-hud-micro-group .ui-hud-res-meter,
body.ui-reboot .ui-shell-header.ui-panel-header .ui-hud-res-meter {
  display: none !important;
}

/* Ressourcen-Meter */
.ui-hud-res-meter {
  height: 3px !important;
  border-radius: 2px !important;
  background: rgba(0, 0, 0, 0.1) !important;
  overflow: hidden !important;
  border: none !important;
  min-width: 40px !important;
}

.ui-hud-res-meter-fill {
  height: 100% !important;
  border-radius: 2px !important;
  background: #3b82f6 !important;
  transition: width 0.5s ease !important;
}

.ui-hud-res-meter-label {
  font-size: 9px !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

.ui-hud-res-meter.is-warn .ui-hud-res-meter-fill {
  background: #d97706 !important;
}

.ui-hud-res-meter.is-full .ui-hud-res-meter-fill {
  background: #dc2626 !important;
}

/* ============================================================
   HAUPT-INHALTSBEREICH
   ============================================================ */

.ui-center-hero {
  padding: 20px 24px !important;
  background: transparent !important;
  overflow-y: auto !important;
}

/* Alle ui-frame Varianten transparent */
.ui-frame,
.ui-frame--heavy,
.ui-frame--glass,
.ui-frame.ui-frame--heavy,
.ui-frame.ui-frame--glass {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.ui-frame::before,
.ui-frame::after,
.ui-frame.ui-frame--heavy::before,
.ui-frame.ui-frame--heavy::after,
.ui-frame.ui-frame--glass::before,
.ui-frame.ui-frame--glass::after {
  display: none !important;
  content: none !important;
}

.ui-frame__body {
  background: transparent !important;
  padding: 0 !important;
}

/* GridMatrix-Header */
.ng-gridmatrix-header {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #1a202c !important;
  font-family: 'Inter', sans-serif !important;
  padding: 0 0 16px !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* ============================================================
   DASHBOARD KARTEN (GLASSMORPHISM HELL)
   ============================================================ */

.ng-cityview-card,
.ng-tiles-card,
body.ui-reboot .ng-cityview-card,
body.ui-reboot .ng-tiles-card,
body.ui-reboot.ng-shell .ng-cityview-card,
body.ui-reboot.ng-shell .ng-dashboard-gridstack.grid-stack .ng-cityview-card,
body.ui-reboot .ng-cityview-card.ng-tiles-card,
body.ui-reboot .ng-cityview-card.ng-grid-cityinfo {
  background: rgba(255, 255, 255, 0.65) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(0, 0, 0, 0.07) !important;
  border-radius: 20px !important;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06) !important;
  overflow: hidden !important;
  padding: 16px !important;
}

.ng-cityview-card::before,
.ng-cityview-card::after,
body.ui-reboot.ng-shell .ng-dashboard-gridstack.grid-stack .ng-cityview-card::before,
body.ui-reboot.ng-shell .ng-dashboard-gridstack.grid-stack .ng-cityview-card::after,
body.ui-reboot.ng-shell .ng-dashboard-gridstack.grid-stack .ng-cityview-card.ng-grid-cityinfo::before {
  display: none !important;
  content: none !important;
}

/* Card-Titel */
.ng-cityview-card-title {
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.6px !important;
  color: rgba(0, 0, 0, 0.4) !important;
  font-family: 'Inter', sans-serif !important;
  margin-bottom: 12px !important;
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
}

/* GridStack */
.grid-stack {
  background: transparent !important;
}

.grid-stack > .grid-stack-item > .grid-stack-item-content {
  border-radius: 20px !important;
  overflow: hidden !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* ============================================================
   BUILD TILES
   ============================================================ */

.ng-build-tiles-grid,
body.ui-reboot .ng-cityview-card.ng-tiles-card .ng-build-tiles-grid {
  gap: 16px !important;
}

.ng-build-row {
  gap: 16px !important;
}

.ng-tile,
body.ui-reboot .ng-build-row .ng-tile,
body.ui-reboot .ng-tech-row .ng-tile,
body.ui-reboot .ng-hangar-row .ng-tile,
body.ui-reboot .ng-defense-row .ng-tile {
  border-radius: 16px !important;
  overflow: hidden !important;
  border: 1px solid rgba(0, 0, 0, 0.07) !important;
  background: rgba(255, 255, 255, 0.6) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05) !important;
}

.ng-tile::before,
.ng-tile::after {
  display: none !important;
}

.ng-tile-bg {
  border-radius: 16px !important;
  opacity: 0.3 !important;
}

.ng-tile-title,
.ng-tile .ng-tile-title {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  color: #1a202c !important;
}

.ng-tile-level-badge,
.ng-tile .ng-tile-level-badge {
  font-family: 'Inter', sans-serif !important;
  font-size: 10px !important;
  background: rgba(0, 0, 0, 0.08) !important;
  border-radius: 8px !important;
  padding: 2px 7px !important;
  border: none !important;
  color: rgba(0, 0, 0, 0.55) !important;
}

.ng-tile:hover,
body.ui-reboot .ng-build-row .ng-tile:hover {
  border-color: rgba(0, 0, 0, 0.12) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1) !important;
}

.ng-tile-inactive,
.ng-tile.ng-tile-inactive {
  opacity: 0.45 !important;
}

.ng-build-group-title,
.ng-build-group-title--center,
.ng-build-group-title--split {
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  color: rgba(0, 0, 0, 0.35) !important;
  font-family: 'Inter', sans-serif !important;
  border: none !important;
  background: transparent !important;
}

.ng-tile-spacer {
  background: transparent !important;
  border: none !important;
}

/* ============================================================
   DEPOT / RESSOURCEN KARTEN
   ============================================================ */

.ng-depot-meter {
  height: 6px !important;
  border-radius: 3px !important;
  background: rgba(0, 0, 0, 0.08) !important;
  border: none !important;
  overflow: hidden !important;
}

.ng-depot-meter-fill {
  height: 100% !important;
  border-radius: 3px !important;
  background: #3b82f6 !important;
  transition: width 0.5s ease !important;
}

.ng-depot-meter-glow {
  display: none !important;
}

.ng-depot-meter-cap {
  font-size: 10px !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

.ng-depot-meter-ticks {
  display: none !important;
}

.ng-cityview-depot-group.is-warn .ng-depot-meter-fill {
  background: #d97706 !important;
}

.ng-cityview-depot-group.is-full .ng-depot-meter-fill {
  background: #dc2626 !important;
}

.ng-cityview-res-name {
  font-size: 12px !important;
  color: rgba(0, 0, 0, 0.5) !important;
}

.ng-cityview-res-now {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #1a202c !important;
  font-family: 'Inter', sans-serif !important;
}

.ng-cityview-kv {
  font-size: 11px !important;
  color: rgba(0, 0, 0, 0.35) !important;
}

.ng-cityview-kv.is-negative {
  color: #dc2626 !important;
}

/* ============================================================
   SKYLINE / DURCHSCHNITT
   ============================================================ */

.ng-cityview-skybar {
  background: rgba(0, 0, 0, 0.08) !important;
  border-radius: 4px !important;
}

.ng-cityview-skyfill {
  background: #3b82f6 !important;
  border-radius: 4px !important;
}

.ng-cityview-sky.is-above .ng-cityview-skyfill {
  background: #16a34a !important;
}

.ng-cityview-sky.is-below .ng-cityview-skyfill {
  background: #d97706 !important;
}

.ng-skyline-median-line {
  border-color: rgba(0, 0, 0, 0.25) !important;
}

.ng-cityview-skyname {
  font-size: 9px !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

/* ============================================================
   CITY INFO KARTE
   ============================================================ */

.ng-cityinfo-imagewrap {
  border-radius: 12px !important;
  overflow: hidden !important;
  margin-bottom: 12px !important;
}

.ng-cityinfo-image {
  border-radius: 12px !important;
  border: none !important;
}

.ng-cityinfo-kv {
  font-size: 12px !important;
  color: rgba(0, 0, 0, 0.6) !important;
  padding: 3px 0 !important;
  border: none !important;
}

.ng-cityinfo-kv .k {
  color: rgba(0, 0, 0, 0.45) !important;
}

.ng-cityinfo-kv .v {
  color: #1a202c !important;
  font-weight: 600 !important;
}

.ng-cityinfo-kv .k i {
  color: rgba(0, 0, 0, 0.3) !important;
}

/* ============================================================
   AKTIVE JOBS KARTE
   ============================================================ */

.ng-active-jobs-count {
  background: #3b82f6 !important;
  color: #fff !important;
  border-radius: 8px !important;
  padding: 1px 6px !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  margin-left: 6px !important;
}

.ng-active-job-item {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 8px 0 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.ng-active-job-item:last-child {
  border-bottom: none !important;
}

.ng-job-label {
  font-size: 10px !important;
  color: rgba(0, 0, 0, 0.4) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
}

.ng-job-name {
  font-size: 13px !important;
  color: #1a202c !important;
  font-weight: 500 !important;
}

.ng-job-level,
.ng-job-amount {
  font-size: 11px !important;
  color: #3b82f6 !important;
  font-weight: 600 !important;
}

.ng-timer-value {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #3b82f6 !important;
  font-family: 'JetBrains Mono', monospace !important;
}

.ng-empty-state {
  padding: 20px !important;
  text-align: center !important;
}

.ng-empty-text {
  font-size: 12px !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

/* ============================================================
   RADAR KARTE
   ============================================================ */

.ng-header-radar,
.ng-radar-canvas-wrap {
  background: rgba(0, 0, 0, 0.04) !important;
  border: 1px solid rgba(0, 0, 0, 0.07) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
}

.ng-radar-canvas-wrap::before,
.ng-radar-canvas-wrap::after {
  display: none !important;
}

.ng-radar-live {
  font-family: 'JetBrains Mono', monospace !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

/* ============================================================
   HACKER TERMINAL KARTE
   ============================================================ */

.ng-hacker-body {
  background: rgba(0, 0, 0, 0.04) !important;
  border-radius: 10px !important;
  border: none !important;
}

.ng-hacker-line {
  font-size: 11px !important;
  color: rgba(0, 0, 0, 0.4) !important;
  font-family: 'JetBrains Mono', monospace !important;
}

.ng-hacker-cursor {
  color: #3b82f6 !important;
}

/* ============================================================
   KAMPFBERICHTE / FLÜGE
   ============================================================ */

.ng-combat-list-item {
  padding: 8px !important;
  border-radius: 10px !important;
  background: rgba(0, 0, 0, 0.03) !important;
  border: 1px solid rgba(0, 0, 0, 0.05) !important;
  margin-bottom: 6px !important;
}

.ng-combat-list-item:hover {
  background: rgba(0, 0, 0, 0.06) !important;
}

.ng-combat-list-item.is-unread {
  border-color: rgba(59, 130, 246, 0.3) !important;
}

.ng-combat-list-time {
  font-size: 10px !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

.ng-combat-list-badge {
  background: #3b82f6 !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-size: 9px !important;
  padding: 1px 5px !important;
}

/* ============================================================
   MODALS & POPUPS
   ============================================================ */

.ng-tile-overlay {
  background: rgba(0, 0, 0, 0.35) !important;
  backdrop-filter: blur(4px) !important;
}

.ng-tile-modal,
.ng-tile-popups-root .ng-tile-modal,
.ng-tile-popups-root .ng-modal,
.ng-modal-card,
.ng-modal-frame {
  background: rgba(255, 255, 255, 0.92) !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 20px !important;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.15) !important;
  backdrop-filter: blur(30px) !important;
  -webkit-backdrop-filter: blur(30px) !important;
}

.ng-tile-modal::before,
.ng-tile-modal::after {
  display: none !important;
}

.ng-modal-backdrop {
  background: rgba(0, 0, 0, 0.35) !important;
  backdrop-filter: blur(4px) !important;
}

.ng-tile-popup {
  background: rgba(255, 255, 255, 0.92) !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 16px !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12) !important;
}

.ng-modal__inner {
  background: rgba(255, 255, 255, 0.92) !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 20px !important;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.15) !important;
}

.ng-modal__footer {
  border-top: 1px solid rgba(0, 0, 0, 0.06) !important;
  background: rgba(0, 0, 0, 0.02) !important;
  padding: 12px 20px !important;
}

.ng-modal-header-row,
.ng-modal__header {
  border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
  padding: 16px 20px !important;
  background: transparent !important;
}

.ng-modal-title,
.ng-modal__title {
  font-size: 16px !important;
  font-weight: 600 !important;
  color: #1a202c !important;
  font-family: 'Inter', sans-serif !important;
  letter-spacing: 0 !important;
}

.ng-modal-close-btn {
  width: 32px !important;
  height: 32px !important;
  border-radius: 10px !important;
  background: rgba(0, 0, 0, 0.05) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  color: rgba(0, 0, 0, 0.5) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
}

.ng-modal-close-btn:hover {
  background: rgba(0, 0, 0, 0.08) !important;
  color: #1a202c !important;
}

.ng-modal__body {
  padding: 20px !important;
}

/* ============================================================
   BUTTONS
   ============================================================ */

.ui-btn,
.ng-button {
  font-family: 'Inter', sans-serif !important;
  border-radius: 10px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  transition: all 0.15s ease !important;
  padding: 8px 16px !important;
  background: rgba(0, 0, 0, 0.05) !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  color: #1a202c !important;
  font-size: 13px !important;
  cursor: pointer !important;
}

.ui-btn:hover,
.ng-button:hover {
  background: rgba(0, 0, 0, 0.08) !important;
}

.ng-button-primary,
.ui-btn-primary {
  background: #3b82f6 !important;
  border-color: #3b82f6 !important;
  color: #fff !important;
}

.ng-button-primary:hover,
.ui-btn-primary:hover {
  background: #2563eb !important;
  border-color: #2563eb !important;
}

/* ============================================================
   INPUTS / FORMS
   ============================================================ */

.ng-input,
.ui-input,
input[type="text"],
input[type="number"],
input[type="password"],
input[type="email"],
select,
textarea {
  background: rgba(255, 255, 255, 0.8) !important;
  border: 1px solid rgba(0, 0, 0, 0.12) !important;
  border-radius: 10px !important;
  color: #1a202c !important;
  font-family: 'Inter', sans-serif !important;
  padding: 8px 12px !important;
  font-size: 13px !important;
}

.ng-input:focus,
input:focus,
select:focus,
textarea:focus {
  border-color: #3b82f6 !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15) !important;
}

/* ============================================================
   TABELLEN
   ============================================================ */

.ng-table th,
table th {
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  color: rgba(0, 0, 0, 0.45) !important;
  padding: 8px 12px !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
  background: transparent !important;
}

.ng-table td,
table td {
  padding: 8px 12px !important;
  font-size: 13px !important;
  color: rgba(0, 0, 0, 0.7) !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.04) !important;
  background: transparent !important;
}

.ng-table tr:hover td {
  background: rgba(0, 0, 0, 0.02) !important;
}

/* ============================================================
   SCROLLBAR
   ============================================================ */

::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.12);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, 0.2);
}

/* ============================================================
   FOOTER / TICKER
   ============================================================ */

.ui-ticker {
  display: none !important;
}

.hud-edge {
  display: none !important;
}

/* ============================================================
   OVERLAY BACKDROP
   ============================================================ */

.ng-overlay-backdrop {
  background: rgba(0, 0, 0, 0.3) !important;
  backdrop-filter: blur(4px) !important;
}

/* ============================================================
   SECTIONS SLIDER
   ============================================================ */

.ng-sections-slider,
.ng-section-panel,
.ng-section-panel-inner {
  background: transparent !important;
}

/* ============================================================
   HUD / SONSTIGE ELEMENTE
   ============================================================ */

.hud-glow,
[class*="hud-glow"] {
  box-shadow: none !important;
}

.hud-glow::before,
.hud-glow::after,
[class*="hud-glow"]::before,
[class*="hud-glow"]::after {
  display: none !important;
}

.hud-title-bar {
  border: none !important;
  background: transparent !important;
}

.hud-title-bar__text {
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  color: #1a202c !important;
}

.hud-divider {
  background: rgba(0, 0, 0, 0.07) !important;
  height: 1px !important;
  border: none !important;
}

.hud-data-row__label {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  color: rgba(0, 0, 0, 0.45) !important;
  letter-spacing: 0 !important;
}

.ui-log {
  font-family: 'Inter', sans-serif !important;
  border: none !important;
  background: transparent !important;
}

/* ============================================================
   COMBAT MODAL
   ============================================================ */

.ng-combat-modal-backdrop {
  background: rgba(0, 0, 0, 0.35) !important;
  backdrop-filter: blur(4px) !important;
}

.ng-combat-modal-card {
  background: rgba(255, 255, 255, 0.92) !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 20px !important;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.15) !important;
}

/* ============================================================
   BADGES / TAGS
   ============================================================ */

.ng-badge {
  border-radius: 8px !important;
  padding: 2px 8px !important;
  font-size: 10px !important;
  font-weight: 600 !important;
}

.ng-badge-capital {
  background: rgba(59, 130, 246, 0.12) !important;
  color: #2563eb !important;
  border: 1px solid rgba(59, 130, 246, 0.2) !important;
}

.ng-badge-colony {
  background: rgba(0, 0, 0, 0.06) !important;
  color: rgba(0, 0, 0, 0.5) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
}

/* ============================================================
   LANDING / LOGIN SEITE
   ============================================================ */

body.ui-reboot.ng-shell.landing-page {
  background: #e8e9ec !important;
}

.landing-logo {
  font-family: 'Inter', sans-serif !important;
  color: #1a202c !important;
  letter-spacing: 4px !important;
}

.landing-logo span {
  color: #3b82f6 !important;
  opacity: 1 !important;
}

.landing-tagline {
  font-family: 'Inter', sans-serif !important;
  color: rgba(0, 0, 0, 0.45) !important;
  letter-spacing: 1px !important;
}

.landing-login-panel {
  background: rgba(255, 255, 255, 0.75) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08) !important;
  padding: 32px !important;
}

.landing-login-panel::before {
  display: none !important;
}

.landing-login-title {
  font-family: 'Inter', sans-serif !important;
  color: #1a202c !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
}

/* ============================================================
   LINKS
   ============================================================ */

a {
  color: #3b82f6 !important;
  text-decoration: none !important;
}

a:hover {
  color: #2563eb !important;
}

/* ============================================================
   TERMINAL FEED
   ============================================================ */

.ng-terminal-feed {
  background: rgba(0, 0, 0, 0.04) !important;
  border-radius: 10px !important;
  padding: 10px !important;
  border: none !important;
}

.ng-term-line {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

/* ============================================================
   PRELOADER
   ============================================================ */

.ng-preloader-overlay {
  background: #e8e9ec !important;
}

.ng-preloader-text {
  color: rgba(0, 0, 0, 0.5) !important;
  font-size: 14px !important;
  font-family: 'Inter', sans-serif !important;
}

/* ============================================================
   SECTION TITLE / MISC TEXT
   ============================================================ */

.ng-section-title {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #1a202c !important;
  font-family: 'Inter', sans-serif !important;
  letter-spacing: 0 !important;
  border: none !important;
  margin-bottom: 8px !important;
}

.ng-text-muted {
  color: rgba(0, 0, 0, 0.45) !important;
}

.ng-font-12 {
  font-size: 12px !important;
  font-family: 'Inter', sans-serif !important;
}

/* ============================================================
   FOCUS STYLES
   ============================================================ */

:focus-visible {
  outline: 2px solid #3b82f6 !important;
  outline-offset: 2px !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
  .ui-shell,
  .ui-shell.ui-shell--modules {
    grid-template-columns: 1fr !important;
  }

  .ui-panel-left,
  .ng-left-panel {
    display: none !important;
  }

  .ui-shell-header,
  body.ui-reboot .ui-shell-header.ui-panel-header {
    height: auto !important;
    max-height: none !important;
    flex-wrap: wrap !important;
    padding: 8px !important;
    gap: 8px !important;
  }
}

/* ============================================================
   DEMO1 KARTE
   ============================================================ */

.ng-demo1-surface {
  background: rgba(0, 0, 0, 0.04) !important;
  border-radius: 12px !important;
  border: none !important;
}

/* ============================================================
   COMM FULLVIEW
   ============================================================ */

.ng-comm-fullview {
  background: rgba(255, 255, 255, 0.85) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: 20px !important;
}

/* ============================================================
   UNREAD DOT
   ============================================================ */

.ng-unread-dot {
  width: 7px !important;
  height: 7px !important;
  border-radius: 50% !important;
  background: #dc2626 !important;
  animation: none !important;
  box-shadow: none !important;
}

/* ============================================================
   CITY MAP
   ============================================================ */

#city-map {
  border-radius: 12px !important;
  overflow: hidden !important;
}

/* ============================================================
   SECTIONS BAR (Tile-Übersicht)
   ============================================================ */

.ng-main-sections-bar .ng-tile.ng-tile-system {
  border-radius: 16px !important;
  border: 1px solid rgba(0, 0, 0, 0.07) !important;
  background: rgba(255, 255, 255, 0.6) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05) !important;
}

.ng-main-sections-bar .ng-tile.ng-tile-system:hover {
  border-color: rgba(0, 0, 0, 0.12) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1) !important;
  transform: translateY(-2px) !important;
}

.ng-main-sections-bar .ng-tile.ng-tile-system::before {
  display: none !important;
}
