/* ═══════════════════════════════════════════
   ATLAS SKYWAYS — Dark Theme + Footer Fix
   /public/disposable/stylesheet/theme_custom.css
═══════════════════════════════════════════ */

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

/* ── Root Variables — Dark ── */
:root {
  --bg-base:    #0d1117;
  --bg-card:    #161b27;
  --bg-card2:   #1c2333;
  --border:     rgba(255,255,255,0.08);
  --accent:     #3b7eff;
  --accent2:    #00c6ff;
  --red:        #e63757;
  --green:      #00c9a7;
  --text:       #cdd5e0;
  --text-muted: #6b7a99;
  --radius:     10px;
  --shadow:     0 4px 20px rgba(0,0,0,0.5);
  --icon-color: #8b9ab5;
}

/* ── Font — protect FA ── */
body {
  font-family: 'Inter', sans-serif !important;
  background-color: var(--bg-base) !important;
  background-image: none !important;
  color: var(--text) !important;
}
*:not(i):not(span.fa):not([class*="fa-"]) {
  font-family: 'Inter', sans-serif !important;
}
i.fas, i.far, i.fab, i.fal, i.fad, i.fa,
.fas, .far, .fab, .fal, .fad {
  font-family: 'Font Awesome 7 Free', 'Font Awesome 6 Free', 'Font Awesome 5 Free' !important;
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  color: var(--icon-color) !important;
  visibility: visible !important;
  opacity: 1 !important;
}
i.fab, .fab {
  font-family: 'Font Awesome 7 Brands', 'Font Awesome 6 Brands', 'Font Awesome 5 Brands' !important;
}

/* ── Hide dark mode toggle (we handle it ourselves) ── */
.dark-mode-switch, #darkmode_switch,
.form-check.form-switch,
label[for*="dark"], input[id*="dark"],
[class*="dark-mode"] { display: none !important; }

/* ── Navbar ── */
.navbar, nav.navbar, #Dispo_NavBar {
  background: #0d1117 !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: 0 1px 12px rgba(0,0,0,0.4) !important;
  padding: 0 1rem !important;
  min-height: 52px !important;
  display: flex !important;
  align-items: center !important;
  z-index: 1050 !important;
  position: sticky !important;
  top: 0 !important;
}
.navbar-brand, .navbar-brand span {
  color: #fff !important;
  font-weight: 700 !important;
}
.navbar-nav {
  align-items: center !important;
  flex-direction: row !important;
}
.navbar-nav .nav-item {
  display: flex !important;
  align-items: center !important;
  height: 52px !important;
}
.navbar-nav .nav-link,
#Dispo_NavBar a.nav-link,
nav .nav-link {
  color: var(--text-muted) !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  padding: 0 0.7rem !important;
  height: 52px !important;
  display: flex !important;
  align-items: center !important;
  pointer-events: all !important;
  cursor: pointer !important;
  z-index: 1060 !important;
  position: relative !important;
  text-decoration: none !important;
  transition: color 0.15s !important;
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
  color: var(--accent2) !important;
}

/* ── Dropdowns ── */
.dropdown { position: relative !important; }
.dropdown-menu {
  background: var(--bg-card2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6) !important;
  z-index: 9999 !important;
  position: absolute !important;
}
.dropdown-item {
  color: var(--text) !important;
  font-size: 0.83rem !important;
  padding: 0.45rem 1rem !important;
  background: transparent !important;
}
.dropdown-item:hover {
  background: rgba(59,126,255,0.12) !important;
  color: var(--accent2) !important;
}
.dropdown-divider { border-color: var(--border) !important; }

/* ── Page layout ── */
#page-contents {
  z-index: 1 !important;
  position: relative !important;
  padding-bottom: 1rem !important;
  min-height: unset !important;
}

/* ── Cards ── */
.card {
  background: var(--bg-card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  color: var(--text) !important;
  overflow: visible !important;
}
.card-header, .card .card-header {
  background: var(--bg-card2) !important;
  border-bottom: 1px solid var(--border) !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  color: var(--text-muted) !important;
  padding: 0.55rem 0.9rem !important;
}

/* ── Text overrides ── */
.card .text-center, .card h4, .card h5, .card h6,
.card p, .card span:not(.badge), .card strong, .card b {
  color: var(--text) !important;
}
.card small, .card .small,
.card .text-muted { color: var(--text-muted) !important; }
.text-white { color: var(--text) !important; }
.text-light { color: var(--text-muted) !important; }
.text-dark  { color: var(--text) !important; }
.bg-dark    { background: var(--bg-card2) !important; color: var(--text) !important; }
.bg-white, .bg-light {
  background: var(--bg-card) !important;
  color: var(--text) !important;
}

/* ── Tables — full fix ── */
.table {
  color: var(--text) !important;
  font-size: 0.82rem !important;
  --bs-table-bg: transparent !important;
  --bs-table-striped-bg: rgba(255,255,255,0.02) !important;
  --bs-table-hover-bg: rgba(59,126,255,0.06) !important;
  --bs-table-border-color: var(--border) !important;
  --bs-table-color: var(--text) !important;
  border-color: var(--border) !important;
}
.table thead th {
  background: var(--bg-card2) !important;
  color: var(--accent2) !important;
  font-size: 0.72rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  border-bottom: 2px solid rgba(0,198,255,0.2) !important;
  font-weight: 700 !important;
}
.table tbody td, .table tbody th {
  border-color: var(--border) !important;
  background-color: transparent !important;
  color: var(--text) !important;
}
.table tbody tr:last-child td,
.table tbody tr:last-child th {
  border-bottom: none !important;
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: rgba(255,255,255,0.02) !important;
  color: var(--text) !important;
}
.table-responsive, .card > .table,
.card > .table-responsive {
  border: none !important;
  border-bottom: none !important;
}
/* Nuclear option for white bottom line */
.table { border-bottom: none !important; }
.table > *:last-child { border-bottom: none !important; }

/* ── Progress ── */
.progress {
  background: rgba(255,255,255,0.06) !important;
  border-radius: 4px !important;
  height: 6px !important;
}
.progress-bar {
  border-radius: 4px !important;
  color: #fff !important;
  font-weight: 700 !important;
}
/* Tour label */
.card .badge.bg-warning,
.card span.bg-warning,
.card span[style*="background"],
.card div[style*="background: rgb"] {
  color: #000 !important;
  font-weight: 600 !important;
}

/* ── Buttons ── */
.btn {
  border-radius: 7px !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  transition: all 0.15s !important;
}
.btn-primary {
  background: var(--accent) !important;
  border: none !important; color: #fff !important;
}
.btn-primary:hover { background: #2a6aee !important; }
.btn-info {
  background: var(--accent2) !important;
  border: none !important; color: #000 !important;
}
.btn-success {
  background: var(--green) !important;
  border: none !important; color: #000 !important;
}
.btn-danger {
  background: var(--red) !important;
  border: none !important; color: #fff !important;
}
.btn-secondary, .btn-default {
  background: rgba(255,255,255,0.08) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
}
.btn-warning {
  background: #f59e0b !important;
  border: none !important; color: #000 !important;
}

/* ── Forms ── */
.form-control, .form-select,
.select2-container--default .select2-selection--single {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  border-radius: 7px !important;
}
.form-control:focus, .form-select:focus {
  background: rgba(255,255,255,0.07) !important;
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(59,126,255,0.18) !important;
  color: #fff !important;
}
.select2-dropdown {
  background: var(--bg-card2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
}
.select2-results__option { color: var(--text) !important; }
.select2-results__option--highlighted { background: var(--accent) !important; color: #fff !important; }
.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--text) !important;
}

/* ── Badges ── */
.badge {
  border-radius: 6px !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  padding: 3px 8px !important;
}
.badge.bg-success { background: var(--green) !important; color: #000 !important; }
.badge.bg-danger  { background: var(--red) !important; color: #fff !important; }
.badge.bg-primary { background: var(--accent) !important; color: #fff !important; }
.badge.bg-warning { background: #f59e0b !important; color: #000 !important; }
.badge.bg-info    { background: var(--accent2) !important; color: #000 !important; }

/* ── Links ── */
a { color: var(--accent2) !important; text-decoration: none !important; }
a:hover { color: #fff !important; }

/* ── METAR widget ── */
[id*="metar"] *, [class*="metar"] * { color: var(--text) !important; }
[id*="metar"] .badge, [class*="metar"] .badge {
  background: var(--accent) !important;
  color: #fff !important;
}

/* ── Stat bar icons unified ── */
#Dispo_StatBar i, #Dispo_StatBar .fas,
#Dispo_StatBar .far { color: var(--accent2) !important; }

/* ── Hide floating corner logos ── */
#page-contents > div[style*="position: absolute"],
#page-contents > div[style*="bottom: 2rem"],
#page-contents > .card.bg-transparent.border-0 {
  display: none !important;
}

/* ── Discord widget ── */
[id*="discord"], [class*="discord-widget"] {
  max-height: 280px !important;
  overflow-y: auto !important;
}

/* ══════════════════════════════
   FOOTER FIX — sticky to bottom
   ══════════════════════════════ */
html, body { height: 100% !important; }
body {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100vh !important;
}
#page-container {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100vh !important;
}
#page-contents {
  flex: 1 0 auto !important;
}
#footer {
  flex-shrink: 0 !important;
  position: relative !important;
  z-index: 10 !important;
  margin-top: auto !important;
  clear: both !important;
  width: 100% !important;
}
#footer .card {
  background: #0a0d14 !important;
  border-top: 1px solid var(--border) !important;
  border-left: none !important;
  border-right: none !important;
  border-bottom: none !important;
  border-radius: 0 !important;
  font-size: 0.76rem !important;
  color: var(--text-muted) !important;
  margin-bottom: 0 !important;
  box-shadow: none !important;
}
#footer a { color: var(--text-muted) !important; }
#footer a:hover { color: var(--accent2) !important; }

/* ── IVAO footer logo ── */
#footer .ivao-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#footer .ivao-footer img {
  height: 26px !important;
  width: auto !important;
  opacity: 0.6 !important;
  transition: opacity 0.2s !important;
}
#footer .ivao-footer img:hover { opacity: 1 !important; }

/* ── VATSIM (for later) ── */
/*
#footer .vatsim-footer { display:flex !important; align-items:center !important; justify-content:center !important; }
#footer .vatsim-footer img { height:22px !important; opacity:0.6 !important; }
*/

/* ── Tour Progress label fix ── */
[href*="dtours"],
a[href*="dtours"] {
  color: var(--accent2) !important;
  font-weight: 600 !important;
}
/* Kill hardcoded black color on tour link */
.card a[style*="color: black"],
.card a[style*="color:black"] {
  color: var(--accent2) !important;
}
/* Progress bar background */
.card .progress {
  background: rgba(255,255,255,0.08) !important;
  height: 8px !important;
  border-radius: 4px !important;
}

/* ── Input Groups (SimBrief form) ── */
.input-group-text {
  background: var(--bg-card2) !important;
  border: 1px solid var(--border) !important;
  color: var(--text-muted) !important;
  font-size: 0.8rem !important;
}
.input-group .form-select,
.input-group .form-control {
  background: var(--bg-card) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
}
.input-group .form-select:focus,
.input-group .form-control:focus {
  background: var(--bg-card2) !important;
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(59,126,255,0.18) !important;
  color: #fff !important;
}
/* Dropdown options inside selects */
.form-select option,
.input-group select option {
  background: var(--bg-card2) !important;
  color: var(--text) !important;
}

/* ── Prevent modal backdrop from blocking page on load ── */
body:not(.modal-open) .modal-backdrop {
  display: none !important;
  pointer-events: none !important;
}
body:not(.modal-open) .modal {
  pointer-events: none !important;
}

/* ── Modals — above navbar ── */
.modal         { z-index: 1200 !important; }
.modal-backdrop { z-index: 1190 !important; }
.modal-dialog  { z-index: 1210 !important; }

/* ── Navbar — must be BELOW modal ── */
.navbar, nav.navbar, #Dispo_NavBar {
  z-index: 1050 !important;
  position: sticky !important;
  top: 0 !important;
}
  background: var(--bg-card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  color: var(--text) !important;
}
.modal-header {
  background: var(--bg-card2) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 0.6rem 1rem !important;
}
.modal-header .btn-close {
  filter: invert(1) !important;
  opacity: 0.7 !important;
}
.modal-header .btn-close:hover { opacity: 1 !important; }
.modal-footer {
  background: var(--bg-card2) !important;
  border-top: 1px solid var(--border) !important;
}
.modal-body { padding: 0 !important; }

/* ── Leaflet map — subtle dark overlay instead of invert ── */
.leaflet-tile-pane {
  filter: brightness(0.7) saturate(0.8) !important;
}
/* Leave markers/overlays/controls untouched */
.leaflet-marker-pane,
.leaflet-overlay-pane,
.leaflet-shadow-pane,
.leaflet-control-container {
  filter: none !important;
}
/* Leaflet controls */
.leaflet-bar a {
  background: var(--bg-card2) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}
.leaflet-bar a:hover {
  background: var(--bg-card) !important;
  color: var(--accent2) !important;
}
.leaflet-control-layers {
  background: var(--bg-card2) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
}
.leaflet-control-attribution {
  background: rgba(11,14,26,0.8) !important;
  color: var(--text-muted) !important;
}
.leaflet-control-attribution a { color: var(--accent2) !important; }

/* ── Nav pills (Tour tabs) ── */
.nav-pills .nav-link {
  color: var(--text-muted) !important;
  background: var(--bg-card2) !important;
  border: 1px solid var(--border) !important;
  border-radius: 7px !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  transition: all 0.15s !important;
}
.nav-pills .nav-link.active,
.nav-pills .nav-link:hover {
  background: var(--accent) !important;
  color: #fff !important;
  border-color: var(--accent) !important;
}

/* ── Card Footer ── */
.card-footer {
  background: var(--bg-card2) !important;
  border-top: 1px solid var(--border) !important;
  color: var(--text-muted) !important;
}
.card-footer a { color: var(--accent2) !important; }
.card-footer a:hover { color: #fff !important; }
.card-footer i { color: var(--text-muted) !important; }

/* ── Misc ── */
.text-muted { color: var(--text-muted) !important; }
.border, .border-top, .border-bottom { border-color: var(--border) !important; }
hr { border-color: var(--border) !important; opacity: 1 !important; }
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg-base); }
::-webkit-scrollbar-thumb { background: rgba(59,126,255,0.35); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ── Nav Tabs (Route Map / tab buttons) ── */
.nav-tabs .nav-link,
.nav-tabs .nav-item .nav-link,
button.nav-link {
  color: var(--text-muted) !important;
  background: transparent !important;
  border-color: transparent !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  transition: color 0.15s !important;
}
.nav-tabs .nav-link.active,
.nav-tabs .nav-link:hover,
button.nav-link.active,
button.nav-link:hover {
  color: var(--accent2) !important;
  background: transparent !important;
  border-bottom: 2px solid var(--accent2) !important;
}
.nav-tabs {
  border-bottom: 1px solid var(--border) !important;
}

/* ── Table dark-on-dark text nuclear fix ── */
.tab-content .table,
.tab-pane .table,
.tab-content table,
.tab-pane table {
  color: var(--text) !important;
}
.tab-content .table td,
.tab-content .table th,
.tab-pane .table td,
.tab-pane .table th,
.tab-content table td,
.tab-content table th {
  color: var(--text) !important;
  background-color: transparent !important;
}

/* ── Plane / aircraft icon on Leaflet map ── */
.leaflet-marker-pane i.fa,
.leaflet-marker-pane i.fas,
.leaflet-marker-pane i.far,
.leaflet-marker-pane [class*="fa-plane"],
.leaflet-marker-pane [class*="aircraft"],
.leaflet-div-icon i,
.leaflet-div-icon span {
  color: #ffffff !important;
  text-shadow: 0 0 6px rgba(255, 255, 255, 0.6) !important;
  filter: none !important;
}

/* Fallback: if icon is an <img> being darkened */
.leaflet-marker-pane img {
  filter: brightness(0) invert(1) !important;
}