/* ========================================
   BOTONES CORPORATIVOS
   ======================================== */
/* Botón filtros */
.btn-filters {
  width: 70px !important;
}

/* Botón base - Aplica a todos los botones Bootstrap */
.btn {
  width: var(--button-width);
  height: var(--button-height);
  font-size: var(--font-size-small);
  border-radius: var(--border-radius-button) !important;
  font-weight: bold;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--spacing-md);
  border-width: 1px;
  border-style: solid;
}

/* Botón primario - Púrpura corporativo */
.btn-primary {
  background-color: var(--corporate-purple) !important;
  border-color: var(--corporate-purple) !important;
  color: white !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
  background-color: #6a3a7a !important;
  border-color: #6a3a7a !important;
  color: white !important;
  box-shadow: 0 2px 4px rgba(127, 71, 144, 0.3) !important;
}

.btn-primary:disabled,
.btn-primary.disabled {
  background-color: rgba(127, 71, 144, 0.5) !important;
  border-color: rgba(127, 71, 144, 0.5) !important;
  opacity: 0.65;
}

/* Botón secundario - Azul corporativo con fondo transparente */
.btn-secondary {
  background-color: transparent !important;
  border-color: var(--corporate-blue) !important;
  color: var(--corporate-blue) !important;
}

.btn-secondary:hover,
.btn-secondary:focus,
.btn-secondary:active {
  background-color: var(--corporate-blue) !important;
  border-color: var(--corporate-blue) !important;
  color: white !important;
  box-shadow: 0 2px 4px rgba(57, 119, 180, 0.3) !important;
}

.btn-secondary:disabled,
.btn-secondary.disabled {
  border-color: rgba(57, 119, 180, 0.5) !important;
  color: rgba(57, 119, 180, 0.5) !important;
  opacity: 0.65;
}

/* Botón de éxito - Verde con toque corporativo */
.btn-success {
  background-color: #28a745 !important;
  border-color: #28a745 !important;
  color: white !important;
}

.btn-success:hover,
.btn-success:focus,
.btn-success:active {
  background-color: #218838 !important;
  border-color: #1e7e34 !important;
  color: white !important;
}

/* Botón de peligro - Rojo */
.btn-danger {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: white !important;
}

.btn-danger:hover,
.btn-danger:focus,
.btn-danger:active {
  background-color: #c82333 !important;
  border-color: #bd2130 !important;
  color: white !important;
}

/* Botón de advertencia - Amarillo */
.btn-warning {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #1e1e1e !important;
}

.btn-warning:hover,
.btn-warning:focus,
.btn-warning:active {
  background-color: #e0a800 !important;
  border-color: #d39e00 !important;
  color: #1e1e1e !important;
}

/* Botón de información - Azul claro corporativo */
.btn-info {
  background-color: var(--corporate-light-blue) !important;
  border-color: var(--corporate-light-blue) !important;
  color: var(--corporate-black) !important;
}

.btn-info:hover,
.btn-info:focus,
.btn-info:active {
  background-color: #5a9dd8 !important;
  border-color: #5a9dd8 !important;
  color: white !important;
}

/* Botón claro - Gris claro */
.btn-light {
  background-color: #f8f9fa !important;
  border-color: rgba(30, 30, 30, 0.15) !important;
  color: var(--corporate-black) !important;
}

.btn-light:hover,
.btn-light:focus,
.btn-light:active {
  background-color: #e2e6ea !important;
  border-color: rgba(30, 30, 30, 0.25) !important;
  color: var(--corporate-black) !important;
}

/* Botón oscuro - Negro corporativo */
.btn-dark {
  background-color: var(--corporate-black) !important;
  border-color: var(--corporate-black) !important;
  color: white !important;
}

.btn-dark:hover,
.btn-dark:focus,
.btn-dark:active {
  background-color: #0a0a0a !important;
  border-color: #0a0a0a !important;
  color: white !important;
}

/* Botón outline - Variantes con borde */
.btn-outline-secondary {
  background-color: transparent !important;
  border-color: var(--corporate-purple) !important;
  color: var(--corporate-purple) !important;
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus,
.btn-outline-secondary:active {
  background-color: var(--corporate-purple) !important;
  border-color: var(--corporate-purple) !important;
  color: white !important;
}

.btn-outline-primary {
  background-color: transparent !important;
  border-color: var(--corporate-blue) !important;
  color: var(--corporate-blue) !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
  background-color: var(--corporate-blue) !important;
  border-color: var(--corporate-blue) !important;
  color: white !important;
}

/* Tamaños de botones */
.btn-sm {
  width: 80px;
  height: 24px;
  font-size: 11px;
  padding: 0 var(--spacing-sm);
}

.btn-lg {
  width: 160px;
  height: 40px;
  font-size: 14px;
  padding: 0 var(--spacing-lg);
}

/* Botón de ancho completo */
.btn-block {
  width: 100% !important;
}

/* Grupo de botones */
.btn-group .btn {
  border-radius: 0 !important;
}

.btn-group .btn:first-child {
  border-radius: var(--border-radius-button) 0 0 var(--border-radius-button) !important;
}

.btn-group .btn:last-child {
  border-radius: 0 var(--border-radius-button) var(--border-radius-button) 0 !important;
}

/* Arrow buttons with consistent border-radius on all corners */
/* Higher specificity selectors to override .btn-group rules */
.btn-group .btn.btn-arrow-rounded,
.btn-group .btn.btn-arrow-rounded:first-child,
.btn-group .btn.btn-arrow-rounded:last-child {
  border-radius: var(--border-radius-button) !important;
  margin-left: 0 !important;
  border-width: 1px !important;
  border-style: solid !important;
}

/* Ensure outline-primary arrow buttons have complete blue border */
.btn-group .btn.btn-arrow-rounded.btn-outline-primary {
  border-color: var(--corporate-blue) !important;
}

/* Botón con icono */
.btn i,
.btn svg {
  margin-right: 5px;
}

.btn i:only-child,
.btn svg:only-child {
  margin-right: 0;
}

/* Estados de focus para accesibilidad */
.btn:focus,
.btn:focus-visible {
  outline: 2px solid var(--corporate-purple);
  outline-offset: 2px;
}

/* Clases personalizadas adicionales (compatibilidad con código existente) */
.btn-corporate {
  width: var(--button-width);
  height: var(--button-height);
  font-size: var(--font-size-small);
  border-radius: var(--border-radius-button);
  font-weight: bold;
  transition: all 0.3s ease;
}

.btn-corporate-primary {
  background-color: var(--corporate-purple);
  border-color: var(--corporate-purple);
  color: white;
}

.btn-corporate-primary:hover {
  background-color: #6a3a7a;
  border-color: #6a3a7a;
  color: white;
}

.btn-corporate-secondary {
  background-color: transparent;
  border-color: var(--corporate-blue);
  color: var(--corporate-blue);
}

.btn-corporate-secondary:hover {
  background-color: var(--corporate-blue);
  color: white;
}

/* === CARDS === */
.card-corporate {
  background-color: white;
  border-radius: var(--border-radius-card);
  padding: var(--spacing-md);
  box-shadow: var(--shadow-card);
  border: var(--border-card);
}

.card-corporate-title {
  font-size: var(--font-size-title-small);
  color: var(--corporate-purple);
  font-weight: 600;
  margin-bottom: var(--spacing-sm);
}

/* === TÍTULOS === */
.title-corporate-large {
  font-size: var(--font-size-title-large);
  font-weight: 600;
  color: var(--corporate-blue);
}

.title-corporate-medium {
  font-size: var(--font-size-title-medium);
  font-weight: bold;
  color: var(--corporate-purple);
}

/* === ENCABEZADOS HTML (h1, h2, h3) === */
/* Aplicar color morado corporativo a todos los encabezados */
h1 {
  color: var(--corporate-purple);
  font-weight: 600;
}

h2 {
  color: var(--corporate-purple);
  font-weight: 600;
}

h3 {
  color: var(--corporate-purple);
  font-weight: 600;
}

/* === LABELS === */
.label-corporate {
  font-size: var(--font-size-body);
  color: var(--corporate-blue);
  font-weight: 600;
}

/* === ENLACES === */
.link-corporate {
  color: var(--corporate-purple);
  text-decoration: none;
  transition: color 0.3s ease;
}

.link-corporate:hover {
  color: #6a3a7a;
  text-decoration: underline;
}

/* === INDICADORES === */
.indicator-corporate {
  background: var(--corporate-light-blue);
  height: 20px;
  width: 20px;
  color: var(--corporate-black);
  font-size: var(--font-size-small);
  font-weight: bold;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}


.btn-bigger {
  width: fit-content !important;
}

/* Botón de acción para tablas - solo ocupa el espacio del icono */
.btn-action {
  width: fit-content !important;
  min-width: auto !important;
}

/* --- ESTILOS GLOBALES DE ENLACES --- */
table a {
  color: var(--link-blue);
  text-decoration: none;
  transition: color 0.3s ease;
}

table a:hover {
  color: var(--link-blue);
  text-decoration: underline;
}

/* --- ESTILOS DE PAGINACIÓN UNIVERSAL (Look DataTables) --- */
.pagination {
  gap: var(--spacing-xs);
  display: flex;
  justify-content: flex-end;
  /* Alineación por defecto a la derecha */
}

.pagination .page-link {
  border-radius: var(--border-radius-button) !important;
  width: 130px;
  height: 30px;
  font-size: var(--font-size-small);
  font-weight: bold;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  background-color: transparent;
  border: 1px solid rgba(30, 30, 30, 0.15) !important;
  color: var(--link-blue);
}

/* Previous button  */
.pagination .page-item.previous .page-link {
  border: 1px solid rgba(30, 30, 30, 0.15) !important;
  color: var(--corporate-blue) !important;
}

.pagination .page-item.previous .page-link:hover:not(.disabled) {
  background-color: var(--corporate-blue) !important;
  border-color: var(--corporate-blue) !important;
  color: white !important;
}

/* Next button - Blue (matching DataTables) */
.pagination .page-item.next .page-link {
  border: 1px solid rgba(30, 30, 30, 0.15) !important;
  color: var(--corporate-blue) !important;
}

.pagination .page-item.next .page-link:hover:not(.disabled) {
  background-color: var(--corporate-blue) !important;
  border-color: var(--corporate-blue) !important;
  color: white !important;
}

.pagination .page-item.active .page-link {
  background-color: var(--corporate-blue) !important;
  border-color: var(--corporate-blue) !important;
  color: white !important;
}

.pagination .page-item.disabled .page-link {
  opacity: 0.5;
  cursor: not-allowed;
  border-color: rgba(30, 30, 30, 0.15) !important;
  color: #6c757d;
  background-color: transparent !important;
}

.pagination .page-link:hover:not(.disabled):not(.previous):not(.next) {
  background-color: var(--link-blue);
  border-color: var(--link-blue);
  color: white;
}
