/* =================================================================
   AgentePixju - Sistema de Temas (Claro/Oscuro)
   ================================================================= */

/* Definiciones Base y Reset de Variables */
:root {
  /* TEMA CLARO (Default) */
  --bg-primary: #ffffff;
  --bg-secondary: #f8f9fa; /* Fondo general del dashboard */
  --bg-tertiary: #e9ecef;
  --bg-sidebar: #ffffff;
  --bg-card: #ffffff;
  --bg-hover: #f1f3f5;
  --bg-input: #ffffff;

  /* Texto */
  --text-primary: #2e2e2e; /* Complementario (Light Mode Text) */
  --text-secondary: #6c757d;
  --text-tertiary: #adb5bd;
  --text-sidebar: #2e2e2e;
  --text-sidebar-active: #fa710f; /* Color Principal */
  --text-sidebar-link: #2e2e2e;

  /* Bordes */
  --border-color: #dee2e6;
  --border-light: #e9ecef;
  --border-dark: #adb5bd;

  /* Accent Colors */
  --accent-primary: #fa710f; /* Color Principal */
  --accent-primary-hover: #d65a00;
  --accent-primary-light: rgba(250, 113, 15, 0.1);
  --accent-success: #10b981;
  --accent-danger: #ef4444;
  --accent-warning: #f59e0b;
  --accent-info: #3b82f6;

  /* Sombras */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);

  /* Transiciones */
  --transition-base: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

/* TEMA OSCURO */
[data-theme="dark"] {
  --bg-primary: #2e2e2e;   /* Fondo */
  --bg-secondary: #2e2e2e; /* Fondo dashboard wrapper */
  --bg-tertiary: #1a1a1a;
  --bg-sidebar: #2e2e2e;   /* Sidebar */
  --bg-card: #2e2e2e;      /* Tarjetas */
  --bg-hover: #1f1f1f;
  --bg-input: #1a1a1a;

  /* Texto */
  --text-primary: #919191; /* Complementario al fondo */
  --text-secondary: #919191; /* Aclarado para mejor lectura */
  --text-tertiary: #6c757d;
  --text-sidebar: #919191;
  --text-sidebar-active: #fa710f;
  --text-sidebar-link: #919191;

  /* Bordes */
  --border-color: #2d2d2d;
  --border-light: #1f1f1f;
  --border-dark: #404040;

  /* Accent Adjustments */
  --accent-primary: #fa710f; /* Botones */
  --accent-primary-light: rgba(250, 113, 15, 0.15);
}

/* =================================================================
   APLICACIÓN GLOBAL DE ESTILOS
   ================================================================= */

body, html {
  background-color: var(--bg-secondary) !important; /* Forzar fondo global */
  color: var(--text-primary) !important;
  height: 100%;
}

/* Wrapper principal del dashboard */
#wrapper, .backDashboard, #page-content-wrapper {
  background-color: var(--bg-secondary) !important;
  color: var(--text-primary);
}

/* Forzar color de texto en encabezados y párrafos */
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
  color: var(--text-primary) !important;
}

/* Specific Dark Mode Header override */
[data-theme="dark"] h1, 
[data-theme="dark"] h2, 
[data-theme="dark"] h3, 
[data-theme="dark"] h4, 
[data-theme="dark"] h5, 
[data-theme="dark"] h6, 
[data-theme="dark"] .h1, 
[data-theme="dark"] .h2, 
[data-theme="dark"] .h3, 
[data-theme="dark"] .h4, 
[data-theme="dark"] .h5, 
[data-theme="dark"] .h6 {
  color: #fa710f !important; /* Cabeceras y titulos: #fa710f */
}

p, span, div {
  color: inherit; /* Heredar del padre salvo que se especifique */
}

/* Redefinir clases utilitarias de Bootstrap para Dark Mode */
.text-secondary {
  color: var(--text-secondary) !important;
}

.text-dark {
  color: var(--text-primary) !important; /* En dark mode, 'dark' debe ser claro */
}

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

.bg-white {
  background-color: var(--bg-card) !important;
  color: var(--text-primary) !important;
}

.bg-light {
  background-color: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
}

/* Cards */
.card {
  background-color: var(--bg-card);
  border-color: var(--border-color);
  box-shadow: var(--shadow-sm);
}

.card-header {
  background-color: var(--bg-card);
  border-bottom: 1px solid var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .card-header {
    color: #fa710f !important; /* Headers match headers color preference */
}

.card-body {
  color: var(--text-primary);
}

/* Sidebar */
.sidebar {
  background-color: var(--bg-sidebar) !important;
  border-right: 1px solid var(--border-color);
}

.sidebar .nav-link, 
.text-sidebar-link,
.list-group-item {
  color: var(--text-sidebar-link) !important;
  background-color: transparent !important;
}

.sidebar .nav-link:hover, 
.text-sidebar-link:hover,
.list-group-item:hover {
  background-color: var(--bg-hover) !important;
  color: var(--accent-primary) !important;
}

.sidebar .nav-link.active, 
.list-group-item.active {
  background-color: var(--accent-primary-light) !important;
  color: var(--text-sidebar-active) !important;
}

/* Navbar superior */
.navbar {
  background-color: var(--bg-card) !important;
  border-bottom: 1px solid var(--border-color) !important;
}

/* Inputs y Selects */
.form-control, 
.form-select, 
.input-group-text {
  background-color: var(--bg-input) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

.form-control:focus, 
.form-select:focus {
  background-color: var(--bg-input) !important;
  border-color: var(--accent-primary) !important;
  color: var(--text-primary) !important;
  box-shadow: 0 0 0 0.2rem var(--accent-primary-light);
}

/* Placeholders */
::placeholder {
  color: var(--text-tertiary) !important;
  opacity: 1;
}

/* Tablas */
.table {
  color: var(--text-primary) !important;
  border-color: var(--border-color);
}

.table thead th {
  background-color: var(--bg-tertiary) !important;
  border-bottom: 2px solid var(--border-color);
  color: var(--text-primary) !important;
}

[data-theme="dark"] .table thead th {
    color: #fa710f !important;
}

.table td, .table th {
  border-color: var(--border-color);
}

.table-hover tbody tr:hover {
  background-color: var(--bg-hover) !important;
  color: var(--text-primary);
}

/* Modales */
.modal-content {
  background-color: var(--bg-card);
  border: 1px solid var(--border-color);
}

.modal-header, .modal-footer {
  border-color: var(--border-color);
}

[data-theme="dark"] .modal-title {
    color: #fa710f !important;
}

.btn-close {
    filter: var(--text-primary) == #f8f9fa ? invert(1) : none;
}
[data-theme="dark"] .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

/* Botones */
.btn-primary {
  background-color: var(--accent-primary);
  border-color: var(--accent-primary);
  color: #ffffff;
}

.btn-outline-primary {
  color: var(--accent-primary);
  border-color: var(--accent-primary);
}

.btn-outline-primary:hover {
  background-color: var(--accent-primary);
  color: #ffffff;
}

/* Toggle de Tema */
.theme-toggle {
  cursor: pointer;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.3s ease;
}

.navbar .theme-toggle:hover {
  color: var(--accent-primary);
}

/* Breadcrumb & Links */
.breadcrumb-item {
  color: var(--text-secondary);
}

.breadcrumb-item.active {
  color: var(--text-primary);
}

a {
  color: var(--accent-primary);
  text-decoration: none;
}

a:hover {
  color: var(--accent-primary-hover);
}

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

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

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

::-webkit-scrollbar-thumb:hover {
  background: var(--text-tertiary);
}