/* =============================================================
   Overrides — traduce las clases Bootstrap al dark theme tokenizado
   ============================================================= */

body {
  background: var(--bg-base);
  color: var(--text-secondary);
  font-family: var(--font-sans);
}

h1, h2, h3, h4, h5, h6 { color: var(--text-primary); letter-spacing: -0.2px; }

/* Cards */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  color: var(--text-secondary);
}
.card a { color: var(--text-primary); }

/* Form controls */
.form-label { color: var(--text-muted); font-size: 12px; font-weight: 500; }
.form-control, .form-select {
  background: var(--bg-card-alt);
  border: 1px solid var(--border);
  color: var(--text-primary);
  border-radius: var(--radius-md);
}
.form-control:focus, .form-select:focus {
  background: var(--bg-card-alt);
  border-color: var(--border-focus);
  color: var(--text-primary);
  box-shadow: none;
}
.form-control::placeholder { color: var(--text-dim); }
.form-text { color: var(--text-muted); font-size: 12px; }

/* Buttons */
.btn-outline-secondary {
  color: var(--text-secondary);
  border-color: var(--border);
}
.btn-outline-secondary:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
  border-color: var(--border-hover);
}
/* Tabs estilo "pill" neutro del design system, no usa brand-primary */
.btn-outline-primary {
  background: transparent;
  color: var(--text-muted);
  border: 1px solid var(--border);
}
.btn-outline-primary:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
  border-color: var(--border-hover);
}
/* El btn-primary activo de tabs debe verse como "seleccionado" neutro */
.btn-group .btn-primary,
.btn-group .btn.btn-primary {
  background: var(--text-primary);
  color: var(--bg-base);
  border: 1px solid var(--text-primary);
}
.btn-group .btn-primary:hover {
  filter: brightness(0.95);
  color: var(--bg-base);
}
.btn-outline-success { color: #50E3C2; border-color: #50E3C2; }
.btn-outline-success:hover { background: #50E3C2; color: #000; border-color: #50E3C2; }
.btn-outline-danger { color: #ff6b6b; border-color: #7F1D1D; }
.btn-outline-danger:hover { background: #7F1D1D; color: #fff; border-color: #7F1D1D; }
.btn-success { background: #50E3C2; color: #000; border: 0; }
.btn-success:hover { background: #3acfab; color: #000; }
.btn-danger { background: #7F1D1D; border: 0; }
.btn-secondary {
  background: var(--bg-hover);
  border: 1px solid var(--border);
  color: var(--text-primary);
}
.btn-secondary:hover { background: var(--border); color: var(--text-primary); }

/* Tables */
.table {
  color: var(--text-secondary);
  --bs-table-bg: transparent;
  --bs-table-color: var(--text-secondary);
  --bs-table-hover-bg: var(--bg-hover);
  --bs-table-hover-color: var(--text-primary);
  --bs-table-striped-bg: var(--bg-card-alt);
  border-color: var(--border);
}
.table thead {
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  font-size: 11px;
}
.table thead th {
  border-bottom: 1px solid var(--border);
  font-weight: 500;
  background: transparent !important;
  color: var(--text-muted) !important;
}
.table td, .table th { border-color: var(--border); }

/* Alerts */
.alert {
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}
.alert-success { background: rgba(80, 227, 194, 0.08); border-color: rgba(80, 227, 194, 0.25); color: #a7f3d0; }
.alert-danger  { background: rgba(127, 29, 29, 0.18); border-color: rgba(127, 29, 29, 0.4); color: #fca5a5; }
.alert-warning { background: rgba(251, 191, 36, 0.08); border-color: rgba(251, 191, 36, 0.25); color: #fcd34d; }
.alert-info    { background: rgba(96, 165, 250, 0.08); border-color: rgba(96, 165, 250, 0.25); color: #93c5fd; }

/* Badges */
.badge.bg-light { background: var(--bg-card-alt) !important; color: var(--text-secondary) !important; }
.badge.bg-secondary { background: var(--bg-hover) !important; color: var(--text-secondary) !important; }
.badge.bg-success { background: #50E3C2 !important; color: #000 !important; }
.badge.bg-warning { background: rgba(251, 191, 36, 0.18) !important; color: #fcd34d !important; }

/* Modals */
.modal-content {
  background: var(--bg-card);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
}
.modal-header { border-bottom: 1px solid var(--border); }
.modal-footer { border-top: 1px solid var(--border); }
.btn-close { filter: invert(1) grayscale(1) brightness(2); }

/* Code */
code {
  background: var(--bg-card-alt);
  color: var(--text-primary);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 12px;
}

hr { border-color: var(--border); opacity: 1; }
.text-muted { color: var(--text-muted) !important; }
.vr { background-color: var(--border); opacity: 1; }

/* Page head */
.page-head {
  margin: 8px 0 20px;
}
.page-head h1 { margin: 0; color: var(--text-primary); }
.page-head .sub { color: var(--text-muted); font-size: 13px; margin-top: 4px; }

/* Empty state */
.empty-state {
  text-align: center;
  color: var(--text-muted);
  padding: 40px 20px;
}
.empty-state i { font-size: 24px; margin-bottom: 8px; display: block; color: var(--text-dim); }

/* Fade ins */
.fade-up { animation: fadeUp .25s ease-out both; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
