/**
 * Pynex Design System
 * Sistema de diseño consistente para toda la aplicación
 * -------------------------------------------------------------------------------------
 */

:root {
  /* Colores Principales */
  --px-primary: #696cff;
  --px-primary-dark: #5f61e6;
  --px-primary-darker: #5658d9;
  --px-primary-light: #e1e2ff;
  --px-primary-lighter: #f0f0ff;
  
  --px-secondary: #8592a3;
  --px-success: #71dd37;
  --px-info: #03c3ec;
  --px-warning: #ffab00;
  --px-danger: #ff3e1d;
  --px-dark: #2b2c40;
  
  /* Colores de Texto */
  --px-text-primary: #566a7f;
  --px-text-secondary: #a1acb8;
  --px-text-muted: #a7acb2;
  --px-text-heading: #384551;
  
  /* Colores de Fondo */
  --px-bg-primary: #ffffff;
  --px-bg-secondary: #fafbfc;
  --px-bg-tertiary: #f8f9fa;
  --px-bg-hover: rgba(105, 108, 255, 0.08);
  
  /* Bordes */
  --px-border-color: #e7e7e7;
  --px-border-color-light: #d9dee3;
  --px-border-radius: 12px;
  --px-border-radius-sm: 8px;
  --px-border-radius-lg: 16px;
  
  /* Sombras */
  --px-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.02);
  --px-shadow-md: 0 2px 8px rgba(0, 0, 0, 0.08);
  --px-shadow-lg: 0 4px 12px rgba(0, 0, 0, 0.12);
  --px-shadow-xl: 0 6px 16px rgba(0, 0, 0, 0.16);
  --px-shadow-primary: 0 4px 12px rgba(105, 108, 255, 0.3);
  
  /* Transiciones */
  --px-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --px-transition-fast: all 0.2s ease;
  --px-transition-slow: all 0.4s ease;
  
  /* Espaciado */
  --px-spacing-xs: 0.5rem;
  --px-spacing-sm: 0.75rem;
  --px-spacing-md: 1rem;
  --px-spacing-lg: 1.5rem;
  --px-spacing-xl: 2rem;
  --px-spacing-xxl: 2.5rem;
}

/* Modo Oscuro */
html.dark-mode,
body.dark-mode {
  --px-bg-primary: #2b2c40;
  --px-bg-secondary: #232333;
  --px-bg-tertiary: #1e1f2e;
  --px-bg-hover: rgba(105, 108, 255, 0.15);
  
  --px-text-primary: #e4e6eb;
  --px-text-secondary: #a7acb2;
  --px-text-muted: #6c757d;
  --px-text-heading: #ffffff;
  
  --px-border-color: #3e405e;
  --px-border-color-light: #3e405e;
  
  --px-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.2);
  --px-shadow-md: 0 2px 8px rgba(0, 0, 0, 0.3);
  --px-shadow-lg: 0 4px 12px rgba(0, 0, 0, 0.4);
  --px-shadow-xl: 0 6px 16px rgba(0, 0, 0, 0.5);
}

/* ============================================
   COMPONENTES BASE
   ============================================ */

/* Cards */
.px-card {
  background: var(--px-bg-primary);
  border-radius: var(--px-border-radius);
  box-shadow: var(--px-shadow-md);
  border: 1px solid var(--px-border-color);
  transition: var(--px-transition);
  overflow: hidden;
}

.px-card:hover {
  box-shadow: var(--px-shadow-lg);
  transform: translateY(-2px);
}

.px-card-header {
  padding: var(--px-spacing-lg);
  border-bottom: 1px solid var(--px-border-color);
  background: linear-gradient(135deg, rgba(105, 108, 255, 0.02) 0%, rgba(255, 255, 255, 0) 100%);
}

html.dark-mode .px-card-header,
body.dark-mode .px-card-header {
  background: linear-gradient(135deg, rgba(105, 108, 255, 0.05) 0%, rgba(43, 44, 64, 0) 100%);
}

.px-card-body {
  padding: var(--px-spacing-lg);
}

.px-card-title {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--px-text-heading);
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--px-spacing-sm);
}

.px-card-title i {
  color: var(--px-primary);
  font-size: 1.5rem;
}

/* Botones */
.px-btn {
  padding: 0.75rem 1.5rem;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--px-border-radius-sm);
  border: none;
  transition: var(--px-transition);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--px-spacing-xs);
  position: relative;
  overflow: hidden;
}

.px-btn-primary {
  background: linear-gradient(135deg, var(--px-primary) 0%, var(--px-primary-dark) 100%);
  color: #ffffff;
  box-shadow: var(--px-shadow-primary);
}

.px-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(105, 108, 255, 0.4);
  background: linear-gradient(135deg, var(--px-primary-dark) 0%, var(--px-primary-darker) 100%);
  color: #ffffff;
}

.px-btn-secondary {
  background: var(--px-bg-tertiary);
  color: var(--px-text-primary);
  border: 1px solid var(--px-border-color);
}

.px-btn-secondary:hover {
  background: var(--px-bg-hover);
  border-color: var(--px-primary);
  color: var(--px-primary);
  transform: translateY(-2px);
}

.px-btn-success {
  background: linear-gradient(135deg, var(--px-success) 0%, #5fc82a 100%);
  color: #ffffff;
}

.px-btn-success:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(113, 221, 55, 0.3);
}

.px-btn-danger {
  background: linear-gradient(135deg, var(--px-danger) 0%, #e63615 100%);
  color: #ffffff;
}

.px-btn-danger:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 62, 29, 0.3);
}

.px-btn-outline {
  background: transparent;
  border: 2px solid var(--px-primary);
  color: var(--px-primary);
}

.px-btn-outline:hover {
  background: var(--px-primary);
  color: #ffffff;
  transform: translateY(-2px);
}

.px-btn-icon {
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: var(--px-border-radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Formularios */
.px-form-group {
  position: relative;
  margin-bottom: var(--px-spacing-lg);
}

.px-form-label {
  font-weight: 500;
  color: var(--px-text-primary);
  margin-bottom: var(--px-spacing-xs);
  display: flex;
  align-items: center;
  gap: var(--px-spacing-xs);
  background: transparent !important;
  text-shadow: none !important;
  -webkit-text-stroke: 0 !important;
}

.px-form-label i {
  color: var(--px-primary);
  font-size: 1.1rem;
}

.px-form-control,
.px-form-select {
  width: 100%;
  border: 2px solid var(--px-border-color-light);
  border-radius: var(--px-border-radius-sm);
  padding: 0.75rem 1rem;
  font-size: 0.9375rem;
  transition: var(--px-transition);
  background: var(--px-bg-primary);
  color: var(--px-text-primary);
}

.px-form-control:focus,
.px-form-select:focus {
  border-color: var(--px-primary);
  box-shadow: 0 0 0 4px rgba(105, 108, 255, 0.1);
  outline: none;
  background: var(--px-bg-primary);
}

.px-form-control::placeholder {
  color: var(--px-text-secondary);
}

.px-input-group-icon {
  position: relative;
}

.px-input-group-icon i {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--px-text-secondary);
  z-index: 10;
  transition: var(--px-transition-fast);
}

.px-input-group-icon .px-form-control {
  padding-left: 2.75rem;
}

.px-input-group-icon .px-form-control:focus ~ i {
  color: var(--px-primary);
  transform: translateY(-50%) scale(1.1);
}

/* Secciones de Formulario */
.px-form-section {
  margin-bottom: var(--px-spacing-xxl);
}

.px-form-section-title {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--px-text-heading);
  margin-bottom: var(--px-spacing-lg);
  padding-bottom: var(--px-spacing-sm);
  border-bottom: 2px solid var(--px-border-color);
  display: flex;
  align-items: center;
  gap: var(--px-spacing-sm);
  position: relative;
}

.px-form-section-title::before {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, var(--px-primary) 0%, transparent 100%);
  border-radius: 2px;
}

.px-form-section-title i {
  font-size: 1.5rem;
  color: var(--px-primary);
}

/* Tablas */
.px-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border-radius: var(--px-border-radius-sm);
  overflow: hidden;
  background: var(--px-bg-primary);
  box-shadow: var(--px-shadow-sm);
}

.px-table thead {
  background: linear-gradient(135deg, var(--px-primary) 0%, var(--px-primary-dark) 100%);
  color: #ffffff;
}

.px-table thead th {
  padding: 1rem;
  font-weight: 600;
  color: #ffffff !important;
  border: none;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.5px;
}

.px-table tbody td {
  padding: 0.875rem 1rem;
  vertical-align: middle;
  color: var(--px-text-primary) !important;
  border-bottom: 1px solid var(--px-border-color);
}

.px-table tbody tr {
  transition: var(--px-transition-fast);
}

.px-table tbody tr:hover {
  background-color: var(--px-bg-hover);
}

.px-table tbody tr:last-child td {
  border-bottom: none;
}

/* Badges */
.px-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.35rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  border-radius: var(--px-border-radius-sm);
  line-height: 1;
}

.px-badge-primary {
  background: linear-gradient(135deg, var(--px-primary) 0%, var(--px-primary-dark) 100%);
  color: #ffffff;
}

.px-badge-success {
  background: linear-gradient(135deg, var(--px-success) 0%, #5fc82a 100%);
  color: #ffffff;
}

.px-badge-warning {
  background: linear-gradient(135deg, var(--px-warning) 0%, #ff9900 100%);
  color: #ffffff;
}

.px-badge-danger {
  background: linear-gradient(135deg, var(--px-danger) 0%, #e63615 100%);
  color: #ffffff;
}

.px-badge-info {
  background: linear-gradient(135deg, var(--px-info) 0%, #02a8c4 100%);
  color: #ffffff;
}

/* Alerts */
.px-alert {
  padding: var(--px-spacing-lg);
  border-radius: var(--px-border-radius-sm);
  border-left: 4px solid;
  margin-bottom: var(--px-spacing-lg);
  display: flex;
  align-items: flex-start;
  gap: var(--px-spacing-sm);
}

.px-alert-primary {
  background: var(--px-primary-lighter);
  border-left-color: var(--px-primary);
  color: var(--px-text-primary);
}

.px-alert-success {
  background: rgba(113, 221, 55, 0.1);
  border-left-color: var(--px-success);
  color: var(--px-text-primary);
}

.px-alert-warning {
  background: rgba(255, 171, 0, 0.1);
  border-left-color: var(--px-warning);
  color: var(--px-text-primary);
}

.px-alert-danger {
  background: rgba(255, 62, 29, 0.1);
  border-left-color: var(--px-danger);
  color: var(--px-text-primary);
}

/* Contenedores */
.px-container {
  background: var(--px-bg-primary);
  border-radius: var(--px-border-radius);
  box-shadow: var(--px-shadow-md);
  padding: var(--px-spacing-xl);
  margin-bottom: var(--px-spacing-xl);
}

.px-container-header {
  margin-bottom: var(--px-spacing-lg);
  padding-bottom: var(--px-spacing-md);
  border-bottom: 1px solid var(--px-border-color);
}

.px-container-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--px-text-heading);
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--px-spacing-sm);
}

.px-container-title i {
  color: var(--px-primary);
  font-size: 1.75rem;
}

/* Utilidades */
.px-text-gradient {
  background: linear-gradient(135deg, var(--px-primary) 0%, var(--px-primary-dark) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
}

.px-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--px-border-color) 50%, transparent 100%);
  margin: var(--px-spacing-xl) 0;
}

.px-loading {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 3px solid rgba(105, 108, 255, 0.3);
  border-radius: 50%;
  border-top-color: var(--px-primary);
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ============================================
   MEJORAS A COMPONENTES EXISTENTES
   ============================================ */

/* Mejorar cards de Bootstrap */
.card {
  border-radius: var(--px-border-radius);
  border: 1px solid var(--px-border-color);
  box-shadow: var(--px-shadow-md);
  transition: var(--px-transition);
  background: var(--px-bg-primary);
  overflow: hidden;
}

.card:hover {
  box-shadow: var(--px-shadow-lg);
}

.card-header {
  background: linear-gradient(135deg, rgba(105, 108, 255, 0.02) 0%, rgba(255, 255, 255, 0) 100%);
  border-bottom: 1px solid var(--px-border-color);
  padding: var(--px-spacing-lg);
}

html.dark-mode .card-header,
body.dark-mode .card-header {
  background: linear-gradient(135deg, rgba(105, 108, 255, 0.05) 0%, rgba(43, 44, 64, 0) 100%);
}

.card-body {
  padding: var(--px-spacing-lg);
}

/* Mejorar botones de Bootstrap */
.btn {
  border-radius: var(--px-border-radius-sm);
  font-weight: 600;
  padding: 0.75rem 1.5rem;
  transition: var(--px-transition);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--px-spacing-xs);
}

.btn-primary {
  background: linear-gradient(135deg, var(--px-primary) 0%, var(--px-primary-dark) 100%);
  border: none;
  box-shadow: var(--px-shadow-primary);
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(105, 108, 255, 0.4);
  background: linear-gradient(135deg, var(--px-primary-dark) 0%, var(--px-primary-darker) 100%);
}

.btn-secondary {
  background: var(--px-bg-tertiary);
  border-color: var(--px-border-color);
  color: var(--px-text-primary);
}

.btn-secondary:hover {
  background: var(--px-bg-hover);
  border-color: var(--px-primary);
  color: var(--px-primary);
  transform: translateY(-2px);
}

/* Mejorar formularios de Bootstrap */
.form-control,
.form-select {
  border: 2px solid var(--px-border-color-light);
  border-radius: var(--px-border-radius-sm);
  padding: 0.75rem 1rem;
  transition: var(--px-transition);
  background: var(--px-bg-primary);
  color: var(--px-text-primary);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--px-primary);
  box-shadow: 0 0 0 4px rgba(105, 108, 255, 0.1);
  background: var(--px-bg-primary);
  color: var(--px-text-primary);
}

.form-label {
  font-weight: 500;
  color: var(--px-text-primary);
  margin-bottom: var(--px-spacing-xs);
  background: transparent !important;
  text-shadow: none !important;
  -webkit-text-stroke: 0 !important;
}

/* Mejorar DataTables */
.dataTables_wrapper {
  margin-top: var(--px-spacing-lg);
}

.dataTables_wrapper .dataTables_filter input {
  border: 2px solid var(--px-border-color-light);
  border-radius: var(--px-border-radius-sm);
  padding: 0.5rem 1rem;
  transition: var(--px-transition);
}

.dataTables_wrapper .dataTables_filter input:focus {
  border-color: var(--px-primary);
  box-shadow: 0 0 0 4px rgba(105, 108, 255, 0.1);
}

.dataTables_wrapper .dataTables_length select {
  border: 2px solid var(--px-border-color-light);
  border-radius: var(--px-border-radius-sm);
  padding: 0.5rem 1rem;
}

table.dataTable {
  border-radius: var(--px-border-radius-sm);
  overflow: hidden;
}

table.dataTable thead th {
  background: linear-gradient(135deg, var(--px-primary) 0%, var(--px-primary-dark) 100%);
  color: #ffffff;
  border: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.5px;
}

table.dataTable tbody tr {
  transition: var(--px-transition-fast);
}

table.dataTable tbody tr:hover {
  background-color: var(--px-bg-hover);
}

/* Estilos para botones de exportación de DataTables */
.dt-buttons {
  margin-bottom: var(--px-spacing-md);
  display: flex;
  gap: var(--px-spacing-xs);
  flex-wrap: wrap;
}

.dt-buttons .btn {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  border-radius: var(--px-border-radius-sm);
  transition: var(--px-transition);
  border: 1px solid var(--px-border-color);
}

.dt-buttons .btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--px-shadow-sm);
}

/* Estilos para dropdown de acciones en tablas */
table.dataTable .dropdown {
  position: relative;
}

table.dataTable .dropdown-toggle {
  background: transparent;
  border: none;
  padding: 0.25rem 0.5rem;
  color: var(--px-text-secondary);
  transition: var(--px-transition-fast);
}

table.dataTable .dropdown-toggle:hover {
  color: var(--px-primary);
  background-color: var(--px-bg-hover);
  border-radius: var(--px-border-radius-sm);
}

table.dataTable .dropdown-menu {
  border: 1px solid var(--px-border-color);
  border-radius: var(--px-border-radius-sm);
  box-shadow: var(--px-shadow-md);
  padding: 0.5rem 0;
  min-width: 150px;
  margin-top: 0.25rem;
}

table.dataTable .dropdown-item {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  color: var(--px-text-primary);
  transition: var(--px-transition-fast);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

table.dataTable .dropdown-item:hover {
  background-color: var(--px-bg-hover);
  color: var(--px-primary);
}

table.dataTable .dropdown-item i {
  font-size: 1rem;
  width: 1.25rem;
  text-align: center;
}

/* ============================================
   MODO OSCURO ESPECÍFICO
   ============================================ */

html.dark-mode .card,
body.dark-mode .card {
  background-color: var(--px-bg-primary) !important;
  border-color: var(--px-border-color) !important;
  color: var(--px-text-primary) !important;
}

html.dark-mode .form-control,
html.dark-mode .form-select,
body.dark-mode .form-control,
body.dark-mode .form-select {
  background-color: var(--px-bg-primary) !important;
  border-color: var(--px-border-color) !important;
  color: var(--px-text-primary) !important;
}

html.dark-mode .form-control:focus,
html.dark-mode .form-select:focus,
body.dark-mode .form-control:focus,
body.dark-mode .form-select:focus {
  background-color: var(--px-bg-primary) !important;
  border-color: var(--px-primary) !important;
  color: var(--px-text-primary) !important;
}

html.dark-mode .form-control::placeholder,
html.dark-mode .form-select::placeholder,
body.dark-mode .form-control::placeholder,
body.dark-mode .form-select::placeholder {
  color: var(--px-text-muted) !important;
}

html.dark-mode .form-label,
body.dark-mode .form-label {
  color: var(--px-text-primary) !important;
  background: transparent !important;
}

html.dark-mode .btn-primary,
body.dark-mode .btn-primary {
  background: linear-gradient(135deg, var(--px-primary) 0%, var(--px-primary-dark) 100%) !important;
  border-color: var(--px-primary) !important;
  color: #ffffff !important;
}

html.dark-mode .btn-primary:hover,
body.dark-mode .btn-primary:hover {
  background: linear-gradient(135deg, var(--px-primary-dark) 0%, var(--px-primary-darker) 100%) !important;
}

html.dark-mode table.dataTable thead th,
body.dark-mode table.dataTable thead th {
  background: linear-gradient(135deg, var(--px-primary) 0%, var(--px-primary-dark) 100%) !important;
  color: #ffffff !important;
}

/* Modo oscuro para botones de exportación */
html.dark-mode .dt-buttons .btn,
body.dark-mode .dt-buttons .btn {
  background-color: var(--px-bg-primary) !important;
  border-color: var(--px-border-color) !important;
  color: var(--px-text-primary) !important;
}

html.dark-mode .dt-buttons .btn:hover,
body.dark-mode .dt-buttons .btn:hover {
  background-color: var(--px-bg-hover) !important;
  border-color: var(--px-primary) !important;
  color: var(--px-primary) !important;
}

/* Modo oscuro para dropdown de acciones */
html.dark-mode table.dataTable .dropdown-menu,
body.dark-mode table.dataTable .dropdown-menu {
  background-color: var(--px-bg-primary) !important;
  border-color: var(--px-border-color) !important;
}

html.dark-mode table.dataTable .dropdown-item,
body.dark-mode table.dataTable .dropdown-item {
  color: var(--px-text-primary) !important;
}

html.dark-mode table.dataTable .dropdown-item:hover,
body.dark-mode table.dataTable .dropdown-item:hover {
  background-color: var(--px-bg-hover) !important;
  color: var(--px-primary) !important;
}

/* ============================================
   CORRECCIONES DE LAYOUT
   ============================================ */

/* Eliminar espacios innecesarios entre sidebar, header y contenido */
.layout-wrapper {
  margin: 0;
  padding: 0;
  gap: 0;
}

.layout-container {
  margin: 0;
  padding: 0;
  gap: 0;
}

.layout-page {
  margin: 0;
  padding: 0 !important;
  gap: 0;
}

/* Estilos de content-wrapper consolidados más abajo */

/* Reducir padding del container principal */
.container-xxl.container-p-y {
  padding-top: 0.5rem !important;
  padding-bottom: 0.75rem !important;
}

/* Eliminar padding extra del primer elemento dentro del container */
.container-xxl.container-p-y > .row:first-child {
  margin-top: 0;
  padding-top: 0;
}

/* Asegurar que el contenido comience inmediatamente después del navbar */
.layout-content-navbar .content-wrapper .container-xxl {
  padding-top: 0.5rem !important;
}

/* Asegurar que no haya espacios entre navbar y contenido */
.layout-content-navbar .layout-page {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

.layout-content-navbar .content-wrapper {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Eliminar espacios en el navbar */
.layout-navbar {
  margin: 0;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

/* Asegurar que el sidebar no tenga espacios */
.layout-menu {
  margin: 0;
  padding: 0;
}

/* ============================================
   SCROLL INDEPENDIENTE DEL SIDEBAR
   ============================================ */

/* Hacer que el sidebar tenga altura fija y scroll independiente */
#layout-menu.layout-menu {
  height: 100vh;
  max-height: 100vh;
  display: flex !important;
  flex-direction: column;
  overflow: hidden;
}

/* Cuando el sidebar está fijo, asegurar que tenga la altura correcta */
@media (min-width: 1200px) {
  .layout-menu-fixed #layout-menu.layout-menu,
  .layout-menu-fixed-offcanvas #layout-menu.layout-menu {
    height: 100vh;
    max-height: 100vh;
    display: flex !important;
    flex-direction: column;
    overflow: hidden;
  }
}

/* El logo y buscador no deben hacer scroll */
#layout-menu #initio {
  flex-shrink: 0;
}

#layout-menu .px-3.pb-3 {
  flex-shrink: 0;
}

/* El menú interno debe hacer scroll independiente */
#layout-menu .menu-inner {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  min-height: 0;
  -webkit-overflow-scrolling: touch;
}

/* Estilo personalizado para el scrollbar del sidebar */
#layout-menu .menu-inner::-webkit-scrollbar {
  width: 6px;
}

#layout-menu .menu-inner::-webkit-scrollbar-track {
  background: transparent;
}

#layout-menu .menu-inner::-webkit-scrollbar-thumb {
  background: rgba(105, 108, 255, 0.3);
  border-radius: 10px;
  transition: background 0.3s ease;
}

#layout-menu .menu-inner::-webkit-scrollbar-thumb:hover {
  background: rgba(105, 108, 255, 0.5);
}

/* Para Firefox */
#layout-menu .menu-inner {
  scrollbar-width: thin;
  scrollbar-color: rgba(105, 108, 255, 0.3) transparent;
}

/* Asegurar que el contenido principal tenga su propio scroll */
.layout-page {
  height: 100vh;
  max-height: 100vh;
  overflow: visible;
  display: flex !important;
  flex-direction: column;
}

/* Consolidar estilos de content-wrapper para scroll independiente */
.content-wrapper {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  min-height: 0;
  -webkit-overflow-scrolling: touch;
  height: auto;
  display: flex !important;
  flex-direction: column !important;
  margin: 0;
  padding: 0;
  padding-bottom: 0;
  gap: 0;
  position: relative;
}

/* El contenedor principal debe poder crecer y hacer scroll */
.content-wrapper > .container-xxl {
  flex: 0 0 auto;
  width: 100%;
  max-height: none !important;
}

/* Asegurar que el contenido dentro del container-xxl pueda crecer y empujar el footer */
.content-wrapper > .container-xxl.container-p-y {
  flex: 0 0 auto;
  position: relative;
  padding-bottom: 1rem;
  max-height: none !important;
  min-height: 0;
}

/* Asegurar que el footer esté dentro del content-wrapper y sea visible */
.content-wrapper .content-footer {
  margin-top: auto !important;
  flex-shrink: 0 !important;
  order: 999 !important;
}

/* Asegurar que el footer esté al final del contenido */
.content-footer {
  flex-shrink: 0 !important;
  width: 100% !important;
  position: relative !important;
  background: var(--px-bg-primary, #ffffff) !important;
  margin-top: 2rem !important;
  margin-bottom: 0 !important;
  z-index: 100 !important;
  display: none !important; /* Ocultar inicialmente */
  visibility: hidden !important; /* Ocultar inicialmente */
  padding: 1rem 0 !important;
  min-height: 80px !important;
  opacity: 0 !important; /* Ocultar inicialmente */
  order: 999 !important;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* Mostrar el footer cuando la página esté completamente cargada */
.content-footer.footer-loaded {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Asegurar que el content-wrapper permita que el footer sea visible */
.content-wrapper {
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
}

/* Asegurar que content-backdrop no cubra el footer */
.content-backdrop {
  z-index: -1 !important;
  pointer-events: none !important;
}

/* Asegurar que el contenido principal pueda crecer cuando es necesario */
.content-wrapper > .container-xxl.flex-grow-1 {
  flex: 0 0 auto;
}

/* Estilo personalizado para el scrollbar del contenido */
.content-wrapper::-webkit-scrollbar {
  width: 8px;
}

.content-wrapper::-webkit-scrollbar-track {
  background: var(--px-bg-secondary);
}

.content-wrapper::-webkit-scrollbar-thumb {
  background: rgba(105, 108, 255, 0.3);
  border-radius: 10px;
  transition: background 0.3s ease;
}

.content-wrapper::-webkit-scrollbar-thumb:hover {
  background: rgba(105, 108, 255, 0.5);
}

/* Para Firefox */
.content-wrapper {
  scrollbar-width: thin;
  scrollbar-color: rgba(105, 108, 255, 0.3) var(--px-bg-secondary);
}

/* Ajustes para modo responsive */
@media (max-width: 1199.98px) {
  #layout-menu.layout-menu {
    height: 100vh;
    max-height: 100vh;
    display: flex !important;
    flex-direction: column;
    overflow: hidden;
  }
}

/* Asegurar que el navbar no interfiera con el scroll */
.layout-navbar {
  flex-shrink: 0;
}

/* Asegurar que el layout-container y layout-wrapper no interfieran */
.layout-container {
  height: 100vh;
  max-height: 100vh;
  overflow: hidden;
  display: flex;
}

.layout-wrapper {
  height: 100vh;
  max-height: 100vh;
  overflow: hidden;
  display: flex;
}

/* Asegurar que body y html no tengan overflow que interfiera */
/* Solo aplicar cuando no hay modales abiertos */
body:not(.modal-open) {
  overflow: hidden;
  height: 100vh;
  max-height: 100vh;
}

html:not(.modal-open) {
  height: 100%;
  overflow: hidden;
}

/* Permitir scroll cuando hay modales */
body.modal-open {
  overflow: auto;
}

html.modal-open {
  overflow: auto;
}

/* Eliminar espacios en body y html */
body.layout-menu-fixed {
  padding: 0;
  margin: 0;
}

/* Asegurar que no haya gap entre elementos del layout */
.layout-wrapper > *,
.layout-container > *,
.layout-page > * {
  margin-top: 0;
  margin-bottom: 0;
}

/* Reducir márgenes en el primer row del contenido */
.container-xxl.container-p-y > .row:first-child > .col-12:first-child > .d-flex:first-child {
  margin-bottom: 1rem !important;
}

/* Asegurar que el navbar esté pegado al contenido */
.layout-content-navbar .layout-navbar {
  margin-bottom: 0;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* Eliminar cualquier espacio entre navbar y content-wrapper */
.layout-content-navbar .layout-navbar + .content-wrapper {
  margin-top: 0;
  padding-top: 0;
}

/* Eliminar separaciones visuales entre sidebar y navbar */
#layout-menu {
  border-right: none !important;
  box-shadow: none !important;
}

.layout-menu {
  border-right: none !important;
  box-shadow: none !important;
}

.layout-navbar {
  border-bottom: none !important;
  box-shadow: none !important;
}

/* Asegurar mismo fondo para sidebar y navbar */
#layout-menu,
.layout-menu {
  background: linear-gradient(180deg, #ffffff 0%, #fafbfc 100%) !important;
}

#layout-navbar,
.layout-navbar {
  background: linear-gradient(180deg, #ffffff 0%, #fafbfc 100%) !important;
}

/* Modo oscuro */
html.dark-mode #layout-menu,
html.dark-mode .layout-menu,
body.dark-mode #layout-menu,
body.dark-mode .layout-menu {
  background: linear-gradient(180deg, #2b2c40 0%, #232333 100%) !important;
  border-right: none !important;
  box-shadow: none !important;
}

html.dark-mode #layout-navbar,
html.dark-mode .layout-navbar,
body.dark-mode #layout-navbar,
body.dark-mode .layout-navbar {
  background: linear-gradient(180deg, #2b2c40 0%, #232333 100%) !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 768px) {
  .px-container {
    padding: var(--px-spacing-lg);
  }
  
  .px-card-body {
    padding: var(--px-spacing-md);
  }
  
  .px-btn {
    padding: 0.625rem 1.25rem;
    font-size: 0.875rem;
  }
  
  .container-xxl.container-p-y {
    padding-top: 0.75rem !important;
    padding-bottom: 0.75rem !important;
  }
}

/* ============================================
   ANIMACIONES
   ============================================ */

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateX(-10px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.px-fade-in {
  animation: fadeIn 0.3s ease-out;
}

.px-slide-in {
  animation: slideIn 0.3s ease-out;
}

