/* Elite Dangerous Custom Bootstrap Theme */
/* Inspired by the game's UI color scheme and typography */

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

:root {
  /* Elite Dangerous Color Palette */
  --ed-orange: #ff7b00;
  --ed-orange-light: #ff9533;
  --ed-orange-lighter: #ffb066;
  --ed-orange-dark: #cc6200;
   --ed-orange-darkfaded: #cc6300c4;
  --ed-blue: #00d4ff;
  --ed-blue-light: #33ddff;
  --ed-blue-dark: #0099cc;
  --ed-dark-bg: #0a0a0a;
  --ed-panel-bg: #1a1a1a;
  --ed-panel-border: #2a2a2a;
  --ed-text-primary: #ffffff;
  --ed-text-secondary: #cccccc;
  --ed-text-muted: #999999;
  --ed-success: #00ff41;
  --ed-warning: #ffaa00;
  --ed-danger: #ff4444;
  --ed-grid-lines: #333333;
}

/* AGGRESSIVE OVERRIDES - Force Elite Dangerous Theme */

/* HTML and Body - Highest Priority */
html {
  background-color: var(--ed-dark-bg) !important;
}

body, 
body.container-fluid,
body.container {
  font-family: 'Exo 2', 'Segoe UI', sans-serif !important;
  background-color: var(--ed-dark-bg) !important;
  background: linear-gradient(135deg, var(--ed-dark-bg) 0%, #111111 50%, var(--ed-dark-bg) 100%) !important;
  background-attachment: fixed !important;
  color: var(--ed-text-primary) !important;
  font-weight: 400 !important;
  min-height: 100vh !important;
}

/* Override all heading elements */
h1, h1.display-1, h1.display-2, h1.display-3, h1.display-4, h1.display-5, h1.display-6,
h2, h2.display-1, h2.display-2, h2.display-3, h2.display-4, h2.display-5, h2.display-6,
h3, h3.display-1, h3.display-2, h3.display-3, h3.display-4, h3.display-5, h3.display-6,
h4, h4.display-1, h4.display-2, h4.display-3, h4.display-4, h4.display-5, h4.display-6,
h5, h5.display-1, h5.display-2, h5.display-3, h5.display-4, h5.display-5, h5.display-6,
h6, h6.display-1, h6.display-2, h6.display-3, h6.display-4, h6.display-5, h6.display-6 {
  font-family: 'Orbitron', monospace !important;
  font-weight: 600 !important;
  color: var(--ed-orange) !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

/* FORCE ALL CONTAINERS */
.container, 
.container-sm, 
.container-md, 
.container-lg, 
.container-xl, 
.container-xxl,
.container-fluid,
div.container,
div.container-fluid {
  background-color: rgba(26, 26, 26, 0.95) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-radius: 8px !important;
  padding: 20px !important;
  margin-top: 20px !important;
  box-shadow: 0 0 20px rgba(255, 123, 0, 0.1) !important;
}

/* FORCE ALL CARDS */
.card,
div.card,
.card-body,
div.card-body {
  background-color: var(--ed-panel-bg) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
  color: var(--ed-text-primary) !important;
}

.card-header,
div.card-header {
  background-color: var(--ed-orange) !important;
  color: var(--ed-dark-bg) !important;
  font-family: 'Orbitron', monospace !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  border-bottom: 2px solid var(--ed-orange-dark) !important;
}

/* Erweiterte Card-Title Lesbarkeit entsprechend exdeepa Copilot Instructions */
.card-title,
.card-header .card-title {
  color: var(--ed-text-primary) !important; /* Nutzt bestehende CSS-Variable */
  font-weight: 600 !important;
  font-family: 'Orbitron', monospace !important; /* Konsistent mit bestehenden Headings */
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important; /* Bessere Lesbarkeit */
}

/* Spezifische Anpassungen für farbige Card-Header */
.bg-info .card-title,
.bg-warning .card-title,
.bg-success .card-title,
.bg-primary .card-title {
  color: var(--ed-dark-bg) !important; /* Nutzt bestehende Variable */
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.3) !important;
}

.bg-danger .card-title,
.bg-dark .card-title,
.bg-secondary .card-title {
  color: var(--ed-text-primary) !important; /* Weiß für dunkle Header */
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5) !important;
}

/* FORCE ALL FORMS */
.form-control,
input.form-control,
textarea.form-control,
select.form-control {
  background-color: var(--ed-dark-bg) !important;
  border: 1px solid var(--ed-panel-border) !important;
  color: var(--ed-text-primary) !important;
  font-family: 'Exo 2', sans-serif !important;
}

.form-control:focus,
input.form-control:focus,
textarea.form-control:focus,
select.form-control:focus {
  background-color: var(--ed-panel-bg) !important;
  border-color: var(--ed-orange) !important;
  color: var(--ed-text-primary) !important;
  box-shadow: 0 0 5px rgba(255, 123, 0, 0.3) !important;
}

/* FORCE ALL LABELS */
.form-label,
label.form-label,
label {
  color: var(--ed-text-secondary) !important;
  font-family: 'Exo 2', sans-serif !important;
  font-weight: 500 !important;
}

/* Buttons */
.btn {
  font-family: 'Orbitron', monospace !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  border-radius: 4px !important;
  border: 2px solid !important;
  transition: all 0.3s ease !important;
}

.btn-primary {
  background-color: var(--ed-orange) !important;
  border-color: var(--ed-orange) !important;
  color: var(--ed-dark-bg) !important;
}

.btn-primary:hover {
  background-color: var(--ed-orange-light) !important;
  border-color: var(--ed-orange-light) !important;
  box-shadow: 0 0 15px rgba(255, 123, 0, 0.5) !important;
  transform: translateY(-1px) !important;
}

.btn-secondary {
  background-color: var(--ed-blue) !important;
  border-color: var(--ed-blue) !important;
  color: var(--ed-dark-bg) !important;
}

.btn-secondary:hover {
  background-color: var(--ed-blue-light);
  border-color: var(--ed-blue-light);
  box-shadow: 0 0 15px rgba(0, 212, 255, 0.5);
}

.btn-outline-primary {
  background-color: transparent;
  border-color: var(--ed-orange);
  color: var(--ed-orange);
}

.btn-outline-primary:hover {
  background-color: var(--ed-orange);
  color: var(--ed-dark-bg);
  box-shadow: 0 0 15px rgba(255, 123, 0, 0.3);
}

.btn-outline-secondary {
  background-color: transparent;
  border-color: var(--ed-blue);
  color: var(--ed-blue);
}

.btn-outline-secondary:hover {
  background-color: var(--ed-blue);
  color: var(--ed-dark-bg);
  box-shadow: 0 0 15px rgba(0, 212, 255, 0.3);
}

/* Form Controls */
.form-control, .form-select {
  background-color: var(--ed-panel-bg);
  border: 1px solid var(--ed-panel-border);
  color: var(--ed-text-primary);
  font-family: 'Exo 2', sans-serif;
  border-radius: 4px;
}

.form-control:focus, .form-select:focus {
  background-color: var(--ed-panel-bg);
  border-color: var(--ed-orange);
  color: var(--ed-text-primary);
  box-shadow: 0 0 10px rgba(255, 123, 0, 0.3);
}

.form-control::placeholder {
  color: var(--ed-text-muted);
  font-style: italic;
}

/* Labels */
.form-label {
  color: var(--ed-text-secondary);
  font-family: 'Orbitron', monospace;
  font-weight: 500;
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.5px;
}
.ed-orange-label {
    color: var(--ed-orange-darkfaded) !important;
}

/* Custom Floating Labels - Elite Style */
.custom-floating-container {
  position: relative;
  margin-bottom: 1rem;
}

.custom-floating-input {
  height: 42px;
  padding: 12px 15px 4px 15px;
  border: 1px solid var(--ed-panel-border);
  border-radius: 4px;
  background: var(--ed-panel-bg);
  font-size: 16px;
  width: 100%;
  outline: none;
  transition: all 0.3s ease;
  color: var(--ed-text-primary);
  font-family: 'Exo 2', sans-serif;
}

.custom-floating-label {
  position: absolute;
  top: 12px;
  left: 15px;
  color: var(--ed-text-muted);
  font-size: 16px;
  font-family: 'Orbitron', monospace;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transform-origin: left;
  transition: all 0.3s ease;
  pointer-events: none;
  background: var(--ed-panel-bg);
  padding: 0 6px;
  margin: 0;
}

.custom-floating-input:focus + .custom-floating-label,
.custom-floating-input:not(:placeholder-shown) + .custom-floating-label,
.custom-floating-input[value]:not([value=""]) + .custom-floating-label {
  top: -8px;
  font-size: 11px;
  color: var(--ed-orange);
  font-weight: 600;
  background: var(--ed-dark-bg);
}

.custom-floating-input:focus {
  border-color: var(--ed-orange);
  box-shadow: 0 0 15px rgba(255, 123, 0, 0.2);
  background: var(--ed-panel-bg);
}

/* Bootstrap Floating Labels Integration mit Elite Theme */
.form-floating > .form-control,
.form-floating > .form-select {
    background: var(--ed-panel-bg) !important;
    border: 1px solid var(--ed-panel-border) !important;
    color: var(--ed-text-primary) !important;
}

.form-floating > .form-control:focus,
.form-floating > .form-select:focus {
    background: var(--ed-panel-bg) !important;
    border-color: var(--ed-orange) !important;
    box-shadow: 0 0 10px rgba(255, 123, 0, 0.3) !important;
}

.form-floating > label {
    color: var(--ed-text-muted) !important;
    font-family: 'Orbitron', monospace !important;
    font-weight: 400 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    font-size: 0.85rem !important;
}

.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-select:focus ~ label,
.form-floating > .form-select ~ label {
    color: var(--ed-orange) !important;
    font-weight: 600 !important;
}

/* Verhindere Überschreibung der Floating Label-Funktionalität */
.form-floating > .form-control:not(:placeholder-shown),
.form-floating > .form-control:focus {
    padding-top: 1.625rem !important;
    padding-bottom: 0.625rem !important;
}

/* Tables */
.table {
  color: var(--ed-text-primary);
  font-family: 'Exo 2', sans-serif;
}

.table-dark {
  --bs-table-bg: var(--ed-panel-bg);
  --bs-table-border-color: var(--ed-panel-border);
}

.table th {
  background-color: var(--ed-orange);
  color: var(--ed-dark-bg);
  font-family: 'Orbitron', monospace;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-color: var(--ed-orange-dark);
}

.table td {
  border-color: var(--ed-panel-border);
}

.table-striped > tbody > tr:nth-of-type(odd) > td {
  background-color: rgba(255, 123, 0, 0.05);
}

/* Alerts */
.alert {
  border-radius: 6px;
  border: 1px solid;
  font-family: 'Exo 2', sans-serif;
}

.alert-primary {
  background-color: rgba(255, 123, 0, 0.1);
  border-color: var(--ed-orange);
  color: var(--ed-orange-light);
}

.alert-info {
  background-color: rgba(0, 212, 255, 0.1);
  border-color: var(--ed-blue);
  color: var(--ed-blue-light);
}

.alert-success {
  background-color: rgba(0, 255, 65, 0.1);
  border-color: var(--ed-success);
  color: var(--ed-success);
}

.alert-warning {
  background-color: rgba(255, 170, 0, 0.1);
  border-color: var(--ed-warning);
  color: var(--ed-warning);
}

.alert-danger {
  background-color: rgba(255, 68, 68, 0.1);
  border-color: var(--ed-danger);
  color: var(--ed-danger);
}

/* Navigation */
.navbar {
  background-color: var(--ed-panel-bg) !important;
  border-bottom: 2px solid var(--ed-orange);
}

.navbar-brand {
  font-family: 'Orbitron', monospace;
  font-weight: 700;
  color: var(--ed-orange) !important;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.nav-link {
  color: var(--ed-text-secondary) !important;
  font-family: 'Exo 2', sans-serif;
  font-weight: 500;
  text-transform: uppercase;
  transition: all 0.3s ease;
}

.nav-link:hover {
  color: var(--ed-orange) !important;
  text-shadow: 0 0 8px rgba(255, 123, 0, 0.6);
}

/* Tabs */
.nav-tabs {
  border-bottom: 2px solid var(--ed-panel-border);
}

.nav-tabs .nav-link {
  background-color: var(--ed-panel-bg);
  border: 1px solid var(--ed-panel-border);
  color: var(--ed-text-secondary);
  font-family: 'Orbitron', monospace;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.nav-tabs .nav-link.active {
  background-color: var(--ed-orange);
  border-color: var(--ed-orange);
  color: var(--ed-dark-bg);
}

.nav-tabs .nav-link:hover {
  border-color: var(--ed-orange);
  color: var(--ed-orange);
}

/* Accordion */
.accordion-item {
  background-color: var(--ed-panel-bg);
  border: 1px solid var(--ed-panel-border);
}

.accordion-header button {
  background-color: var(--ed-panel-bg);
  color: var(--ed-text-primary);
  font-family: 'Orbitron', monospace;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border: none;
}

.accordion-header button:not(.collapsed) {
  background-color: var(--ed-orange);
  color: var(--ed-dark-bg);
}

.accordion-body {
  background-color: var(--ed-panel-bg);
  color: var(--ed-text-primary);
}

/* Borders and Dividers */
.border {
  border-color: var(--ed-panel-border) !important;
}

hr {
  border-color: var(--ed-orange);
  opacity: 0.6;
}

/* Background Utilities */
.bg-dark {
  background-color: var(--ed-panel-bg) !important;
}

.bg-primary {
  background-color: var(--ed-orange) !important;
}

.bg-secondary {
  background-color: var(--ed-blue) !important;
}

/* Text Utilities */
.text-primary {
  color: var(--ed-orange) !important;
}

.text-secondary {
  color: var(--ed-blue) !important;
}

.text-muted {
  color: var(--ed-text-muted) !important;
}

/* Elite Dangerous Specific Effects */
.ed-glow {
  text-shadow: 0 0 10px currentColor;
}

.ed-panel {
  background-color: var(--ed-panel-bg);
  border: 1px solid var(--ed-panel-border);
  border-radius: 6px;
  padding: 20px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.ed-grid {
  background-image: 
    linear-gradient(90deg, var(--ed-grid-lines) 1px, transparent 1px),
    linear-gradient(var(--ed-grid-lines) 1px, transparent 1px);
  background-size: 20px 20px;
  opacity: 0.1;
}

/* Scrollbars */
::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--ed-panel-bg);
}

::-webkit-scrollbar-thumb {
  background: var(--ed-orange);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--ed-orange-light);
}

/* Custom Animations */
@keyframes ed-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

.ed-pulse {
  animation: ed-pulse 2s infinite;
}

@keyframes ed-scan {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

.ed-scan-line {
  position: relative;
  overflow: hidden;
}

.ed-scan-line::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--ed-orange), transparent);
  animation: ed-scan 3s infinite;
}

/* ========================================
   JQUERY UI ACCORDION - ELITE DANGEROUS THEME
   ======================================== */

/* Accordion Container */
.ui-accordion {
  background: var(--ed-panel-bg) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-radius: 4px !important;
  font-family: 'Exo 2', sans-serif !important;
}

/* Accordion Headers */
.ui-accordion .ui-accordion-header {
  background: linear-gradient(135deg, var(--ed-panel-bg) 0%, #2a2a2a 50%, var(--ed-panel-bg) 100%) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-bottom: 1px solid var(--ed-orange) !important;
  color: var(--ed-text-primary) !important;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
  padding: 12px 16px !important;
  margin: 0 !important;
  position: relative !important;
  transition: all 0.3s ease !important;
}

/* Accordion Header Hover */
.ui-accordion .ui-accordion-header:hover {
  background: linear-gradient(135deg, #2a2a2a 0%, var(--ed-orange-dark) 50%, #2a2a2a 100%) !important;
  border-bottom-color: var(--ed-orange-light) !important;
  color: var(--ed-orange-light) !important;
  box-shadow: 0 2px 8px rgba(255, 123, 0, 0.3) !important;
}

/* Accordion Header Active */
.ui-accordion .ui-accordion-header.ui-state-active {
  background: linear-gradient(135deg, var(--ed-orange-dark) 0%, var(--ed-orange) 50%, var(--ed-orange-dark) 100%) !important;
  border-bottom-color: var(--ed-orange-light) !important;
  color: var(--ed-text-primary) !important;
  box-shadow: 0 4px 12px rgba(255, 123, 0, 0.5) !important;
}

/* Accordion Content Panels */
.ui-accordion .ui-accordion-content {
  background: var(--ed-dark-bg) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-top: none !important;
  color: var(--ed-text-primary) !important;
  padding: 16px !important;
  font-size: 0.9rem !important;
}

/* Accordion Icons */
.ui-accordion .ui-accordion-header .ui-accordion-header-icon {
  color: var(--ed-orange) !important;
  right: 12px !important;
  transition: all 0.3s ease !important;
}

.ui-accordion .ui-accordion-header:hover .ui-accordion-header-icon {
  color: var(--ed-orange-light) !important;
  transform: scale(1.1) !important;
}

.ui-accordion .ui-accordion-header.ui-state-active .ui-accordion-header-icon {
  color: var(--ed-text-primary) !important;
  transform: rotate(180deg) !important;
}

/* Override jQuery UI Default Styles */
.ui-widget {
  font-family: 'Exo 2', sans-serif !important;
}

.ui-widget-content {
  background: var(--ed-panel-bg) !important;
  border: 1px solid var(--ed-panel-border) !important;
  color: var(--ed-text-primary) !important;
}

.ui-widget-header {
  background: var(--ed-panel-bg) !important;
  border: 1px solid var(--ed-panel-border) !important;
  color: var(--ed-text-primary) !important;
  font-weight: 600 !important;
}

/* Form Elements within Accordions */
.ui-accordion .form-section .form-control,
.ui-accordion .form-section .form-select,
.ui-accordion .form-section .btn {
  background-color: var(--ed-panel-bg) !important;
  border-color: var(--ed-panel-border) !important;
  color: var(--ed-text-primary) !important;
}

.ui-accordion .form-section .form-control:focus,
.ui-accordion .form-section .form-select:focus {
  border-color: var(--ed-orange) !important;
  box-shadow: 0 0 0 0.2rem rgba(255, 123, 0, 0.25) !important;
}

/* ========================================
   JQUERY UI TABS - ELITE DANGEROUS THEME
   ======================================== */

/* Tabs Container */
.ui-tabs {
  background: var(--ed-panel-bg) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-radius: 4px !important;
  font-family: 'Exo 2', sans-serif !important;
}

/* Tab Navigation */
.ui-tabs .ui-tabs-nav {
  background: linear-gradient(135deg, var(--ed-panel-bg) 0%, #2a2a2a 50%, var(--ed-panel-bg) 100%) !important;
  border: none !important;
  border-bottom: 2px solid var(--ed-orange) !important;
  padding: 0 !important;
  border-radius: 4px 4px 0 0 !important;
  margin: 0 0 0 0 !important;
  list-style: none !important;
}

.ui-tabs .ui-tabs-nav:after {
  content: "";
  display: table;
  clear: both;
}

.ui-tabs .ui-tabs-nav li {
  list-style: none !important;
  float: left !important;
  position: relative !important;
  top: 0 !important;
  margin: 0 2px 0 0 !important;
  border-bottom-width: 0 !important;
  padding: 0 !important;
  white-space: nowrap !important;
}

.ui-tabs .ui-tabs-nav li a {
  float: left !important;
  padding: 12px 20px !important;
  text-decoration: none !important;
  background: var(--ed-panel-bg) !important;
  color: var(--ed-text-secondary) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-bottom: none !important;
  font-weight: 500 !important;
  font-size: 0.9rem !important;
  transition: all 0.3s ease !important;
  border-radius: 4px 4px 0 0 !important;
  cursor: pointer !important;
}

.ui-tabs .ui-tabs-nav li a:hover {
  background: linear-gradient(135deg, #2a2a2a 0%, var(--ed-orange-dark) 50%, #2a2a2a 100%) !important;
  color: var(--ed-orange-light) !important;
  border-color: var(--ed-orange) !important;
  box-shadow: 0 2px 8px rgba(255, 123, 0, 0.3) !important;
}

.ui-tabs .ui-tabs-nav li.ui-tabs-active a,
.ui-tabs .ui-tabs-nav li.ui-state-active a {
  background: linear-gradient(135deg, var(--ed-orange-dark) 0%, var(--ed-orange) 50%, var(--ed-orange-dark) 100%) !important;
  color: var(--ed-text-primary) !important;
  border-color: var(--ed-orange) !important;
  box-shadow: 0 4px 12px rgba(255, 123, 0, 0.5) !important;
  cursor: default !important;
}

/* Tab Panels */
.ui-tabs .ui-tabs-panel {
  display: block !important;
  border-width: 0 !important;
  padding: 20px !important;
  background: var(--ed-dark-bg) !important;
  color: var(--ed-text-primary) !important;
}

/* Fix: Sicherstellen dass inaktive Tabs versteckt sind */
.ui-tabs .ui-tabs-hide {
  display: none !important;
}

/* Fix: Aktive Tabs sichtbar halten */
.ui-tabs .ui-tabs-panel:not(.ui-tabs-hide) {
  display: block !important;
}

/* KORRIGIERTE TAB DISPLAY LOGIC */
#system-tabs .ui-tabs-panel {
  display: none !important;
  position: relative !important;
  width: 100% !important;
  height: auto !important;
  overflow: visible !important;
  clear: both !important;
  background: var(--ed-dark-bg) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-radius: 0 0 4px 4px !important; 
  margin: 10px 0 0 0 !important;
  padding: 20px !important;
  box-sizing: border-box !important;
}

/* jQuery UI zeigt aktive Panels durch Entfernen der ui-tabs-hide Klasse */
#system-tabs .ui-tabs-panel:not(.ui-tabs-hide) {
  display: block !important;
}

/* Fallback: Erstes Tab standardmäßig anzeigen */
#system-tabs #tab-system {
  display: block !important;
}

/* Verstecke Tabs die explizit als versteckt markiert sind */
#system-tabs .ui-tabs-panel.ui-tabs-hide,
#system-tabs .ui-tabs-panel[aria-hidden="true"] {
  display: none !important;
}

/* Accordion Styling für bessere Sichtbarkeit */
#systemAccordion .accordion-button {
    background-color: var(--ed-card-bg, #2c3e50) !important;
    color: var(--ed-text-primary, #ecf0f1) !important;
    border: 1px solid var(--ed-panel-border, #34495e) !important;
    font-weight: 500;
}

#systemAccordion .accordion-button:not(.collapsed) {
    background-color: var(--ed-primary, #f39c12) !important;
    color: var(--ed-dark-bg, #1a1a1a) !important;
    box-shadow: 0 2px 4px rgba(243, 156, 18, 0.3) !important;
}

#systemAccordion .accordion-button.collapsed {
    background-color: var(--ed-secondary-bg, #34495e) !important;
    color: var(--ed-text-secondary, #bdc3c7) !important;
    opacity: 0.8;
}

#systemAccordion .accordion-button:hover {
    background-color: var(--ed-hover, #5d6d7e) !important;
    color: var(--ed-text-primary, #ecf0f1) !important;
    opacity: 1;
}

#systemAccordion .accordion-item {
    border: 1px solid var(--ed-panel-border, #34495e) !important;
    margin-bottom: 2px;
}

#systemAccordion .accordion-body {
    background-color: var(--ed-dark-bg, #1a1a1a) !important;
    border-top: 1px solid var(--ed-panel-border, #34495e) !important;
}

.btn-info[disabled] {
  background-color: #33ddff !important;
  color: #222 !important;
  border-color: #33ddff !important;
}
.btn-secondary[disabled] {
  background-color: #999 !important;
  color: #222 !important;
  border-color: #999 !important;
}
.elite-dangerous-bg {
    background-color: #b85c00;
    color: #fff;
}
.system-feature-row {
    border-bottom: 2px dashed var(--bs-border-color, #dee2e6);
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    position: relative;
}

.system-feature-row:last-child {
    border-bottom: none;
    margin-bottom: 1rem;
}

.system-feature-row::after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--bs-primary, #0d6efd), transparent);
    opacity: 0.3;
}

.feature-card {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    border: 1px solid var(--bs-border-color, #dee2e6);
}

.feature-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.feature-badge {
    font-size: 0.7rem;
    margin-left: 0.5rem;
}

/* =============================================================================
   ENHANCED UX STYLES - System Form Interactions
   ============================================================================= */

/* Elite Dangerous Enhanced Form Interactions */
.form-floating input:focus + label,
.form-floating input:not(:placeholder-shown) + label,
.form-floating textarea:focus + label,
.form-floating textarea:not(:placeholder-shown) + label,
.form-floating select:focus + label,
.form-floating select:not(:placeholder-shown) + label {
    color: var(--ed-orange) !important;
    text-shadow: 0 0 4px rgba(255, 123, 0, 0.8) !important;
    transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem) !important;
}

/* Smooth Transitions für Detail-Felder */
.form-floating,
.form-group,
.mb-3 {
    transition: all 0.3s ease !important;
    opacity: 1 !important;
}

/* Hidden state für dynamische Felder */
.form-floating[style*="display: none"],
.form-group[style*="display: none"],
.mb-3[style*="display: none"] {
    opacity: 0 !important;
    transform: translateY(-10px) !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Active Feature Highlight - System Tab */
.feature-active {
    background: linear-gradient(135deg, rgba(255, 123, 0, 0.1), rgba(0, 212, 255, 0.1)) !important;
    border: 1px solid var(--ed-orange) !important;
    border-radius: 0.375rem !important;
    box-shadow: 0 0 12px rgba(255, 123, 0, 0.3) !important;
}

/* Feature Counter Badge - Tab Enhancement */
#system-feature-counter {
    font-size: 0.7rem !important;
    background: linear-gradient(135deg, var(--ed-blue), var(--ed-orange)) !important;
    border: none !important;
    padding: 0.25rem 0.5rem !important;
    border-radius: 0.25rem !important;
    animation: elite-pulse 2s infinite !important;
    box-shadow: 0 0 8px rgba(0, 212, 255, 0.5) !important;
}

/* Elite-style Pulse Animation */
@keyframes elite-pulse {
    0% { 
        opacity: 1; 
        box-shadow: 0 0 8px rgba(0, 212, 255, 0.5);
    }
    50% { 
        opacity: 0.8; 
        box-shadow: 0 0 12px rgba(255, 123, 0, 0.7);
    }
    100% { 
        opacity: 1; 
        box-shadow: 0 0 8px rgba(0, 212, 255, 0.5);
    }
}

/* System Tab Nav Enhancement */
.nav-tabs .nav-link {
    position: relative !important;
}

.nav-tabs .nav-link:has(#system-feature-counter) {
    padding-right: 3rem !important;
}

/* Responsive Enhancements für System Features */
@media (max-width: 768px) {
    .col-3 {
        flex: 0 0 50% !important;
        max-width: 50% !important;
    }
    
    #system-feature-counter {
        font-size: 0.6rem !important;
        padding: 0.2rem 0.4rem !important;
    }
}

@media (max-width: 576px) {
    .col-3 {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
}

/* Elite Dangerous Scan-Line Effect für aktive Bereiche */
.feature-active::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--ed-orange), transparent);
    animation: elite-scan 3s infinite;
}

@keyframes elite-scan {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

/* Enhanced Tab Content Transitions */
.tab-pane {
    transition: all 0.3s ease-in-out !important;
}

.tab-pane.fade:not(.show) {
    opacity: 0 !important;
    transform: translateY(10px) !important;
}

.tab-pane.fade.show {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* =============================================================================
   FORM ROW SEPARATION - Tabs: Körperrelevant / Systemrelevant / Ringe / Zusätzlich
   ============================================================================= */

/* Generelle Absetzung für Rows innerhalb der System-Form */
#systemTabContent .tab-pane .row {
    margin-bottom: 0.9rem !important;
    padding: 0.45rem 0.6rem !important;
    border-radius: 0.5rem;
    border: 1px solid rgba(255,255,255,0.04);
    background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(0,0,0,0.04));
    box-shadow: 0 2px 6px rgba(0,0,0,0.35);
}

/* Leichter Kontrast für bereits markierte/border-rows (bestehende .border-Klasse) */
#systemTabContent .tab-pane .row.border {
    border-color: rgba(255,255,255,0.06) !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.06));
}

/* Spezielles Styling für die Spalten im Systemrelevant-Tab (feinere Abstände) */
#tab-bodies .col-3,
#tab-bodies .col-lg-3,
#tab-coordinates .col-2,
#tab-stations .col-12,
#tab-additional .col-12 {
    padding: 0.5rem !important;
}

/* Alternierende (zebra) Farben pro Row innerhalb tab-bodies für bessere Lesbarkeit */
#tab-bodies > .container-fluid > .row > .col-3:nth-child(odd),
#tab-bodies .tab-pane > .row > .col-3:nth-child(odd) {
    background: rgba(255,255,255,0.02);
}
#tab-bodies > .container-fluid > .row > .col-3:nth-child(even),
#tab-bodies .tab-pane > .row > .col-3:nth-child(even) {
    background: rgba(0,0,0,0.04);
}

/* Hover-Effekt (dezent) für Rows/Columns */
#systemTabContent .tab-pane .row:hover {
    transform: translateY(-2px);
    transition: all 0.18s ease;
    box-shadow: 0 6px 18px rgba(0,0,0,0.5);
}
#systemTabContent .tab-pane .row .col-3:hover {
    background: linear-gradient(135deg, rgba(255,123,0,0.03), rgba(0,212,255,0.02));
}

/* Responsive: weniger Padding auf kleinen Bildschirmen */
@media (max-width: 576px) {
    #systemTabContent .tab-pane .row {
        padding: 0.35rem 0.3rem !important;
    }
    #tab-bodies .col-3,
    #tab-coordinates .col-2 {
        padding: 0.35rem !important;
    }
}

/* ============================================================================
   FORM ROW SEPARATION - final, robust (wirkt auf .tab-pane .row wenn Debug OK)
   ============================================================================ */

.tab-pane .row {
  margin-bottom: 0.9rem !important;
  padding: 0.45rem 0.6rem !important;
  border-radius: 0.5rem !important;
  border: 1px solid rgba(116, 114, 114, 0.973) !important;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(0,0,0,0.04)) !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.35) !important;
}

/* Zebra-Striping auf Row-Ebene für bessere Trennung */
.tab-pane .row:nth-of-type(odd) {
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.03)) !important;
}
.tab-pane .row:nth-of-type(even) {
  background: linear-gradient(180deg, rgba(0,0,0,0.04), rgba(0,0,0,0.06)) !important;
}

/* Feinerer Abstand / Padding für Col-Elemente in Formular-Tabs */
.tab-pane .row > [class*="col-"] {
  padding: 0.5rem !important;
  border-radius: 0.35rem !important;
}

/* Dezenter Hover-Effekt */
.tab-pane .row:hover {
  transform: translateY(-2px);
  transition: all 0.18s ease;
  box-shadow: 0 6px 18px rgba(0,0,0,0.45) !important;
}

/* Optional: stärkerer Kontrast für System-Feature-Spalten */
.tab-pane .row > .col-3:nth-child(odd) {
  background: rgba(255,255,255,0.01) !important;
}
.tab-pane .row > .col-3:nth-child(even) {
  background: rgba(0,0,0,0.03) !important;
}

/* Mobile: weniger Padding, kein Hover-Transform */
@media (max-width: 576px) {
  .tab-pane .row {
    padding: 0.35rem 0.3rem !important;
  }
  .tab-pane .row:hover {
    transform: none !important;
    box-shadow: none !important;
  }
}
.statcol {
  font-family: 'Exo 2', 'Segoe UI', sans-serif !important;
  background-color: var(--ed-dark-bg) !important;
  background: linear-gradient(135deg, var(--ed-dark-bg) 0%, #111111 50%, var(--ed-dark-bg) 100%) !important;
  background-attachment: fixed !important;
  color: var(--ed-text-primary) !important;
  font-weight: 400 !important;
  background-color: rgba(26, 26, 26, 0.95) !important;
  border: 1px solid var(--ed-panel-border) !important;
  border-radius: 8px !important;
  padding: 10px !important;
  margin-top: 20px !important;
  margin-left: 5px !important;
  margin-right: 5px !important;
  box-shadow: 0 0 20px rgba(255, 123, 0, 0.1) !important;
}

/* =============================================================================
   Ende: FORM ROW SEPARATION
   ============================================================================= */

/* Statistics Page entsprechend Elite Dangerous Theme */
.statistics-page .page-title {
  color: var(--ed-orange);
  font-family: 'Orbitron', monospace;
  font-weight: 300;
  margin-bottom: 2rem;
}

.statistics-page .section-title {
  color: var(--ed-text-secondary);
  border-bottom: 2px solid var(--ed-orange);
  padding-bottom: 0.5rem;
}

.statistics-page .metric-card {
  background: rgba(255, 123, 0, 0.1);
  border: 1px solid var(--ed-orange);
  transition: all var(--ed-transition-duration) ease;
}

.statistics-page .metric-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 123, 0, 0.3);
}

/* Statistics Page Elite Dangerous Integration */
.statistics-page .badge.bg-elite-orange {
  background: var(--ed-orange) !important;
  color: var(--ed-dark-bg) !important;
  font-family: 'Orbitron', monospace;
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.statistics-page .badge.bg-elite-blue {
  background: var(--ed-blue) !important;
  color: var(--ed-text-primary) !important;
  font-family: 'Orbitron', monospace;
  font-weight: 600;
}

.statistics-page .elite-badge {
  font-family: 'Orbitron', monospace;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.statistics-page .metric-display {
  padding: 1rem;
  border-radius: 0.5rem;
  background: rgba(243, 168, 74, 0.1);
  border: 1px solid var(--ed-orange);
  transition: all var(--ed-transition-duration) ease;
}

.statistics-page .metric-display:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(243, 168, 74, 0.3);
}

.statistics-page .credits-display {
  background: linear-gradient(135deg, rgba(243, 168, 74, 0.1), rgba(243, 168, 74, 0.05));
  border-radius: 0.5rem;
  padding: 1rem;
  border: 1px solid var(--ed-orange);
}

.statistics-page .card-title {
  color: var(--ed-text-primary) !important;
  font-family: 'Orbitron', monospace;
  font-weight: 600;
}

/* BootstrapLayout Table Elite Theme Override */
.statistics-page .table {
  --bs-table-bg: transparent;
  border: 1px solid var(--ed-grid-lines);
}

.statistics-page .table thead th {
  background: var(--ed-orange) !important;
  color: var(--ed-dark-bg) !important;
  font-family: 'Orbitron', monospace;
  font-weight: 600;
  border-color: var(--ed-orange);
}

.statistics-page .table tbody td {
  color: var(--ed-text-primary);
  border-color: var(--ed-grid-lines);
}

.elite-dashboard-compact-80 {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
}
.elite-dashboard-compact-90 {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
}

/* === JQUERY UI SPINNER - VERBESSERTER ABSTAND === */

/* Globale Spinner Input-Abstand Korrektur */
.ui-spinner-input {
    padding-right: 35px !important; /* Ausreichend Platz für 25px Button + 10px Abstand */
    text-align: right !important;
    font-family: 'Exo 2', monospace !important;
    font-weight: 500 !important;
}

/* Spinner Buttons korrekte Positionierung */
.ui-spinner-button {
    width: 25px !important;
    right: 2px !important; /* 2px Abstand vom Input-Rand */
    background: var(--ed-orange) !important;
    border: 1px solid var(--ed-orange-dark) !important;
    cursor: pointer !important;
}

/* Floating Label Spinner - erweiterten Abstand */
.form-floating .ui-spinner-input {
    padding-right: 40px !important; /* Mehr Platz bei Floating Labels */
}

.form-floating .ui-spinner-button {
    right: 3px !important; /* Größerer Abstand bei Floating Labels */
}

/* Focus State mit korrektem Abstand */
.ui-spinner-input:focus {
    padding-right: 35px !important; /* Abstand bleibt auch bei Focus erhalten */
    color: var(--ed-orange) !important;
}

/* Mobile: angepasste Abstände */
@media (max-width: 768px) {
    .ui-spinner-input {
        padding-right: 32px !important;
    }
    
    .ui-spinner-button {
        width: 22px !important;
        right: 2px !important;
    }
    
    .form-floating .ui-spinner-input {
        padding-right: 35px !important;
    }
}

/* === JQUERY UI SPINNER - BOOTSTRAP-ISOLATION === */

/* Verhindere Bootstrap-Interferenz mit jQuery UI Spinner */
.ui-spinner-input.form-control {
    /* Bootstrap form-control Styles überschreiben */
    background: var(--ed-panel-bg) !important;
    border: 1px solid var(--ed-panel-border) !important;
    color: var(--ed-text-primary) !important;
    font-family: 'Exo 2', monospace !important;
    padding-right: 35px !important;
    text-align: right !important;
}

/* Bootstrap Button-Klassen von Spinner-Buttons isolieren */
.ui-spinner-button:not(.btn) {
    /* Verhindere versehentliche Bootstrap Button-Anwendung */
    background: var(--ed-orange) !important;
    border: 1px solid var(--ed-orange-dark) !important;
    color: var(--ed-dark-bg) !important;
    font-family: inherit !important;
    font-size: inherit !important;
    font-weight: normal !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
}

/* Bootstrap Focus-Ring deaktivieren für Spinner */
.ui-spinner-input:focus {
    /* Bootstrap focus-ring überschreiben */
    box-shadow: 0 0 10px rgba(255, 123, 0, 0.3) !important;
    outline: none !important;
    border-color: var(--ed-orange) !important;
}

/* Bootstrap Input-Group Konflikte vermeiden */
.ui-spinner:not(.input-group) {
    display: inline-block !important;
    position: relative !important;
    width: 100% !important;
}

/* Floating Labels Bootstrap-Kompatibilität */
.form-floating .ui-spinner-input {
    /* Bootstrap Floating Label-Padding beibehalten aber anpassen */
    padding: 1rem 40px 1rem 0.75rem !important;
    text-align: right !important;
    height: calc(3.5rem + 2px) !important;
}

.form-floating .ui-spinner-input:focus ~ label,
.form-floating .ui-spinner-input:not(:placeholder-shown) ~ label {
    /* Bootstrap Floating Label-Animation funktionsfähig halten */
    opacity: 0.65 !important;
    transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem) !important;
    color: var(--ed-orange) !important;
}