/* ============================================
   SISTEMA DE TEMAS GLOBAL - INDEXAR
   ============================================ */

/* Variable dinámica para color primario institucional */
:root {
  /* Color primario personalizable (se puede cambiar dinámicamente) */
  --custom-primary: #4BA1BF;
  --primary-color: var(--custom-primary);
}

/* Variables para tema CLARO (default) */
:root,
:root[data-theme="light"] {
  /* Colores de fondo */
  --bg-color: #f8f9fa;
  --bg-secondary: #ffffff;
  --card-bg: #ffffff;
  --sidebar-bg: #ffffff;
  --navbar-bg: #ffffff;
  --modal-bg: #ffffff;
  --offcanvas-bg: #ffffff;
  
  /* Colores de texto */
  --text-color: #2c6e87;
  --text-primary: #2c6e87;
  --text-secondary: #6c757d;
  --text-muted: #adb5bd;
  
  /* Colores de borde */
  --border-color: #e9ecef;
  --border-secondary: #dee2e6;
  
  /* Colores Indexar (usando variable dinámica) */
  --idx-primary: var(--primary-color);
  --idx-primary-dark: #2C6E87; /* Se calcula automáticamente o se puede personalizar */
  --idx-primary-light: #8FC8DA; /* Se puede calcular desde primary */
  --idx-accent: var(--primary-color);
  --idx-success: #34c38f;
  --idx-warning: #f1b44c;
  --idx-danger: #f46a6a;
  --idx-info: #50a5f1;
  
  /* Sombras */
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 8px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.1);
  
  /* Bordes */
  --radius: 0.5rem;
  --radius-lg: 1rem;
}

/* Variables para tema OSCURO */
:root[data-theme="dark"] {
  /* Colores de fondo */
  --bg-color: #1e1e2f;
  --bg-secondary: #252842;
  --card-bg: #2a3042;
  --sidebar-bg: #2a3042;
  --navbar-bg: #2a3042;
  --modal-bg: #2a3042;
  --offcanvas-bg: #2a3042;
  
  /* Colores de texto */
  --text-color: #f8f9fa;
  --text-primary: #ffffff;
  --text-secondary: #adb5bd;
  --text-muted: #6c757d;
  
  /* Colores de borde */
  --border-color: #3a3f54;
  --border-secondary: #495057;
  
  /* Colores Indexar (usando variable dinámica, ajustados para dark) */
  --idx-primary: var(--primary-color);
  --idx-primary-dark: #2C6E87; /* Se puede calcular desde primary */
  --idx-primary-light: #8FC8DA; /* Se puede calcular desde primary */
  --idx-accent: #8FC8DA;
  --idx-success: #34c38f;
  --idx-warning: #f1b44c;
  --idx-danger: #f46a6a;
  --idx-info: #50a5f1;
  
  /* Sombras (más suaves en dark) */
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 8px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.5);
}

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

html,
body {
  background-color: var(--bg-color) !important;
  color: var(--text-color) !important;
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Cards */
.card {
  background-color: var(--card-bg) !important;
  color: var(--text-color) !important;
  border-color: var(--border-color) !important;
  box-shadow: var(--shadow-md);
}

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

.card-footer {
  background-color: var(--card-bg) !important;
  border-top-color: var(--border-color) !important;
}

/* Tablas */
.table {
  color: var(--text-color) !important;
  background-color: var(--card-bg) !important;
}

.table thead th {
  color: var(--text-secondary) !important;
  border-bottom-color: var(--border-color) !important;
  background-color: var(--card-bg) !important;
}

.table tbody td {
  border-color: var(--border-color) !important;
  background-color: var(--card-bg) !important;
}

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

.table-striped tbody tr:nth-of-type(odd) {
  background-color: var(--bg-secondary) !important;
}

/* Formularios */
.form-control,
.form-select {
  background-color: var(--card-bg) !important;
  color: var(--text-color) !important;
  border-color: var(--border-color) !important;
}

.form-control:focus,
.form-select:focus {
  background-color: var(--card-bg) !important;
  color: var(--text-color) !important;
  border-color: var(--idx-primary) !important;
}

.form-label {
  color: var(--text-primary) !important;
}

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

/* Botones */
.btn-light {
  background-color: var(--bg-secondary) !important;
  color: var(--text-color) !important;
  border-color: var(--border-color) !important;
}

.btn-outline-primary {
  border-color: var(--idx-primary) !important;
  color: var(--idx-primary) !important;
}

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

.btn-secondary {
  background-color: var(--bg-secondary) !important;
  color: var(--text-color) !important;
  border-color: var(--border-color) !important;
}

/* Links */
a {
  color: var(--idx-primary) !important;
}

a:hover {
  color: var(--idx-primary-dark) !important;
}

/* Sidebar */
.sidebar,
.sidebar-skote {
  background: linear-gradient(180deg, var(--sidebar-bg) 0%, var(--bg-secondary) 100%) !important;
  border-right-color: var(--border-color) !important;
  color: var(--text-color) !important;
}

.sidebar .nav-link,
.sidebar-skote .nav-link {
  color: var(--text-color) !important;
}

.sidebar .nav-link:hover,
.sidebar-skote .nav-link:hover {
  background-color: var(--bg-secondary) !important;
  color: var(--idx-accent) !important;
}

.sidebar .nav-link.active,
.sidebar-skote .nav-link.active {
  background-color: rgba(75, 161, 191, 0.15) !important;
  color: var(--idx-primary) !important;
  border-left-color: var(--idx-primary) !important;
}

/* Topbar / Navbar */
.topbar-skote {
  background-color: var(--navbar-bg) !important;
  border-bottom-color: var(--border-color) !important;
  color: var(--text-color) !important;
}

.topbar-skote .btn-search {
  background-color: var(--bg-secondary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
}

.topbar-skote .btn-search:hover {
  border-color: var(--idx-primary) !important;
  background-color: var(--card-bg) !important;
  color: var(--idx-primary) !important;
}

.topbar-skote .btn-icon {
  color: var(--text-secondary) !important;
}

.topbar-skote .btn-icon:hover {
  background-color: var(--bg-secondary) !important;
  color: var(--idx-primary) !important;
}

.topbar-skote .breadcrumb-item {
  color: var(--text-secondary) !important;
}

.topbar-skote .breadcrumb-item.active {
  color: var(--text-primary) !important;
}

.topbar-skote .profile-name {
  color: var(--text-primary) !important;
}

/* Modal y Offcanvas */
.modal-content,
.offcanvas {
  background-color: var(--modal-bg) !important;
  color: var(--text-color) !important;
}

.modal-header,
.offcanvas-header {
  border-bottom-color: var(--border-color) !important;
}

.modal-footer,
.offcanvas-footer {
  border-top-color: var(--border-color) !important;
}

.dropdown-menu {
  background-color: var(--card-bg) !important;
  border-color: var(--border-color) !important;
}

.dropdown-item {
  color: var(--text-color) !important;
}

.dropdown-item:hover {
  background-color: var(--bg-secondary) !important;
  color: var(--text-color) !important;
}

.dropdown-divider {
  border-top-color: var(--border-color) !important;
}

.dropdown-header {
  color: var(--text-primary) !important;
}

/* List groups */
.list-group-item {
  background-color: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-color) !important;
}

.list-group-item-action:hover {
  background-color: var(--bg-secondary) !important;
  color: var(--text-color) !important;
}

/* Badges */
.badge {
  background-color: var(--idx-primary) !important;
  color: #ffffff !important;
}

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

/* Input groups */
.input-group-text {
  background-color: var(--bg-secondary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-color) !important;
}

/* Breadcrumbs */
.breadcrumb {
  background-color: transparent !important;
}

.breadcrumb-item {
  color: var(--text-secondary) !important;
}

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

.breadcrumb-item + .breadcrumb-item::before {
  color: var(--text-muted) !important;
}

/* Utilities Indexar */
.kpi-value {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 800;
  color: var(--text-primary) !important;
}

.kpi-trend-up {
  color: var(--idx-success) !important;
}

.kpi-trend-down {
  color: var(--idx-danger) !important;
}

.btn-primary {
  background-color: var(--idx-primary) !important;
  border-color: var(--idx-primary-dark) !important;
}

.btn-primary:hover {
  background-color: var(--idx-primary-dark) !important;
  border-color: var(--idx-primary-dark) !important;
}

/* ERP Quick */
.erp-quick .item {
  background-color: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-color) !important;
}

.erp-quick .item:hover {
  background-color: var(--bg-secondary) !important;
  border-color: var(--idx-primary) !important;
}

/* Footer */
.footer-muted {
  color: var(--text-muted) !important;
}

/* Sidebar layout específico */
.sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 260px;
  background: var(--sidebar-bg);
  border-right: 1px solid var(--border-color);
}

.sidebar .brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px;
  color: var(--text-color);
  text-decoration: none;
}

.main.has-sidebar {
  margin-left: 260px;
}

.main.has-topbar {
  padding-top: 70px;
}

.main.has-sidebar.has-topbar {
  margin-left: 260px;
  padding-top: 70px;
}

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