.navbar-brand-image {
    height: 8rem !important;
}

.sidebar-logo {
    height: 4rem !important;
}

.bg-color-violet{
    background-color: #3d2fe7 !important;
}

.btn-primary{
    background-color: #3d2fe7 !important;
}

.flex-wrap-unset{
    flex-wrap: unset !important;
}

.disabled-div {
    pointer-events: none; /* bloquea clics */
    opacity: 0.5;          /* da efecto visual */
}

.table-max-height{
    max-height: 550px !important;
}

/* Estilos para el navbar móvil */
@media (max-width: 991.98px) {
    .navbar-nav.flex-row.d-lg-none {
        margin-left: auto;
    }
    
    .navbar-nav.flex-row.d-lg-none .nav-item.dropdown {
        margin-left: 0.5rem;
    }
    
    .navbar-nav.flex-row.d-lg-none .dropdown-menu {
        position: fixed !important;
        top: auto !important;
        left: auto !important;
        right: 1rem !important;
        margin-top: 0.5rem;
        z-index: 1050;
        min-width: 200px;
    }
    
    .navbar-nav.flex-row.d-lg-none .avatar {
        width: 2rem;
        height: 2rem;
    }
    
    .navbar-nav.flex-row.d-lg-none .ps-2 {
        padding-left: 0.5rem !important;
    }
    
    .navbar-nav.flex-row.d-lg-none .ps-2 div:first-child {
        font-size: 0.875rem;
        font-weight: 500;
    }
    
    .navbar-nav.flex-row.d-lg-none .ps-2 .small {
        font-size: 0.75rem;
    }
}

/* Estilos personalizados para recibo de pago */
@media print {
  body, .page-wrapper, .container-xl, .card-lg, .card-body {
    background: #fff !important;
    color: #000 !important;
    box-shadow: none !important;
  }
  .d-print-none {
    display: none !important;
  }
  .card-lg {
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .container-xl {
    max-width: 100% !important;
    padding: 0 !important;
  }
  .recibo-logo {
    max-width: 180px;
    margin-bottom: 1rem;
  }
}

.recibo-logo {
  max-width: 180px;
  margin-bottom: 1rem;
}

.recibo-datos {
  font-size: 1rem;
  margin-bottom: 0.5rem;
}

.recibo-titulo {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 1rem;
}

/* Estilos para tabla de notas cualitativas */
.table-responsive {
  border: 1px solid var(--tblr-border-color);
  border-radius: 0.375rem;
}

#tbEstudiantesCuali {
  margin-bottom: 0;
}

#tbEstudiantesCuali th,
#tbEstudiantesCuali td {
  white-space: nowrap;
  vertical-align: middle;
}

#tbEstudiantesCuali th:first-child,
#tbEstudiantesCuali td:first-child {
  position: sticky;
  left: 0;
  background-color: var(--tblr-bg-surface);
  z-index: 9;
  border-right: 2px solid var(--tblr-border-color);
}

#tbEstudiantesCuali tbody tr:hover td:first-child {
  background-color: var(--tblr-bg-surface-hover);
}

.nota-cuali-select {
  min-width: 80px !important;
  max-width: 100px;
}

/* Asegurar que el header sticky tenga el fondo correcto */
#tbEstudiantesCuali thead th:first-child {
  background-color: var(--tblr-bg-surface) !important;
}

/* Para modo dark específicamente */
[data-bs-theme="dark"] #tbEstudiantesCuali th:first-child,
[data-bs-theme="dark"] #tbEstudiantesCuali td:first-child {
  background-color: var(--tblr-bg-surface);
}

[data-bs-theme="dark"] #tbEstudiantesCuali tbody tr:hover td:first-child {
  background-color: var(--tblr-bg-surface-hover);
}

/* Estilos para botones de calificación rápida */
.grade-btn {
  min-width: 40px;
  height: 32px;
  font-weight: bold;
  font-size: 0.875rem;
  transition: all 0.2s ease;
  margin: 1px;
}

.grade-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(0,0,0,0.15);
}

.grade-btn.active {
  transform: scale(1.05);
  box-shadow: 0 3px 6px rgba(0,0,0,0.2);
}

/* El color de los botones ahora depende solo de las clases de Tabler (btn-outline-indigo, btn-outline-purple, btn-outline-pink, btn-lime, etc.) */

/* Estilos dinámicos para botones de calificación - se aplicarán según el orden */
/*  */

/* Estilos para calificación masiva */
.bulk-grading-controls {
  background-color: var(--tblr-bg-surface);
  border: 1px solid var(--tblr-border-color);
  border-radius: 0.375rem;
  padding: 1rem;
  margin-bottom: 1rem;
}

.bulk-grading-controls .form-check {
  margin-bottom: 0.5rem;
}

.bulk-grading-controls .btn-group {
  margin-top: 0.5rem;
}

/* Estilos para separadores del menú */
.nav-item-divider {
    height: 1px;
    background-color: var(--tblr-border-color);
    margin: 0.5rem 1rem;
    opacity: 0.5;
}

/* Separador más visible para modo claro */
[data-bs-theme="light"] .nav-item-divider {
    background-color: #e9ecef;
    margin: 0.75rem 1rem;
}

/* Separador para modo oscuro */
[data-bs-theme="dark"] .nav-item-divider {
    background-color: #495057;
    margin: 0.75rem 1rem;
}

/* Espaciado adicional después del separador */
.nav-item-divider + .nav-item {
    margin-top: 0.25rem;
}

/* Estilos para grupos de menú */
.nav-item-group {
    margin-bottom: 0.5rem;
}

/* Estilos para el primer elemento después de un separador */
.nav-item-divider + .nav-item .nav-link {
    padding-top: 0.75rem;
}

/* Estilos para estudiantes seleccionados */
.student-row.selected {
  background-color: var(--tblr-bg-surface-hover) !important;
}

.student-row.selected td:first-child {
  background-color: var(--tblr-bg-surface-hover) !important;
}

/* Estilos para indicador de calificación masiva */
.bulk-indicator {
  position: fixed;
  top: 20px;
  right: 20px;
  background-color: #17a2b8;
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 0.375rem;
  z-index: 1050;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  display: none;
}

/* Estilos para tooltip de atajos */
.shortcut-tooltip {
  position: absolute;
  background-color: var(--tblr-bg-surface);
  border: 1px solid var(--tblr-border-color);
  border-radius: 0.25rem;
  padding: 0.5rem;
  font-size: 0.75rem;
  z-index: 1060;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  display: none;
  max-width: 300px;
}

/* Estilos para el efecto parallax */
.parallax-container {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  background: #f6f8fb;
  background-image: url('../images/parallax/background.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

/* Overlay para mejorar la legibilidad del contenido */
/* .parallax-container::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background:  #f6f8fb;
  z-index: 0;
  pointer-events: none;
} */

.parallax-layer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

.parallax-layer img {
  position: absolute;
  opacity: 1;
  transition: opacity 0.3s ease;
}

.parallax-layer img:hover {
  opacity: 1;
}

/* Capa de fondo - Montañas (velocidad más lenta) */
.parallax-mountains {
  z-index: 1;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
}

.parallax-mountains img {
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  max-height: 60vh;
  object-fit: cover;
  margin: 0;
  padding: 0;
  display: block;
}

/* Capa de nubes (velocidad media) */
.parallax-clouds {
  z-index: 2;
}

.parallax-clouds img {
  top: 10%;
  width: 100%;
  height: auto;
  max-height: 40vh;
  object-fit: cover;
}

/* Contenido principal */
.main-content {
  position: relative;
  z-index: 10;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  border-radius: 15px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

/* Efectos de hover para el contenido */
.main-content:hover {
  transform: translateY(-5px);
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
}



/* Responsive */
@media (max-width: 768px) {
  .parallax-container {
    background-attachment: scroll; /* Mejor rendimiento en móviles */
  }
  
  .parallax-layer img {
    opacity: 0.5;
  }
  
  /* Reducir opacidad de capas restantes */
  .parallax-mountains img,
  .parallax-clouds img {
    opacity: 0.3;
  }
}

/* Tablets - Mantener opacidad normal */
@media (min-width: 769px) and (max-width: 1024px) {
  /* Sin cambios específicos para tablets */
}

/* Dispositivos muy pequeños - Desactivar más capas */
@media (max-width: 480px) {
  .parallax-clouds {
    display: none !important; /* Ocultar nubes también */
  }
  
  .parallax-mountains img {
    opacity: 0.2; /* Muy sutil */
  }
  
  /* Simplificar el fondo */
  .parallax-container {
    background: linear-gradient(135deg, #00aaff 0%, #00f3ff 100%);
    background-image: none; /* Desactivar imagen de fondo en móviles muy pequeños */
  }
}

/* Animaciones de entrada */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-in-up {
  animation: fadeInUp 0.8s ease-out;
}

/* Efecto de brillo en el botón */
.btn-primary {
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.btn-primary::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transition: left 0.5s;
}

.btn-primary:hover::before {
  transform: translateX(100%);
}

/* ===== ESTILOS PARA COMENTARIOS DE NOTAS ===== */

/* Contenedor de nota y comentario */
.nota-container {
    position: relative;
}

/* Contenedor del textarea de comentarios */
.comentario-container {
    margin-top: 0.5rem;
    transition: all 0.3s ease;
}

/* Estilos para el textarea de comentarios */
.comentario-input {
    font-size: 0.75rem;
    resize: vertical;
    min-height: 60px;
}

.comentario-input::placeholder {
    color: #6c757d;
    font-style: italic;
}

/* Indicadores visuales para notas bajas */
.nota-input.border-warning {
    border-color: #ffc107 !important;
    box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.25) !important;
    background-color: #fff3cd;
}

.comentario-input.border-warning {
    border-color: #ffc107 !important;
    box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.25) !important;
}

.nota-input.border-warning::placeholder {
    color: #856404;
}

/* Animación suave para mostrar/ocultar comentarios */
.comentario-container {
    transition: all 0.3s ease;
}

/* Responsive para comentarios */
@media (max-width: 768px) {
    .comentario-input {
        font-size: 0.7rem;
        min-height: 50px;
    }
    
    .comentario-container {
        margin-top: 0.25rem;
    }
}