/* =============================================
   Tema personalizado para PHPMaker 2024 (AdminLTE3)
   Colores: Verdes pastel (sutil, tonos suaves)
   Motivo: Abejas y panales (versión delicada)
   Incluye animaciones, degradados, sombras suaves y microinteracciones
   ============================================= */

:root {
  --gold: #C1E1C1;               /* Verde pastel suave (reemplaza al dorado) */
  --gold-light: #D8EAD2;          /* Verde pastel más claro */
  --gold-dark: #8FB389;           /* Verde pastel medio */
  --royal-blue: #4A6B4A;          /* Verde grisáceo oscuro (reemplaza al azul) */
  --royal-blue-light: #7A9E7A;     /* Verde pastel medio */
  --royal-blue-dark: #2D4A2D;      /* Verde muy oscuro pero suave */
  --white: #FFFFFF;
  --off-white: #F2F9F0;            /* Blanco con un toque de verde */
  --honeycomb-pattern: rgba(193, 225, 193, 0.1); /* Verde pastel con transparencia */
}

/* ---------------------------------------------
   Fondo general con partículas flotantes (hexágonos)
--------------------------------------------- */
body {
  background: linear-gradient(145deg, var(--off-white) 0%, #e0f0e0 100%);
  position: relative;
  overflow-x: hidden;
}

/* Partículas de panal flotantes */
body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  background-image: 
    url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="60" height="60" viewBox="0 0 100 100"><polygon points="50,0 93.3,25 93.3,75 50,100 6.7,75 6.7,25" fill="%234A6B4A" opacity="0.03"/></svg>'),
    url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="40" height="40" viewBox="0 0 100 100"><polygon points="50,0 93.3,25 93.3,75 50,100 6.7,75 6.7,25" fill="%23C1E1C1" opacity="0.02"/></svg>');
  background-repeat: repeat;
  animation: floatParticles 60s linear infinite;
  z-index: 0;
}

@keyframes floatParticles {
  0% { background-position: 0 0, 0 0; }
  100% { background-position: 200px 200px, -200px -200px; }
}

/* ---------------------------------------------
   Encabezado superior con efecto de panal y brillo
--------------------------------------------- */
.main-header {
  background: linear-gradient(145deg, var(--royal-blue), var(--royal-blue-dark));
  border-bottom: 4px solid var(--gold);
  box-shadow: 0 8px 20px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.2);
  position: relative;
  z-index: 10;
}

.main-header::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: repeating-linear-gradient(45deg, transparent, transparent 20px, rgba(193,225,193,0.05) 20px, rgba(193,225,193,0.05) 40px);
  pointer-events: none;
}

.main-header .navbar-nav > li > a {
  color: var(--white) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.2);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  position: relative;
  overflow: hidden;
}

.main-header .navbar-nav > li > a::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(193,225,193,0.3), transparent);
  transition: left 0.5s;
}

.main-header .navbar-nav > li > a:hover {
  background-color: var(--gold) !important;
  color: var(--royal-blue-dark) !important;
  transform: scale(1.03) translateY(-1px);
  box-shadow: 0 5px 10px rgba(0,0,0,0.15);
}

.main-header .navbar-nav > li > a:hover::before {
  left: 100%;
}

/* Logo con animación de abeja */
.brand-link {
  background: var(--royal-blue-dark) !important;
  color: var(--gold) !important;
  font-weight: bold;
  border-bottom: 3px solid var(--gold);
  text-shadow: 0 0 8px var(--gold-light);
  position: relative;
  overflow: hidden;
}

.brand-link::after {
  content: "\f0fa";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  margin-left: 10px;
  color: var(--gold);
  font-size: 1.4rem;
  animation: buzz 1s infinite, wiggle 3s infinite;
  display: inline-block;
}

@keyframes wiggle {
  0%, 100% { transform: rotate(0deg); }
  25% { transform: rotate(5deg); }
  75% { transform: rotate(-5deg); }
}

/* ---------------------------------------------
   Barra lateral con efecto 3D y animaciones
--------------------------------------------- */
.main-sidebar {
  background: linear-gradient(135deg, var(--royal-blue), var(--royal-blue-dark));
  border-right: 4px solid var(--gold);
  box-shadow: 8px 0 20px rgba(0,0,0,0.2);
  transition: width 0.3s;
}

.nav-sidebar > li > a {
  color: var(--white) !important;
  border-left: 4px solid transparent;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  z-index: 1;
}

.nav-sidebar > li > a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.3s;
  z-index: -1;
}

.nav-sidebar > li > a:hover {
  background: var(--gold) !important;
  color: var(--royal-blue-dark) !important;
  border-left-color: var(--white);
  transform: translateX(6px) scale(1.01);
  box-shadow: 0 5px 12px rgba(193,225,193,0.3);
}

.nav-sidebar > li > a:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* Elemento activo con brillo */
.nav-sidebar > li.active > a {
  background: linear-gradient(90deg, var(--gold), var(--gold-light)) !important;
  color: var(--royal-blue-dark) !important;
  border-left-color: var(--white);
  font-weight: bold;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.1), 0 0 15px var(--gold-light);
  text-shadow: 0 1px 0 rgba(255,255,255,0.5);
}

.nav-sidebar > li.active > a::before {
  content: "\f0fa";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  margin-right: 10px;
  color: var(--royal-blue-dark);
  animation: buzz 0.8s infinite;
}

/* Submenús con efecto */
.nav-treeview > li > a {
  background: rgba(0, 0, 0, 0.2);
  color: var(--off-white) !important;
  border-left: 4px solid transparent;
  transition: all 0.3s;
}

.nav-treeview > li > a:hover {
  background: var(--gold-dark) !important;
  color: var(--white) !important;
  border-left-color: var(--gold-light);
  transform: translateX(4px);
}

/* ---------------------------------------------
   Tarjetas con efecto 3D y bordes de panal
--------------------------------------------- */
.card {
  border: none;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 15px 25px -8px rgba(0,0,0,0.15);
  transition: transform 0.3s cubic-bezier(0.2, 0.9, 0.3, 1), box-shadow 0.3s;
  background: var(--white);
  position: relative;
  margin-bottom: 25px;
}

.card:hover {
  transform: translateY(-5px) rotateX(1deg);
  box-shadow: 0 20px 30px -10px rgba(0,0,0,0.2), 0 0 0 1px var(--gold);
}

.card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, var(--gold), var(--royal-blue-light), var(--gold));
  background-size: 200% 100%;
  animation: shine 4s infinite linear;
}

@keyframes shine {
  0% { background-position: 0% 0; }
  100% { background-position: 200% 0; }
}

.card-header {
  background: linear-gradient(145deg, var(--royal-blue), var(--royal-blue-dark));
  color: var(--gold);
  font-weight: bold;
  border-bottom: 2px solid var(--gold);
  position: relative;
  padding: 1rem 1.5rem;
  font-size: 1.2rem;
  letter-spacing: 0.5px;
}

.card-header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" opacity="0.08"><polygon points="50,0 93.3,25 93.3,75 50,100 6.7,75 6.7,25" fill="%23C1E1C1"/></svg>');
  background-size: 35px 35px;
  pointer-events: none;
}

.card-body {
  background: linear-gradient(145deg, #ffffff, #f9f9f9);
  padding: 1.8rem;
}

/* ---------------------------------------------
   Botones con efecto 3D y partículas
--------------------------------------------- */
.btn {
  border: none;
  border-radius: 30px;
  padding: 10px 25px;
  font-weight: 600;
  transition: all 0.3s cubic-bezier(0.2, 0.9, 0.3, 1);
  background-size: 200% auto;
  box-shadow: 0 5px 12px rgba(0,0,0,0.1);
  position: relative;
  overflow: hidden;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.btn::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 5px;
  height: 5px;
  background: rgba(255,255,255,0.8);
  opacity: 0;
  border-radius: 100%;
  transform: scale(1, 1) translate(-50%);
  transform-origin: 50% 50%;
}

.btn:focus:not(:active)::after {
  animation: ripple 1s ease-out;
}

@keyframes ripple {
  0% { transform: scale(0, 0); opacity: 0.5; }
  20% { transform: scale(20, 20); opacity: 0.2; }
  100% { opacity: 0; transform: scale(35, 35); }
}

.btn-primary {
  background: linear-gradient(145deg, var(--royal-blue), var(--royal-blue-dark));
  color: var(--white);
  box-shadow: 0 4px 0 var(--royal-blue-dark), 0 6px 12px rgba(0,0,0,0.15);
}

.btn-primary:hover {
  background: linear-gradient(145deg, var(--royal-blue-dark), var(--royal-blue));
  transform: translateY(-2px);
  box-shadow: 0 6px 0 var(--royal-blue-dark), 0 10px 16px rgba(0,0,0,0.15), 0 0 10px var(--gold-light);
}

.btn-primary:active {
  transform: translateY(2px);
  box-shadow: 0 2px 0 var(--royal-blue-dark), 0 6px 12px rgba(0,0,0,0.15);
}

.btn-success {
  background: linear-gradient(145deg, var(--gold), var(--gold-dark));
  color: var(--royal-blue-dark);
  box-shadow: 0 4px 0 var(--gold-dark), 0 6px 12px rgba(0,0,0,0.15);
}

.btn-success:hover {
  background: linear-gradient(145deg, var(--gold-dark), var(--gold));
  transform: translateY(-2px);
  box-shadow: 0 6px 0 var(--gold-dark), 0 10px 16px rgba(0,0,0,0.15), 0 0 10px var(--royal-blue-light);
}

.btn-success:active {
  transform: translateY(2px);
  box-shadow: 0 2px 0 var(--gold-dark), 0 6px 12px rgba(0,0,0,0.15);
}

/* ---------------------------------------------
   Tablas con diseño moderno y rayas de panal
--------------------------------------------- */
.table {
  background: var(--white);
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 10px 20px rgba(0,0,0,0.05);
  border-collapse: separate;
  border-spacing: 0;
}

.table thead th {
  background: var(--royal-blue-dark);
  color: var(--gold);
  font-weight: 600;
  border-bottom: 2px solid var(--gold);
  text-transform: uppercase;
  font-size: 0.9rem;
  letter-spacing: 0.5px;
  padding: 15px;
}

.table tbody tr {
  transition: all 0.2s;
}

.table tbody tr:hover {
  background: rgba(193, 225, 193, 0.2);
  transform: scale(1.005);
  box-shadow: 0 3px 8px rgba(0,0,0,0.05);
}

.table td, .table th {
  padding: 15px;
  border: 1px solid #eaeaea;
}

/* Efecto de panal en filas pares */
.table tbody tr:nth-child(even) {
  background: rgba(74, 107, 74, 0.02);
  background-image: radial-gradient(circle at 30% 50%, rgba(193,225,193,0.05) 1px, transparent 1px);
  background-size: 20px 20px;
}

/* ---------------------------------------------
   Formularios con efectos suaves
--------------------------------------------- */
.form-control {
  border: 1px solid #d0d0d0;
  border-radius: 10px;
  transition: all 0.3s;
  background: var(--white);
}

.form-control:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 0.2rem rgba(193, 225, 193, 0.4), inset 0 1px 2px rgba(0,0,0,0.05);
  transform: translateY(-1px);
}

/* ---------------------------------------------
   Paginación con estilo 3D suave
--------------------------------------------- */
.pagination {
  margin-top: 20px;
}

.pagination > li > a {
  color: var(--royal-blue);
  border: 1px solid var(--gold-light);
  margin: 0 3px;
  border-radius: 8px !important;
  transition: all 0.2s;
  font-weight: 500;
  padding: 8px 15px;
  background: var(--white);
}

.pagination > li.active > a {
  background: var(--royal-blue-dark);
  border-color: var(--gold);
  color: var(--gold);
  box-shadow: 0 3px 0 var(--gold-dark);
  transform: translateY(-1px);
}

.pagination > li > a:hover {
  background: var(--gold-light);
  border-color: var(--royal-blue);
  color: var(--royal-blue-dark);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.pagination > li > a:active {
  transform: translateY(1px);
  box-shadow: 0 1px 0 var(--gold-dark);
}

/* ---------------------------------------------
   Barra de progreso con patrón de panal
--------------------------------------------- */
.progress {
  background-color: var(--off-white);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.1);
  height: 25px;
}

.progress-bar {
  background: linear-gradient(145deg, var(--gold), var(--gold-dark));
  color: var(--royal-blue-dark);
  font-weight: bold;
  line-height: 25px;
  position: relative;
  overflow: hidden;
}

.progress-bar::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: repeating-linear-gradient(45deg, rgba(255,255,255,0.2) 0px, rgba(255,255,255,0.2) 10px, transparent 10px, transparent 20px);
}

/* ---------------------------------------------
   Badges y etiquetas
--------------------------------------------- */
.badge {
  padding: 6px 12px;
  border-radius: 30px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

.badge-primary {
  background: var(--royal-blue);
  color: var(--gold);
}

.badge-warning {
  background: var(--gold);
  color: var(--royal-blue-dark);
}

/* ---------------------------------------------
   Animación de entrada para elementos
--------------------------------------------- */
@keyframes slideInUp {
  from {
    transform: translateY(20px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.card, .table, .btn, .alert {
  animation: slideInUp 0.4s ease-out;
}

/* ---------------------------------------------
   Efectos para notificaciones (alertas)
--------------------------------------------- */
.alert {
  border: none;
  border-radius: 12px;
  border-left: 5px solid;
  box-shadow: 0 5px 12px rgba(0,0,0,0.05);
}

.alert-success {
  background: linear-gradient(145deg, #e6f4e6, #d4e8d4);
  border-left-color: var(--gold);
  color: var(--royal-blue-dark);
}

.alert-info {
  background: linear-gradient(145deg, #e0f0e0, #d0e0d0);
  border-left-color: var(--royal-blue);
  color: var(--royal-blue-dark);
}

/* ---------------------------------------------
   Personalización para móviles (responsive)
--------------------------------------------- */
@media (max-width: 768px) {
  .main-sidebar {
    border-right: 2px solid var(--gold);
  }
  
  .card {
    margin-bottom: 20px;
  }
  
  .btn {
    padding: 8px 16px;
    font-size: 0.9rem;
  }
}