/* ═══════════════════════════════════════════════════════════════════════════ */
/* PALETA DE COLORES MODERNA Y AMIGABLE */
/* ═══════════════════════════════════════════════════════════════════════════ */
:root {
  --azul-primario:      #3B82F6;        /* Azul moderno (confianza) */
  --azul-oscuro:        #1E40AF;        /* Azul oscuro (hover) */
  --naranja-acento:     #F97316;        /* Naranja (call-to-action) */
  --naranja-claro:      #FED7AA;        /* Naranja suave (background) */
  --verde-exito:        #10B981;        /* Verde éxito */
  --verde-claro:        #D1FAE5;        /* Verde claro (background) */
  --rojo-alerta:        #EF4444;        /* Rojo alerta */
  --gris-fondo:         #F9FAFB;        /* Gris muy claro (fondo general) */
  --gris-bordes:        #E5E7EB;        /* Gris para bordes */
  --gris-texto:         #374151;        /* Gris oscuro (texto) */
  --gris-muted:         #6B7280;        /* Gris (texto secundario) */
  --blanco:             #FFFFFF;
  --sombra-suave:       0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
  --sombra-media:       0 4px 6px rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.05);
  --sombra-fuerte:      0 20px 25px rgba(0, 0, 0, 0.1), 0 10px 10px rgba(0, 0, 0, 0.04);
  --radio-borde:        12px;
  --fuente-base:        -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --fuente-peso-normal: 400;
  --fuente-peso-medio:  500;
  --fuente-peso-bold:   600;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* ESTILOS GLOBALES */
/* ═══════════════════════════════════════════════════════════════════════════ */
* {
  box-sizing: border-box;
}

html, body {
  height: 100%;
}

body {
  background: linear-gradient(135deg, var(--gris-fondo) 0%, #F3F4F6 100%);
  font-family: var(--fuente-base);
  color: var(--gris-texto);
  font-size: 1rem;
  line-height: 1.6;
  font-weight: var(--fuente-peso-normal);
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* NAVBAR PERSONALIZADA */
/* ═══════════════════════════════════════════════════════════════════════════ */
.navbar-custom {
  background: linear-gradient(135deg, var(--azul-primario) 0%, var(--azul-oscuro) 100%);
  box-shadow: var(--sombra-media);
  border-bottom: 3px solid var(--naranja-acento);
  padding: 1rem 0;
}

.navbar-brand {
  font-size: 1.5rem;
  font-weight: var(--fuente-peso-bold);
  color: var(--blanco) !important;
  letter-spacing: 0.3px;
  transition: transform 0.2s ease;
}

.navbar-brand:hover {
  transform: translateY(-2px);
}

.navbar-brand i {
  font-size: 1.7rem;
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.8; }
}

.nav-link {
  color: rgba(255, 255, 255, 0.85) !important;
  font-weight: var(--fuente-peso-medio);
  transition: all 0.3s ease;
  border-radius: 6px;
  padding: 0.5rem 0.75rem !important;
  margin: 0 2px;
}

.nav-link:hover {
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--blanco) !important;
  transform: translateY(-2px);
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* CARDS Y CONTENEDORES */
/* ═══════════════════════════════════════════════════════════════════════════ */
.card {
  border: none;
  border-radius: var(--radio-borde);
  box-shadow: var(--sombra-suave);
  transition: all 0.3s ease;
  background: var(--blanco);
  overflow: hidden;
}

.card:hover {
  box-shadow: var(--sombra-media);
  transform: translateY(-4px);
}

.card-header {
  background: linear-gradient(135deg, var(--azul-primario) 0%, var(--azul-oscuro) 100%) !important;
  color: var(--blanco) !important;
  border: none;
  font-weight: var(--fuente-peso-medium);
  padding: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.card-header i {
  font-size: 1.1rem;
}

.card-body {
  padding: 1.5rem;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* LIST GROUPS */
/* ═══════════════════════════════════════════════════════════════════════════ */
.list-group-item {
  border: 1px solid var(--gris-bordes);
  border-radius: var(--radio-borde);
  margin-bottom: 0.75rem;
  transition: all 0.3s ease;
  padding: 1.25rem;
  background: var(--blanco);
}

.list-group-item:hover {
  box-shadow: var(--sombra-suave);
  border-color: var(--azul-primario);
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.02) 0%, rgba(249, 115, 22, 0.02) 100%);
}

.list-group-item.active {
  background: linear-gradient(135deg, var(--azul-primario) 0%, var(--azul-oscuro) 100%);
  border-color: var(--azul-oscuro);
  color: var(--blanco);
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* BOTONES MEJORADOS */
/* ═══════════════════════════════════════════════════════════════════════════ */
.btn {
  border-radius: 8px;
  border: none;
  font-weight: var(--fuente-peso-medium);
  padding: 0.65rem 1.25rem;
  font-size: 0.95rem;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  box-shadow: var(--sombra-suave);
}

.btn:active {
  transform: scale(0.98);
}

/* Botón Primario */
.btn-primary {
  background: linear-gradient(135deg, var(--azul-primario) 0%, var(--azul-oscuro) 100%);
  color: var(--blanco);
  border: none;
}

.btn-primary:hover {
  box-shadow: var(--sombra-fuerte);
  transform: translateY(-2px);
  color: var(--blanco);
}

/* Botón Naranja (Call-to-Action) */
.btn-warning {
  background: linear-gradient(135deg, var(--naranja-acento) 0%, #EA580C 100%);
  color: var(--blanco);
  border: none;
}

.btn-warning:hover {
  box-shadow: var(--sombra-fuerte);
  transform: translateY(-2px);
  color: var(--blanco);
}

/* Botón Éxito */
.btn-success {
  background: linear-gradient(135deg, var(--verde-exito) 0%, #059669 100%);
  color: var(--blanco);
  border: none;
}

.btn-success:hover {
  box-shadow: var(--sombra-fuerte);
  transform: translateY(-2px);
  color: var(--blanco);
}

/* Botón Outline */
.btn-outline-primary,
.btn-outline-secondary,
.btn-outline-success {
  border: 2px solid;
  background: var(--blanco);
  transition: all 0.3s ease;
}

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

.btn-outline-primary:hover {
  background: var(--azul-primario);
  color: var(--blanco);
  transform: translateY(-2px);
  box-shadow: var(--sombra-media);
}

.btn-outline-secondary {
  border-color: var(--gris-muted);
  color: var(--gris-muted);
}

.btn-outline-secondary:hover {
  background: var(--gris-muted);
  color: var(--blanco);
  transform: translateY(-2px);
  box-shadow: var(--sombra-media);
}

.btn-outline-success {
  border-color: var(--verde-exito);
  color: var(--verde-exito);
}

.btn-outline-success:hover {
  background: var(--verde-exito);
  color: var(--blanco);
  transform: translateY(-2px);
  box-shadow: var(--sombra-media);
}

/* Botón Pequeño */
.btn-sm {
  padding: 0.5rem 0.75rem;
  font-size: 0.85rem;
}

/* Botón Link (texto) */
.btn-link {
  color: var(--azul-primario);
  text-decoration: none;
  transition: all 0.2s ease;
}

.btn-link:hover {
  color: var(--azul-oscuro);
  text-decoration: underline;
}

.btn-link.text-danger:hover {
  color: var(--rojo-alerta) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* FORMULARIOS */
/* ═══════════════════════════════════════════════════════════════════════════ */
.form-label {
  font-weight: var(--fuente-peso-medium);
  color: var(--gris-texto);
  margin-bottom: 0.5rem;
}

.form-control,
.form-select {
  border-radius: 8px;
  border: 2px solid var(--gris-bordes);
  padding: 0.75rem 1rem;
  font-size: 0.95rem;
  transition: all 0.3s ease;
  background: var(--blanco);
  color: var(--gris-texto);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--azul-primario);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
  outline: none;
}

.form-control::placeholder {
  color: var(--gris-muted);
  opacity: 0.7;
}

/* Input Group */
.input-group {
  gap: 0.5rem;
}

.input-group-text {
  background: var(--gris-fondo);
  border: 2px solid var(--gris-bordes);
  border-radius: 8px;
  color: var(--gris-muted);
  font-weight: var(--fuente-peso-medium);
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* ALERTAS MEJORADAS */
/* ═══════════════════════════════════════════════════════════════════════════ */
.alert {
  border-radius: var(--radio-borde);
  border: none;
  padding: 1rem 1.25rem;
  font-weight: var(--fuente-peso-medium);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  animation: slideInDown 0.3s ease;
}

@keyframes slideInDown {
  from {
    transform: translateY(-20px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.alert-success {
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.1) 0%, rgba(209, 250, 229, 0.2) 100%);
  color: #047857;
  border-left: 4px solid var(--verde-exito);
}

.alert-warning {
  background: linear-gradient(135deg, rgba(249, 115, 22, 0.1) 0%, rgba(254, 215, 170, 0.2) 100%);
  color: #92400E;
  border-left: 4px solid var(--naranja-acento);
}

.alert-danger {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.1) 0%, rgba(254, 226, 226, 0.2) 100%);
  color: #7F1D1D;
  border-left: 4px solid var(--rojo-alerta);
}

.alert-info {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(219, 234, 254, 0.2) 100%);
  color: #1E40AF;
  border-left: 4px solid var(--azul-primario);
}

.alert i {
  font-size: 1.25rem;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* BADGES */
/* ═══════════════════════════════════════════════════════════════════════════ */
.badge {
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  font-weight: var(--fuente-peso-medium);
  font-size: 0.8rem;
}

.badge.bg-primary {
  background: linear-gradient(135deg, var(--azul-primario) 0%, var(--azul-oscuro) 100%) !important;
}

.badge.bg-success {
  background: linear-gradient(135deg, var(--verde-exito) 0%, #059669 100%) !important;
}

.badge.bg-warning {
  background: linear-gradient(135deg, var(--naranja-acento) 0%, #EA580C 100%) !important;
  color: var(--blanco);
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* TÍTULOS Y ENCABEZADOS */
/* ═══════════════════════════════════════════════════════════════════════════ */
h1, h2, h3, h4, h5, h6 {
  font-weight: var(--fuente-peso-bold);
  color: var(--gris-texto);
  margin-bottom: 1rem;
}

h1 {
  font-size: 2.5rem;
  letter-spacing: -1px;
}

h2 {
  font-size: 2rem;
  letter-spacing: -0.5px;
  border-bottom: 3px solid var(--azul-primario);
  display: inline-block;
  padding-bottom: 0.5rem;
}

h3 {
  font-size: 1.5rem;
}

h4 {
  font-size: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* TABLAS */
/* ═══════════════════════════════════════════════════════════════════════════ */
.table {
  background: var(--blanco);
  border-radius: var(--radio-borde);
  overflow: hidden;
  box-shadow: var(--sombra-suave);
}

.table thead {
  background: linear-gradient(135deg, var(--azul-primario) 0%, var(--azul-oscuro) 100%);
  color: var(--blanco);
  font-weight: var(--fuente-peso-medium);
}

.table thead th {
  border: none;
  padding: 1rem;
  vertical-align: middle;
}

.table tbody tr {
  transition: all 0.2s ease;
  border-bottom: 1px solid var(--gris-bordes);
}

.table tbody tr:hover {
  background-color: rgba(59, 130, 246, 0.02);
}

.table tbody td {
  padding: 1rem;
  vertical-align: middle;
  color: var(--gris-texto);
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* CALENDARIO FULLCALENDAR */
/* ═══════════════════════════════════════════════════════════════════════════ */
#calendar {
  background: var(--blanco);
  border-radius: var(--radio-borde);
  padding: 1.5rem;
  box-shadow: var(--sombra-media);
  font-family: var(--fuente-base);
}

.fc .fc-button-primary {
  background-color: var(--azul-primario) !important;
  border-color: var(--azul-primario) !important;
}

.fc .fc-button-primary:hover {
  background-color: var(--azul-oscuro) !important;
}

.fc .fc-button-primary.fc-button-active {
  background-color: var(--naranja-acento) !important;
  border-color: var(--naranja-acento) !important;
}

.fc .fc-daygrid-day.fc-day-today {
  background-color: rgba(59, 130, 246, 0.05) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* FOOTER */
/* ═══════════════════════════════════════════════════════════════════════════ */
footer {
  background: var(--blanco);
  border-top: 2px solid var(--gris-bordes);
  margin-top: auto;
  color: var(--gris-muted);
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* UTILITIES Y RESPONSIVE */
/* ═══════════════════════════════════════════════════════════════════════════ */
.text-muted {
  color: var(--gris-muted) !important;
}

.text-success {
  color: var(--verde-exito) !important;
}

.text-danger {
  color: var(--rojo-alerta) !important;
}

.text-primary {
  color: var(--azul-primario) !important;
}

.bg-light {
  background-color: var(--gris-fondo) !important;
}

.border-top {
  border-top: 1px solid var(--gris-bordes) !important;
}

.shadow-sm {
  box-shadow: var(--sombra-suave) !important;
}

.shadow {
  box-shadow: var(--sombra-media) !important;
}

/* Espaciado mejorado */
.gap-2 {
  gap: 1rem !important;
}

.gap-3 {
  gap: 1.5rem !important;
}

/* Mobile-first: en pantallas pequeñas, los botones ocupan todo el ancho */
@media (max-width: 576px) {
  .btn {
    width: 100%;
    justify-content: center;
    padding: 0.75rem 1rem;
  }

  h1 {
    font-size: 1.75rem;
  }

  h2 {
    font-size: 1.5rem;
  }

  .card {
    margin-bottom: 1rem;
  }

  .navbar {
    padding: 0.75rem 0;
  }

  .container-fluid {
    padding: 1rem 0.75rem;
  }
}

/* Tablet y superior */
@media (min-width: 768px) {
  .btn {
    width: auto;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* ANIMACIONES Y TRANSICIONES */
/* ═══════════════════════════════════════════════════════════════════════════ */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.content-area {
  animation: fadeIn 0.5s ease;
}

/* Smooth scrolling */
html {
  scroll-behavior: smooth;
}

/* Focus visible para accesibilidad */
:focus-visible {
  outline: 3px solid var(--azul-primario);
  outline-offset: 2px;
}

button:focus-visible,
a:focus-visible {
  border-radius: 4px;
}
