/* =============================================
 * SIDEBAR & NAVBAR - Custom Overrides
 * Archivo centralizado para estilos del sidebar
 * y navbar que sobreescriben Material Dashboard.
 * =============================================
 */

/* --- FLECHAS DE SUBMENÚ --- */
#sidenav-collapse-main .nav-item .collapse-arrow {
  transition: transform 0.2s;
  margin-left: auto;
}
#sidenav-collapse-main .nav-link[data-bs-toggle="collapse"]::after {
  display: none !important;
}
.nav-link[aria-expanded="true"] .collapse-arrow {
  transform: rotate(180deg);
}

/* --- LAYOUT FIJO: main-content con margin del sidebar mini --- */
@media (min-width: 1200px) {
  #sidenav-main.sidenav {
    max-width: 300px !important;
    width: 300px !important;
    z-index: 1040 !important;
  }

  .main-content,
  .sidenav.fixed-start + .main-content,
  .g-sidenav-show .main-content,
  .g-sidenav-show.g-sidenav-pinned .main-content {
    margin-left: 100px !important;
  }

  #iconNavbarSidenav {
    display: none !important;
  }
}

/* Anular transiciones de Material Dashboard en main-content */
.main-content {
  transition: none !important;
}

/* Sidebar: solo animar width/max-width */
#sidenav-main {
  transition: width 0.3s ease-in-out, max-width 0.3s ease-in-out !important;
}

/* Mostrar X de cierre en móviles */
@media (max-width: 719.98px) {
  #iconSidenav {
    display: block !important;
    opacity: 1 !important;
  }
}

/* --- BOTÓN "+" EN LA SIDEBAR --- */
.nav-incluir-btn {
  width: 22px;
  height: 22px;
  background: #f0f2f5;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #344767 !important;
  transition: all 0.2s ease;
  text-decoration: none !important;
  margin-left: 8px;
}
.nav-incluir-btn:hover {
  background: #344767;
  color: #fff !important;
  transform: scale(1.1);
}
.nav-incluir-btn i {
  font-size: 14px !important;
}

/* --- NAVBAR SUPERIOR --- */
.navbar-main .navbar-nav {
  margin-left: auto !important;
  flex-direction: row !important;
  justify-content: flex-end !important;
  width: auto !important;
  display: flex !important;
  gap: 0.5rem !important;
}
.navbar-main .navbar-collapse {
  display: flex !important;
  justify-content: flex-end !important;
  width: auto !important;
  flex-basis: auto !important;
}

/* Menú de la sidebar se mantiene vertical */
#sidenav-main .navbar-nav {
  flex-direction: column !important;
  margin-left: 0 !important;
  justify-content: flex-start !important;
}

/* =============================================
 * SIDEBAR COLAPSADO
 * Usa clase .sidebar-collapsed en #sidenav-main
 * para aislar el sidebar del resto de la página.
 * =============================================
 */
#sidenav-main.sidebar-collapsed {
  width: 80px !important;
  max-width: 80px !important;
  overflow: hidden !important;
}

#sidenav-main.sidebar-collapsed .nav-link-text,
#sidenav-main.sidebar-collapsed .sidenav-header span,
#sidenav-main.sidebar-collapsed .collapse-arrow,
#sidenav-main.sidebar-collapsed .nav-incluir-btn {
  display: none !important;
}

#sidenav-main.sidebar-collapsed .nav-item .nav-link {
  justify-content: center !important;
  padding: 10px !important;
}

#sidenav-main.sidebar-collapsed .nav-item .nav-link i {
  margin-right: 0 !important;
}

/* Header: misma altura fija en ambos modos */
.sidenav-header {
  height: 64px !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 !important;
}
.sidenav-header .navbar-brand {
  padding: 0 1.5rem !important;
  margin: 0 !important;
}

#sidenav-main.sidebar-collapsed .sidenav-header {
  justify-content: center !important;
  padding: 0 !important;
}
#sidenav-main.sidebar-collapsed .navbar-brand {
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  justify-content: center !important;
}
#sidenav-main.sidebar-collapsed .navbar-brand-img {
  margin: 0 !important;
}

/* Sombra sutil al hover sobre sidebar colapsado */
#sidenav-main.sidebar-collapsed:hover {
  box-shadow: 4px 0 16px rgba(52,71,103,0.13);
}

/* Ocultar submenus en modo colapsado */
#sidenav-main.sidebar-collapsed .nav-item .collapse,
#sidenav-main.sidebar-collapsed .nav-item .collapse.show {
  display: none !important;
}

#sidenav-main.sidebar-collapsed .nav-item {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
}
