/* ============================================================
 * sidebar-night.css — Refonte sidebar bleu nuit slate-900
 *
 * Cible : #adminSideNav (rendu par router.js)
 * Tokens utilisés : --sidebar-* définis dans aslane-tokens.css
 * Accent actif : rouge ASLANE (var(--color-primary))
 * ============================================================ */

#adminSideNav {
  background: var(--sidebar-bg) !important;
  color: var(--sidebar-text) !important;
  border-right: 1px solid var(--sidebar-border);
  box-shadow: 2px 0 12px rgba(0, 0, 0, 0.25);
  font-family: var(--font-body);
}

#adminSideNav .sidebar-logo-area {
  background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, transparent 100%);
  border-bottom: 1px solid var(--sidebar-border);
  padding: var(--space-3) var(--space-2);
}

#adminSideNav .sidebar-logo-area img {
  background: #fff;
  padding: 4px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}

#adminSideNav .sidebar-links {
  padding: var(--space-2) 0;
}

#adminSideNav .snav-group {
  margin: 1px 0;
}

#adminSideNav .snav-link {
  color: var(--sidebar-text) !important;
  border-left: 3px solid transparent;
  border-bottom: 1px solid transparent;
  transition: background var(--transition-fast),
              color var(--transition-fast),
              border-left-color var(--transition-fast);
}

#adminSideNav .snav-icon {
  color: var(--sidebar-icon-color);
}

#adminSideNav .snav-label {
  color: var(--sidebar-text);
  font-weight: var(--font-semibold);
}

/* Hover */
#adminSideNav .snav-link:hover {
  background: var(--sidebar-bg-hover) !important;
  color: var(--sidebar-text-active) !important;
  border-left-color: var(--color-primary);
}

#adminSideNav .snav-link:hover .snav-icon {
  color: var(--sidebar-icon-active);
}

#adminSideNav .snav-link:hover .snav-label {
  color: var(--sidebar-text-active);
}

/* Active : rouge ASLANE transparent + bordure rouge */
#adminSideNav .snav-link.active {
  background: rgba(217, 4, 41, 0.18) !important;
  border-left-color: var(--color-primary) !important;
  color: var(--sidebar-text-active) !important;
  font-weight: var(--font-bold);
}

#adminSideNav .snav-link.active .snav-icon {
  color: var(--color-primary);
}

#adminSideNav .snav-link.active .snav-label {
  color: var(--sidebar-text-active);
  font-weight: var(--font-bold);
}

/* Parent (groupe replié) */
#adminSideNav .snav-parent {
  color: var(--sidebar-text-muted) !important;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

#adminSideNav .snav-parent .snav-label {
  color: var(--sidebar-section-label);
  font-weight: var(--font-semibold);
}

#adminSideNav .snav-parent:hover .snav-label {
  color: var(--sidebar-text-active);
}

/* Sous-menu : items plus discrets et indentés */
#adminSideNav .snav-group [id^="submenu_"] .snav-link {
  font-size: 0.72rem;
  padding-left: 0.8rem;
}

/* Séparateurs */
#adminSideNav .sidebar-links > div[style*="border-top"] {
  border-top: 1px solid var(--sidebar-border) !important;
  opacity: 1 !important;
}

/* Footer (email user + select année) */
#adminSideNav > div[style*="border-top"]:last-of-type {
  background: rgba(0, 0, 0, 0.25);
  border-top: 1px solid var(--sidebar-border) !important;
  color: var(--sidebar-text-muted);
}

#adminSideNav #sidebar-year-select {
  background: var(--sidebar-bg-hover) !important;
  color: var(--sidebar-text) !important;
  border: 1px solid var(--sidebar-border) !important;
}

/* Badges compteurs (déjà colorés dynamiquement) — légère bordure pour contraste */
#adminSideNav [id^="sc-"] {
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.15);
  font-weight: var(--font-bold) !important;
}

/* Mobile : drawer */
@media (max-width: 899px) {
  #adminSideNav { display: none !important; }
  #adminSideNav.open {
    display: flex !important;
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: 260px;
    z-index: 10000;
    box-shadow: 4px 0 20px rgba(0, 0, 0, 0.4);
  }
}

/* Hamburger mobile : couleur cohérente */
#mobile-hamburger {
  background: var(--sidebar-bg) !important;
  color: var(--sidebar-text-active) !important;
}
