/* ============================================
   AegisSight Design System - Dark Theme
   Admin Panel CSS Override for Bootstrap 5.3
   ============================================ */

/* --- Google Fonts --- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Poppins:wght@600;700&display=swap');

/* --- Design Tokens --- */
:root {
  --as-bg-primary: #0B1121;
  --as-bg-secondary: #1A2440;
  --as-bg-card: #151D2E;
  --as-bg-sidebar: #0A1832;
  --as-bg-topbar: #151D2E;
  --as-bg-input: #1A2440;
  --as-bg-hover: #1E2D45;

  --as-text-primary: #E8ECF4;
  --as-text-secondary: #8896AB;
  --as-text-disabled: #4A5568;

  --as-border: #1E2D45;
  --as-input-border: #1E2D45;

  --as-accent: #C8A851;
  --as-accent-hover: #B5923E;
  --as-accent-pressed: #A07E2B;

  --as-success: #10B981;
  --as-warning: #F59E0B;
  --as-error: #EF4444;
  --as-info: #7C8DB5;

  --as-table-alt-row: #111827;
  --as-table-header-bg: #0F172A;

  --as-sidebar-width: 240px;
  --as-sidebar-collapsed-width: 64px;
  --as-topbar-height: 56px;
  --as-border-radius: 4px;
  --as-border-radius-lg: 8px;

  /* --- Bootstrap 5 Variable Overrides --- */
  --bs-body-bg: var(--as-bg-primary);
  --bs-body-color: var(--as-text-primary);
  --bs-primary: var(--as-accent);
  --bs-primary-rgb: 200, 168, 81;
  --bs-secondary: var(--as-text-secondary);
  --bs-secondary-rgb: 136, 150, 171;
  --bs-success: var(--as-success);
  --bs-success-rgb: 16, 185, 129;
  --bs-warning: var(--as-warning);
  --bs-warning-rgb: 245, 158, 11;
  --bs-danger: var(--as-error);
  --bs-danger-rgb: 239, 68, 68;
  --bs-info: var(--as-info);
  --bs-info-rgb: 124, 141, 181;
  --bs-light: var(--as-bg-secondary);
  --bs-light-rgb: 26, 36, 64;
  --bs-dark: var(--as-bg-primary);
  --bs-dark-rgb: 11, 17, 33;
  --bs-border-color: var(--as-border);
  --bs-border-radius: 4px;
  --bs-border-radius-lg: 8px;
  --bs-link-color: var(--as-accent);
  --bs-link-color-rgb: 200, 168, 81;
  --bs-link-hover-color: var(--as-accent-hover);
  --bs-link-hover-color-rgb: 181, 146, 62;
  --bs-card-bg: var(--as-bg-card);
  --bs-card-border-color: var(--as-border);
  --bs-card-color: var(--as-text-primary);
  --bs-card-cap-bg: var(--as-bg-secondary);
  --bs-modal-bg: var(--as-bg-card);
  --bs-modal-color: var(--as-text-primary);
  --bs-modal-border-color: var(--as-border);

  /* Sidebar variables (override from base.html) */
  --sidebar-width: 240px;
  --sidebar-collapsed: 64px;
  --status-active: #10B981;
  --status-warning: #F59E0B;
  --status-danger: #EF4444;
  --status-inactive: #4A5568;
  --status-info: #7C8DB5;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */

body {
  font-family: 'Inter', -apple-system, 'Segoe UI', Roboto, sans-serif !important;
  font-size: 14px;
  font-weight: 400;
  background-color: var(--as-bg-primary) !important;
  color: var(--as-text-primary) !important;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: 'Poppins', -apple-system, 'Segoe UI', sans-serif;
  font-weight: 600;
  color: var(--as-text-primary);
}

h1, .h1 { font-weight: 700; font-size: 24px; }
h2, .h2 { font-size: 20px; }
h3, .h3 { font-size: 18px; }
h4, .h4 { font-size: 16px; }
h5, .h5 { font-size: 15px; }

code, pre, .font-monospace {
  font-family: 'SF Mono', 'Consolas', 'Menlo', monospace;
}

.text-muted {
  color: var(--as-text-secondary) !important;
}

a {
  color: var(--as-accent);
}

a:hover {
  color: var(--as-accent-hover);
}

/* ============================================
   BACKGROUND / TEXT UTILITY OVERRIDES
   ============================================ */

.bg-light {
  background-color: var(--as-bg-secondary) !important;
}

.bg-dark {
  background-color: var(--as-bg-primary) !important;
}

.bg-white, .bg-body {
  background-color: var(--as-bg-primary) !important;
}

.bg-body-tertiary {
  background-color: var(--as-bg-secondary) !important;
}

.text-dark {
  color: var(--as-text-primary) !important;
}

.text-white {
  color: var(--as-text-primary) !important;
}

.text-light {
  color: var(--as-text-primary) !important;
}

.text-body {
  color: var(--as-text-primary) !important;
}

.text-primary {
  color: var(--as-accent) !important;
}

.text-success {
  color: var(--as-success) !important;
}

.text-danger {
  color: var(--as-error) !important;
}

.text-warning {
  color: var(--as-warning) !important;
}

.text-info {
  color: var(--as-info) !important;
}

.text-secondary {
  color: var(--as-text-secondary) !important;
}

.border {
  border-color: var(--as-border) !important;
}

.border-secondary {
  border-color: var(--as-border) !important;
}

.border-bottom {
  border-bottom-color: var(--as-border) !important;
}

.rounded {
  border-radius: var(--as-border-radius) !important;
}

/* ============================================
   NAVBAR (TOPBAR)
   ============================================ */

.navbar, nav.navbar {
  background-color: var(--as-bg-topbar) !important;
  border-bottom: 1px solid var(--as-border) !important;
  min-height: var(--as-topbar-height);
  box-shadow: none !important;
}

.navbar .navbar-brand {
  color: var(--as-text-primary) !important;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.navbar .navbar-brand img {
  height: 28px;
  width: auto;
}

.navbar .nav-link {
  color: var(--as-text-secondary) !important;
  font-size: 14px;
  font-weight: 500;
}

.navbar .nav-link:hover,
.navbar .nav-link.active {
  color: var(--as-accent) !important;
}

.navbar .btn-outline-light {
  color: var(--as-text-secondary) !important;
  border-color: var(--as-border) !important;
}

.navbar .btn-outline-light:hover {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-text-primary) !important;
  border-color: var(--as-accent) !important;
}

.navbar-toggler {
  border-color: var(--as-border) !important;
}

.navbar-toggler-icon {
  filter: invert(0.8);
}

/* ============================================
   SIDEBAR
   ============================================ */

.sidebar, #sidebar {
  background-color: var(--as-bg-sidebar) !important;
  border-right: 1px solid var(--as-border) !important;
  top: var(--as-topbar-height);
  height: calc(100vh - var(--as-topbar-height));
}

.sidebar-header {
  background-color: var(--as-bg-sidebar) !important;
  border-bottom: 1px solid var(--as-border) !important;
  color: var(--as-text-secondary) !important;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sidebar-nav .nav-item {
  border-bottom: 1px solid rgba(30, 45, 69, 0.5) !important;
}

.sidebar-nav .nav-link {
  color: var(--as-text-primary) !important;
  font-size: 14px;
  font-weight: 400;
  padding: 10px 16px !important;
  min-height: 44px;
  display: flex !important;
  align-items: center !important;
  border-left: 3px solid transparent;
  transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease;
}

.sidebar-nav .nav-link:hover {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-text-primary) !important;
}

.sidebar-nav .nav-link.active {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-accent) !important;
  border-left: 3px solid var(--as-accent) !important;
  font-weight: 500;
}

.sidebar-nav .nav-link i {
  color: var(--as-text-secondary);
  width: 20px;
  text-align: center;
  margin-right: 12px;
  font-size: 16px;
  transition: color 150ms ease;
}

.sidebar-nav .nav-link:hover i,
.sidebar-nav .nav-link.active i {
  color: var(--as-accent);
}

.sidebar-submenu {
  background-color: rgba(10, 24, 50, 0.5) !important;
}

.sidebar-submenu .nav-link {
  padding-left: 2.5rem !important;
  font-size: 13px !important;
}

/* Arrow for submenu items */
.nav-link.has-submenu::after {
  color: var(--as-text-disabled);
  opacity: 0.6;
}

/* Main content area */
.main-content {
  min-height: calc(100vh - var(--as-topbar-height));
}

/* ============================================
   CARDS
   ============================================ */

.card {
  background-color: var(--as-bg-card) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: var(--as-border-radius) !important;
  box-shadow: none !important;
  color: var(--as-text-primary);
}

.card-header {
  background-color: var(--as-bg-secondary) !important;
  border-bottom: 1px solid var(--as-border) !important;
  color: var(--as-text-primary) !important;
  font-weight: 600;
}

.card-header.bg-dark {
  background-color: var(--as-bg-primary) !important;
}

.card-header.bg-primary {
  background-color: rgba(200, 168, 81, 0.15) !important;
  color: var(--as-accent) !important;
}

.card-header.bg-warning {
  background-color: rgba(245, 158, 11, 0.15) !important;
  color: var(--as-warning) !important;
}

.card-header.bg-info {
  background-color: rgba(124, 141, 181, 0.15) !important;
  color: var(--as-info) !important;
}

.card-header.bg-danger {
  background-color: rgba(239, 68, 68, 0.15) !important;
  color: var(--as-error) !important;
}

.card-header.bg-success {
  background-color: rgba(16, 185, 129, 0.15) !important;
  color: var(--as-success) !important;
}

.card-body {
  background-color: transparent;
  color: var(--as-text-primary);
}

.card-footer {
  background-color: var(--as-bg-secondary) !important;
  border-top: 1px solid var(--as-border) !important;
}

.card-title {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  color: var(--as-text-primary);
}

/* Stat cards from dashboard */
.stat-card {
  border: 1px solid var(--as-border) !important;
  box-shadow: none !important;
}

.stat-card:hover {
  border-color: var(--as-accent) !important;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
}

.stat-card .card-value {
  color: var(--as-accent) !important;
}

.stat-card .card-label {
  color: var(--as-text-secondary) !important;
}

/* ============================================
   TABLES
   ============================================ */

.table {
  --bs-table-bg: var(--as-bg-card);
  --bs-table-color: var(--as-text-primary);
  --bs-table-border-color: var(--as-border);
  --bs-table-striped-bg: var(--as-table-alt-row);
  --bs-table-striped-color: var(--as-text-primary);
  --bs-table-hover-bg: var(--as-bg-secondary);
  --bs-table-hover-color: var(--as-text-primary);
  --bs-table-active-bg: rgba(200, 168, 81, 0.1);
  --bs-table-active-color: var(--as-text-primary);
  border-color: var(--as-border);
  font-size: 14px;
  color: var(--as-text-primary);
}

.table > thead {
  background-color: var(--as-table-header-bg);
}

.table > thead > tr > th {
  background-color: var(--as-table-header-bg) !important;
  color: var(--as-text-secondary) !important;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  border-bottom: 1px solid var(--as-border) !important;
  padding: 10px 12px;
  height: 44px;
  vertical-align: middle;
}

.table > tbody > tr > td {
  padding: 8px 12px;
  vertical-align: middle;
  border-bottom: 1px solid var(--as-border);
  color: var(--as-text-primary);
}

.table > tbody > tr:hover > td {
  background-color: var(--as-bg-hover) !important;
}

.table-dark {
  --bs-table-bg: var(--as-bg-card) !important;
  --bs-table-color: var(--as-text-primary) !important;
  --bs-table-border-color: var(--as-border) !important;
}

.table-dark > thead > tr > th {
  background-color: var(--as-table-header-bg) !important;
  color: var(--as-text-secondary) !important;
}

.table-sm > thead > tr > th {
  padding: 8px 10px;
  height: 40px;
}

.table-sm > tbody > tr > td {
  padding: 6px 10px;
}

.table-responsive {
  border-radius: var(--as-border-radius);
}

/* Sortable table overrides */
.sortable-table th.sortable:hover {
  background-color: var(--as-bg-hover) !important;
}

.sortable-table th.sortable.asc::after,
.sortable-table th.sortable.desc::after {
  color: var(--as-accent) !important;
}

/* Sticky table header */
.table-sticky thead th {
  background-color: var(--as-table-header-bg) !important;
}

/* ============================================
   BUTTONS
   ============================================ */

.btn {
  border-radius: var(--as-border-radius);
  font-weight: 600;
  font-size: 14px;
  transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease;
}

.btn-sm {
  font-size: 12px;
}

.btn-primary {
  background-color: var(--as-accent) !important;
  border-color: var(--as-accent) !important;
  color: #0B1121 !important;
}

.btn-primary:hover, .btn-primary:focus {
  background-color: var(--as-accent-hover) !important;
  border-color: var(--as-accent-hover) !important;
  color: #0B1121 !important;
}

.btn-primary:active, .btn-primary.active {
  background-color: var(--as-accent-pressed) !important;
  border-color: var(--as-accent-pressed) !important;
}

.btn-outline-primary {
  color: var(--as-accent) !important;
  border-color: var(--as-accent) !important;
  background-color: transparent !important;
}

.btn-outline-primary:hover, .btn-outline-primary:focus {
  background-color: var(--as-accent) !important;
  color: #0B1121 !important;
}

.btn-secondary {
  background-color: var(--as-bg-secondary) !important;
  border-color: var(--as-border) !important;
  color: var(--as-text-primary) !important;
}

.btn-secondary:hover {
  background-color: var(--as-bg-hover) !important;
  border-color: var(--as-accent) !important;
}

.btn-success {
  background-color: var(--as-success) !important;
  border-color: var(--as-success) !important;
  color: #fff !important;
}

.btn-success:hover {
  background-color: #0ea571 !important;
  border-color: #0ea571 !important;
}

.btn-danger {
  background-color: var(--as-error) !important;
  border-color: var(--as-error) !important;
  color: #fff !important;
}

.btn-danger:hover {
  background-color: #DC2626 !important;
  border-color: #DC2626 !important;
}

.btn-warning {
  background-color: var(--as-warning) !important;
  border-color: var(--as-warning) !important;
  color: #0B1121 !important;
}

.btn-warning:hover {
  background-color: #d97706 !important;
  border-color: #d97706 !important;
}

.btn-info {
  background-color: var(--as-info) !important;
  border-color: var(--as-info) !important;
  color: #fff !important;
}

.btn-outline-secondary {
  color: var(--as-text-secondary) !important;
  border-color: var(--as-border) !important;
}

.btn-outline-secondary:hover {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-text-primary) !important;
  border-color: var(--as-accent) !important;
}

.btn-outline-success {
  color: var(--as-success) !important;
  border-color: var(--as-success) !important;
}

.btn-outline-success:hover {
  background-color: var(--as-success) !important;
  color: #fff !important;
}

.btn-outline-danger {
  color: var(--as-error) !important;
  border-color: var(--as-error) !important;
}

.btn-outline-danger:hover {
  background-color: var(--as-error) !important;
  color: #fff !important;
}

.btn-outline-warning {
  color: var(--as-warning) !important;
  border-color: var(--as-warning) !important;
}

.btn-outline-warning:hover {
  background-color: var(--as-warning) !important;
  color: #0B1121 !important;
}

.btn-outline-info {
  color: var(--as-info) !important;
  border-color: var(--as-info) !important;
}

.btn-outline-info:hover {
  background-color: var(--as-info) !important;
  color: #fff !important;
}

.btn-outline-light {
  color: var(--as-text-secondary) !important;
  border-color: var(--as-border) !important;
}

.btn-outline-light:hover {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-text-primary) !important;
}

.btn-close {
  filter: invert(1) grayscale(100%) brightness(200%);
}

/* ============================================
   FORMS & INPUTS
   ============================================ */

.form-control, .form-select {
  background-color: var(--as-bg-input) !important;
  border: 1px solid var(--as-input-border) !important;
  color: var(--as-text-primary) !important;
  border-radius: var(--as-border-radius);
  font-size: 14px;
}

.form-control:focus, .form-select:focus {
  background-color: var(--as-bg-input) !important;
  border-color: var(--as-accent) !important;
  color: var(--as-text-primary) !important;
  box-shadow: 0 0 0 2px rgba(200, 168, 81, 0.2) !important;
}

.form-control::placeholder {
  color: var(--as-text-disabled) !important;
}

.form-control:disabled, .form-control[readonly] {
  background-color: var(--as-bg-primary) !important;
  color: var(--as-text-disabled) !important;
  opacity: 0.7;
}

.form-label {
  color: var(--as-text-primary);
  font-weight: 500;
  font-size: 14px;
  margin-bottom: 4px;
}

.form-text {
  color: var(--as-text-secondary);
  font-size: 12px;
}

.form-check-input {
  background-color: var(--as-bg-input) !important;
  border-color: var(--as-input-border) !important;
}

.form-check-input:checked {
  background-color: var(--as-accent) !important;
  border-color: var(--as-accent) !important;
}

.form-check-input:focus {
  box-shadow: 0 0 0 2px rgba(200, 168, 81, 0.2) !important;
  border-color: var(--as-accent) !important;
}

.form-switch .form-check-input:checked {
  background-color: var(--as-accent) !important;
  border-color: var(--as-accent) !important;
}

.input-group-text {
  background-color: var(--as-bg-secondary) !important;
  border-color: var(--as-input-border) !important;
  color: var(--as-text-secondary) !important;
}

textarea.form-control {
  height: auto;
}

/* Select2 overrides */
.select2-container--bootstrap-5 .select2-selection {
  background-color: var(--as-bg-input) !important;
  border-color: var(--as-input-border) !important;
  color: var(--as-text-primary) !important;
}

.select2-container--bootstrap-5 .select2-dropdown {
  background-color: var(--as-bg-card) !important;
  border-color: var(--as-border) !important;
}

.select2-container--bootstrap-5 .select2-results__option {
  color: var(--as-text-primary) !important;
}

.select2-container--bootstrap-5 .select2-results__option--highlighted {
  background-color: var(--as-accent) !important;
  color: #0B1121 !important;
}

.select2-container--bootstrap-5 .select2-search__field {
  background-color: var(--as-bg-input) !important;
  color: var(--as-text-primary) !important;
}

/* ============================================
   BADGES
   ============================================ */

.badge {
  font-weight: 600;
  font-size: 11px;
  border-radius: var(--as-border-radius);
}

.badge.bg-primary {
  background-color: var(--as-accent) !important;
  color: #0B1121 !important;
}

.badge.bg-success {
  background-color: var(--as-success) !important;
  color: #fff !important;
}

.badge.bg-danger {
  background-color: var(--as-error) !important;
  color: #fff !important;
}

.badge.bg-warning {
  background-color: var(--as-warning) !important;
  color: #0B1121 !important;
}

.badge.bg-info {
  background-color: var(--as-info) !important;
  color: #fff !important;
}

.badge.bg-secondary {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-text-secondary) !important;
  border: 1px solid var(--as-border);
}

.badge.bg-dark {
  background-color: var(--as-bg-primary) !important;
  color: var(--as-text-primary) !important;
}

/* Custom status badges from base.html */
.badge-aktiv { background-color: var(--as-success) !important; }
.badge-ablaufend { background-color: var(--as-warning) !important; color: #0B1121 !important; }
.badge-abgelaufen { background-color: var(--as-error) !important; }
.badge-deaktiviert { background-color: var(--as-text-disabled) !important; }

.status-aktiv { color: var(--as-success) !important; }
.status-ablaufend { color: var(--as-warning) !important; }
.status-abgelaufen { color: var(--as-error) !important; }
.status-deaktiviert { color: var(--as-text-disabled) !important; }

/* ============================================
   MODALS
   ============================================ */

.modal-content {
  background-color: var(--as-bg-card) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: var(--as-border-radius-lg) !important;
  color: var(--as-text-primary);
}

.modal-header {
  border-bottom: 1px solid var(--as-border) !important;
  color: var(--as-text-primary);
}

.modal-footer {
  border-top: 1px solid var(--as-border) !important;
}

.modal-title {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  color: var(--as-text-primary);
}

.modal-backdrop {
  background-color: #000;
}

/* ============================================
   ALERTS
   ============================================ */

.alert {
  border-radius: var(--as-border-radius);
}

.alert-success {
  background-color: rgba(16, 185, 129, 0.1) !important;
  border-color: rgba(16, 185, 129, 0.3) !important;
  color: var(--as-success) !important;
}

.alert-danger {
  background-color: rgba(239, 68, 68, 0.1) !important;
  border-color: rgba(239, 68, 68, 0.3) !important;
  color: var(--as-error) !important;
}

.alert-warning {
  background-color: rgba(245, 158, 11, 0.1) !important;
  border-color: rgba(245, 158, 11, 0.3) !important;
  color: var(--as-warning) !important;
}

.alert-info {
  background-color: rgba(124, 141, 181, 0.1) !important;
  border-color: rgba(124, 141, 181, 0.3) !important;
  color: var(--as-info) !important;
}

.alert-primary {
  background-color: rgba(200, 168, 81, 0.1) !important;
  border-color: rgba(200, 168, 81, 0.3) !important;
  color: var(--as-accent) !important;
}

/* ============================================
   DROPDOWNS
   ============================================ */

.dropdown-menu {
  background-color: var(--as-bg-card) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: var(--as-border-radius);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.dropdown-item {
  color: var(--as-text-primary) !important;
  font-size: 14px;
  padding: 8px 16px;
}

.dropdown-item:hover, .dropdown-item:focus {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-text-primary) !important;
}

.dropdown-item.active, .dropdown-item:active {
  background-color: var(--as-accent) !important;
  color: #0B1121 !important;
}

.dropdown-divider {
  border-color: var(--as-border) !important;
}

/* ============================================
   PAGINATION
   ============================================ */

.page-link {
  background-color: var(--as-bg-card);
  border-color: var(--as-border);
  color: var(--as-text-primary);
}

.page-link:hover {
  background-color: var(--as-bg-secondary);
  border-color: var(--as-border);
  color: var(--as-accent);
}

.page-item.active .page-link {
  background-color: var(--as-accent);
  border-color: var(--as-accent);
  color: #0B1121;
}

.page-item.disabled .page-link {
  background-color: var(--as-bg-primary);
  border-color: var(--as-border);
  color: var(--as-text-disabled);
}

/* ============================================
   LIST GROUPS
   ============================================ */

.list-group-item {
  background-color: var(--as-bg-card) !important;
  border-color: var(--as-border) !important;
  color: var(--as-text-primary);
}

.list-group-item.active {
  background-color: var(--as-accent) !important;
  border-color: var(--as-accent) !important;
  color: #0B1121;
}

.list-group-item-action:hover {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-text-primary);
}

/* ============================================
   TABS & NAV PILLS
   ============================================ */

.nav-tabs {
  border-bottom-color: var(--as-border);
}

.nav-tabs .nav-link {
  color: var(--as-text-secondary);
  border: none;
  border-bottom: 2px solid transparent;
  border-radius: 0;
}

.nav-tabs .nav-link:hover {
  color: var(--as-text-primary);
  border-bottom-color: var(--as-text-secondary);
}

.nav-tabs .nav-link.active {
  color: var(--as-accent) !important;
  background-color: transparent !important;
  border-bottom: 2px solid var(--as-accent) !important;
}

.nav-pills .nav-link {
  color: var(--as-text-secondary);
  border-radius: var(--as-border-radius);
}

.nav-pills .nav-link.active {
  background-color: var(--as-accent) !important;
  color: #0B1121 !important;
}

/* ============================================
   ACCORDION
   ============================================ */

.accordion-item {
  background-color: var(--as-bg-card) !important;
  border-color: var(--as-border) !important;
  color: var(--as-text-primary);
}

.accordion-button {
  background-color: var(--as-bg-card) !important;
  color: var(--as-text-primary) !important;
}

.accordion-button:not(.collapsed) {
  background-color: var(--as-bg-secondary) !important;
  color: var(--as-accent) !important;
  box-shadow: none;
}

.accordion-button::after {
  filter: invert(1) brightness(2);
}

.accordion-body {
  background-color: var(--as-bg-card);
  color: var(--as-text-primary);
}

/* ============================================
   PROGRESS BARS
   ============================================ */

.progress {
  background-color: var(--as-bg-secondary) !important;
  border-radius: var(--as-border-radius);
}

.progress-bar {
  background-color: var(--as-accent);
}

.progress-bar.bg-success {
  background-color: var(--as-success) !important;
}

.progress-bar.bg-warning {
  background-color: var(--as-warning) !important;
}

.progress-bar.bg-danger {
  background-color: var(--as-error) !important;
}

/* ============================================
   TOOLTIPS & POPOVERS
   ============================================ */

.tooltip-inner {
  background-color: var(--as-bg-secondary);
  color: var(--as-text-primary);
  border: 1px solid var(--as-border);
  border-radius: var(--as-border-radius);
  font-size: 12px;
}

.popover {
  background-color: var(--as-bg-card);
  border-color: var(--as-border);
}

.popover-header {
  background-color: var(--as-bg-secondary);
  border-bottom-color: var(--as-border);
  color: var(--as-text-primary);
}

.popover-body {
  color: var(--as-text-primary);
}

/* ============================================
   CODE BLOCKS
   ============================================ */

code {
  color: var(--as-accent);
  background-color: rgba(200, 168, 81, 0.1);
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 13px;
}

pre {
  background-color: var(--as-bg-secondary);
  border: 1px solid var(--as-border);
  border-radius: var(--as-border-radius);
  padding: 16px;
  color: var(--as-text-primary);
}

pre code {
  background-color: transparent;
  padding: 0;
}

/* ============================================
   SPINNERS
   ============================================ */

.spinner-border.text-primary {
  color: var(--as-accent) !important;
}

/* ============================================
   SCROLLBAR (WebKit)
   ============================================ */

::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--as-bg-primary);
}

::-webkit-scrollbar-thumb {
  background: var(--as-border);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--as-text-disabled);
}

/* Firefox scrollbar */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--as-border) var(--as-bg-primary);
}

/* ============================================
   SELECTION
   ============================================ */

::selection {
  background-color: rgba(200, 168, 81, 0.3);
  color: var(--as-text-primary);
}

/* ============================================
   SESSION TIMER (from base.html)
   ============================================ */

#session-timer {
  font-family: 'SF Mono', 'Consolas', monospace;
  border-radius: var(--as-border-radius);
}

.timer-normal {
  background-color: var(--as-success) !important;
  color: #fff !important;
}

.timer-warning {
  background-color: var(--as-warning) !important;
  color: #0B1121 !important;
}

.timer-danger {
  background-color: var(--as-error) !important;
  color: #fff !important;
}

.timer-critical {
  background-color: var(--as-error) !important;
  color: #fff !important;
}

/* ============================================
   LOGIN PAGE
   ============================================ */

.login-container {
  min-height: 100vh;
  background-color: var(--as-bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.login-card {
  background-color: var(--as-bg-card);
  border: 1px solid var(--as-border);
  border-radius: var(--as-border-radius-lg);
  padding: 40px;
  width: 100%;
  max-width: 420px;
}

.login-card .login-logo {
  text-align: center;
  margin-bottom: 32px;
}

.login-card .login-logo img {
  height: 60px;
  margin-bottom: 16px;
}

.login-card .login-logo h2 {
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 22px;
  color: var(--as-accent);
  margin-bottom: 4px;
}

.login-card .login-logo .subtitle {
  color: var(--as-text-secondary);
  font-size: 14px;
}

.login-card .error-failed {
  background-color: var(--as-error) !important;
  color: #fff !important;
  border-radius: var(--as-border-radius);
  padding: 12px;
  text-align: center;
  font-weight: 600;
  margin-bottom: 16px;
  font-size: 14px !important;
  text-transform: none !important;
}

.login-card .error-blocked {
  background-color: rgba(124, 141, 181, 0.15) !important;
  border: 1px solid var(--as-info);
  color: var(--as-info) !important;
  border-radius: var(--as-border-radius);
  padding: 12px;
  text-align: center;
  font-weight: 600;
  margin-bottom: 16px;
  font-size: 14px !important;
}

.login-card .error-captcha {
  background-color: rgba(245, 158, 11, 0.15) !important;
  border: 1px solid var(--as-warning);
  color: var(--as-warning) !important;
  border-radius: var(--as-border-radius);
  padding: 12px;
  text-align: center;
  font-weight: 600;
  margin-bottom: 16px;
  font-size: 14px !important;
}

.login-card .attempts-warning {
  background-color: rgba(245, 158, 11, 0.15);
  border: 1px solid var(--as-warning);
  color: var(--as-warning);
  padding: 8px 12px;
  border-radius: var(--as-border-radius);
  text-align: center;
  margin-bottom: 16px;
  font-weight: 600;
  font-size: 13px;
}

.login-card .security-info {
  color: var(--as-text-disabled);
  font-size: 12px;
  text-align: center;
  margin-top: 16px;
}

/* ============================================
   ERROR PAGES (404, 500)
   ============================================ */

.error-page {
  min-height: 100vh;
  background-color: var(--as-bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--as-text-primary);
}

.error-page .error-code {
  font-family: 'Poppins', sans-serif;
  font-size: 80px;
  font-weight: 700;
  color: var(--as-accent);
  line-height: 1;
  margin-bottom: 16px;
}

.error-page .error-message {
  font-family: 'Poppins', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--as-text-primary);
  margin-bottom: 8px;
}

.error-page .error-detail {
  font-size: 14px;
  color: var(--as-text-secondary);
  margin-bottom: 32px;
}

/* ============================================
   MISC OVERRIDES
   ============================================ */

/* Breadcrumbs */
.breadcrumb-item a { color: var(--as-accent); }
.breadcrumb-item.active { color: var(--as-text-secondary); }
.breadcrumb-item + .breadcrumb-item::before { color: var(--as-text-disabled); }

/* Close button in dark modals */
.btn-close-white {
  filter: invert(1) grayscale(100%) brightness(200%);
}

/* Bulk actions bar */
.bulk-actions {
  background-color: var(--as-bg-secondary) !important;
  border-top: 1px solid var(--as-border);
}

/* Copy button */
.btn-copy:hover {
  background-color: var(--as-bg-secondary) !important;
}

.btn-copy.copied {
  background-color: var(--as-success) !important;
  color: #fff !important;
}

/* Session warning */
.session-warning-modal .alert {
  background-color: var(--as-bg-card) !important;
  border: 1px solid var(--as-error) !important;
  color: var(--as-text-primary) !important;
}

/* Service health border-left */
.border-start, [style*="border-left"] {
  border-color: inherit;
}

/* Dark text override for card-header with bg-warning text-dark combo */
.card-header.bg-warning .text-dark,
.card-header .text-dark {
  color: inherit !important;
}
