/* Custom overrides for AdminLTE */
body {
  background-color: #f4f6f9;
  font-family: 'Source Sans Pro', sans-serif;
}

.content-wrapper {
  background-color: #f4f6f9;
}

.small-box {
  transition: all 0.3s ease;
}

.small-box:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
}

.card {
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
  border: none;
}

.card:hover {
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.text-muted {
  color: #6c757d;
}

.text-success {
  color: #28a745;
}

.info-box {
  transition: all 0.3s ease !important;
}

.info-box:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.15) !important;
}

.info-box-content {
  display: flex;
  flex-direction: column;
}

.stat-value {
  font-size: 2rem;
  font-weight: 700;
  margin: 5px 0;
}

.stat-label {
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: rgba(0,0,0,0.6);
}

.card-header {
  background: linear-gradient(135deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0.02) 100%);
  border-bottom: 2px solid rgba(0,0,0,0.08);
}

.card-header.bg-danger {
  background: linear-gradient(135deg, #dc3545 0%, #c82333 100%) !important;
}

.card-header.bg-info {
  background: linear-gradient(135deg, #17a2b8 0%, #138496 100%) !important;
}

.card-header.bg-warning {
  background: linear-gradient(135deg, #ffc107 0%, #e0a800 100%) !important;
}

.progress {
  background-color: #e9ecef;
  border-radius: 3px;
  overflow: hidden;
}

.alert-badge {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.alert-critical {
  background-color: #ff6b6b;
  color: white;
}

.alert-warning {
  background-color: #ffc107;
  color: #333;
}

.alert-info {
  background-color: #17a2b8;
  color: white;
}

.list-group-item {
  transition: all 0.2s ease;
  background-color: #fff;
}

.list-group-item:hover {
  background-color: #f8f9fa;
}

.table-hover tbody tr:hover {
  background-color: #f8f9fa;
}

.bg-gradient-primary {
  background: linear-gradient(135deg, #007bff 0%, #0056b3 100%) !important;
}

.opacity-75 {
  opacity: 0.75;
}

/* Header action buttons (e.g. "+ Nuevo ...") */
.content-header .page-header-actions .btn.btn-sm,
.content-header .page-header-actions .btn,
.content-header .sub-toolbar .btn.btn-sm,
.content-header .sub-toolbar .btn,
.content-header .page-actions .btn.btn-sm,
.content-header .page-actions .btn,
.content-header .ph-actions .btn.btn-sm,
.content-header .ph-actions .btn,
.page-header-actions .btn.btn-sm,
.page-header-actions .btn,
.page-header-actions .btn-novo,
.page-actions .btn.btn-sm,
.page-actions .btn,
.ph-actions .btn.btn-sm,
.ph-actions .btn,
.sub-toolbar .btn.btn-sm,
.sub-toolbar .btn {
  padding: 0.55rem 1.05rem !important;
  font-weight: 800 !important;
  border-radius: 999px !important;
  letter-spacing: 0.2px !important;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18) !important;
  border: 1px solid rgba(255, 255, 255, 0.35) !important;
}

.content-header .page-header-actions .btn.btn-sm i,
.content-header .page-header-actions .btn i,
.content-header .sub-toolbar .btn.btn-sm i,
.content-header .sub-toolbar .btn i,
.content-header .page-actions .btn.btn-sm i,
.content-header .page-actions .btn i,
.content-header .ph-actions .btn.btn-sm i,
.content-header .ph-actions .btn i,
.page-header-actions .btn.btn-sm i,
.page-header-actions .btn i,
.page-header-actions .btn-novo i,
.page-actions .btn.btn-sm i,
.page-actions .btn i,
.ph-actions .btn.btn-sm i,
.ph-actions .btn i,
.sub-toolbar .btn.btn-sm i,
.sub-toolbar .btn i {
  font-size: 0.95em !important;
}

.content-header .page-header-actions .btn:hover,
.content-header .sub-toolbar .btn:hover,
.content-header .page-actions .btn:hover,
.content-header .ph-actions .btn:hover,
.page-header-actions .btn:hover,
.page-header-actions .btn-novo:hover,
.page-actions .btn:hover,
.ph-actions .btn:hover,
.sub-toolbar .btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.22) !important;
}

/* Extra-specific override for header "Nuevo" buttons (kept scoped to action containers) */
.page-header-actions button.btn.btn-light,
.page-header-actions button.btn.btn-light.btn-sm,
.page-header-actions button.btn.btn-primary,
.sub-toolbar button.btn.btn-light,
.sub-toolbar button.btn.btn-light.btn-sm,
.sub-toolbar button.btn.btn-primary,
.page-actions button.btn.btn-light,
.page-actions button.btn.btn-light.btn-sm,
.page-actions button.btn.btn-primary,
.ph-actions button.btn.btn-light,
.ph-actions button.btn.btn-light.btn-sm,
.ph-actions button.btn.btn-primary {
  color: #1f2937 !important;
  -webkit-text-fill-color: #1f2937 !important;
}

.page-header-actions button.btn.btn-light *,
.page-header-actions button.btn.btn-light.btn-sm *,
.page-header-actions button.btn.btn-primary *,
.sub-toolbar button.btn.btn-light *,
.sub-toolbar button.btn.btn-light.btn-sm *,
.sub-toolbar button.btn.btn-primary *,
.page-actions button.btn.btn-light *,
.page-actions button.btn.btn-light.btn-sm *,
.page-actions button.btn.btn-primary *,
.ph-actions button.btn.btn-light *,
.ph-actions button.btn.btn-light.btn-sm *,
.ph-actions button.btn.btn-primary * {
  color: #1f2937 !important;
  -webkit-text-fill-color: #1f2937 !important;
}

/* Ensure readable black text on light header action buttons */
.content-header .page-header-actions .btn.btn-light,
.content-header .page-header-actions .btn.btn-outline-secondary,
.content-header .page-header-actions .btn.btn-outline-light,
.content-header .sub-toolbar .btn.btn-light,
.content-header .sub-toolbar .btn.btn-outline-secondary,
.content-header .sub-toolbar .btn.btn-outline-light {
  color: #0f172a !important;
}

.page-header-actions .btn.btn-light,
.page-header-actions .btn.btn-outline-secondary,
.page-header-actions .btn.btn-outline-light,
.sub-toolbar .btn.btn-light,
.sub-toolbar .btn.btn-outline-secondary,
.sub-toolbar .btn.btn-outline-light {
  color: #0f172a !important;
}

.content-header .page-header-actions .btn.btn-light i,
.content-header .page-header-actions .btn.btn-outline-secondary i,
.content-header .page-header-actions .btn.btn-outline-light i,
.content-header .sub-toolbar .btn.btn-light i,
.content-header .sub-toolbar .btn.btn-outline-secondary i,
.content-header .sub-toolbar .btn.btn-outline-light i {
  color: #0f172a !important;
}

.page-header-actions .btn.btn-light i,
.page-header-actions .btn.btn-outline-secondary i,
.page-header-actions .btn.btn-outline-light i,
.sub-toolbar .btn.btn-light i,
.sub-toolbar .btn.btn-outline-secondary i,
.sub-toolbar .btn.btn-outline-light i {
  color: #0f172a !important;
}

.page-header-actions .btn.btn-light *,
.page-header-actions .btn.btn-outline-secondary *,
.page-header-actions .btn.btn-outline-light *,
.sub-toolbar .btn.btn-light *,
.sub-toolbar .btn.btn-outline-secondary *,
.sub-toolbar .btn.btn-outline-light * {
  color: #0f172a !important;
}

/* Force black text on header primary action buttons (keep contrast by using light surface) */
.content-header .page-header-actions .btn.btn-primary,
.content-header .sub-toolbar .btn.btn-primary,
.page-header-actions .btn.btn-primary,
.sub-toolbar .btn.btn-primary {
  color: #1f2937 !important;
  background: linear-gradient(135deg, #fde047 0%, #f59e0b 100%) !important;
  border-color: rgba(15, 23, 42, 0.22) !important;
}

.content-header .page-header-actions .btn.btn-primary i,
.content-header .sub-toolbar .btn.btn-primary i,
.page-header-actions .btn.btn-primary i,
.sub-toolbar .btn.btn-primary i {
  color: #1f2937 !important;
}

.content-header .page-header-actions .btn.btn-primary *,
.content-header .sub-toolbar .btn.btn-primary *,
.page-header-actions .btn.btn-primary *,
.sub-toolbar .btn.btn-primary * {
  color: #1f2937 !important;
}

.content-header .page-header-actions .btn.btn-primary:hover,
.content-header .sub-toolbar .btn.btn-primary:hover,
.page-header-actions .btn.btn-primary:hover,
.sub-toolbar .btn.btn-primary:hover {
  background: linear-gradient(135deg, #fef08a 0%, #fbbf24 100%) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 18px 36px rgba(245, 158, 11, 0.35) !important;
}

/* CTA look for header "Nuevo" buttons that are rendered as btn-light */
.page-header-actions .btn.btn-light,
.sub-toolbar .btn.btn-light,
.content-header .page-header-actions .btn.btn-light,
.content-header .sub-toolbar .btn.btn-light {
  color: #1f2937 !important;
  -webkit-text-fill-color: #1f2937 !important;
  background: linear-gradient(135deg, #fde047 0%, #f59e0b 100%) !important;
  border: 1px solid rgba(15, 23, 42, 0.22) !important;
  box-shadow: 0 18px 36px rgba(245, 158, 11, 0.32) !important;
}

.page-header-actions .btn.btn-light *,
.sub-toolbar .btn.btn-light *,
.content-header .page-header-actions .btn.btn-light *,
.content-header .sub-toolbar .btn.btn-light * {
  color: #1f2937 !important;
  -webkit-text-fill-color: #1f2937 !important;
}

/* Also normalize custom header buttons like .btn-novo (e.g. Consumo) */
.page-header-actions .btn-novo,
.content-header .page-header-actions .btn-novo {
  color: #1f2937 !important;
  -webkit-text-fill-color: #1f2937 !important;
  background: linear-gradient(135deg, #fde047 0%, #f59e0b 100%) !important;
  border: 1px solid rgba(15, 23, 42, 0.22) !important;
  box-shadow: 0 18px 36px rgba(245, 158, 11, 0.32) !important;
}

.page-header-actions .btn-novo *,
.content-header .page-header-actions .btn-novo * {
  color: #1f2937 !important;
  -webkit-text-fill-color: #1f2937 !important;
}

/* Perfil: keep "Inicio" button and account meta readable (dark text), without touching badges */
.page-header.dashboard-header .page-header-top a.btn.btn-light,
.page-header.dashboard-header .page-header-top a.btn.btn-light.btn-sm {
  color: #1f2937 !important;
  -webkit-text-fill-color: #1f2937 !important;
}

.page-header.dashboard-header .page-header-top a.btn.btn-light i,
.page-header.dashboard-header .page-header-top a.btn.btn-light.btn-sm i {
  color: #1f2937 !important;
}

.page-header.dashboard-header .identity-meta .meta-pill .k,
.page-header.dashboard-header .identity-meta .meta-pill .v,
.page-header.dashboard-header .identity-meta .meta-pill .k i,
.page-header.dashboard-header .identity-meta .meta-pill .v i {
  color: #1f2937 !important;
}

/* Perfil: make values (e.g. "Administrador", "Activo") a bit softer than labels */
.page-header.dashboard-header .identity-meta .meta-pill .v,
.page-header.dashboard-header .identity-meta .meta-pill .v i {
  color: #111827 !important;
}

.page-header.dashboard-header .account-info-label,
.page-header.dashboard-header .account-info-value {
  color: #1f2937 !important;
}

.page-header.dashboard-header .account-info-value {
  color: #111827 !important;
}

.page-header.dashboard-header .account-info-value .badge {
  color: #ffffff !important;
}

.page-header-actions .btn.btn-light:hover,
.sub-toolbar .btn.btn-light:hover,
.content-header .page-header-actions .btn.btn-light:hover,
.content-header .sub-toolbar .btn.btn-light:hover {
  background: linear-gradient(135deg, #fef08a 0%, #fbbf24 100%) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 22px 42px rgba(245, 158, 11, 0.38) !important;
}
