/* ============================================
   ENTERPRISE SIDEBAR — Nora Cloud
   Theme-aware: respects AdminLTE skin colors.
   - Dark skins (skin-black, skin-blue, skin-purple,
     skin-green, skin-red, skin-yellow) → dark sidebar,
     light text.
   - Light skins (any *-light variant, skin-white) →
     white sidebar, dark text.
   ============================================ */

/* ---------- Skin variables ---------- */
:root {
  --nora-side-bg: linear-gradient(180deg, #0b1220 0%, #0f172a 60%, #111827 100%);
  --nora-side-border: rgba(255, 255, 255, 0.04);
  --nora-text: #e2e8f0;
  --nora-text-strong: #ffffff;
  --nora-text-muted: #64748b;
  --nora-icon-bg: rgba(148, 163, 184, 0.08);
  --nora-icon: #94a3b8;
  --nora-hover-bg: rgba(99, 102, 241, 0.18);
  --nora-active-bg: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
  --nora-active-text: #ffffff;
  --nora-active-shadow: 0 4px 14px rgba(99, 102, 241, 0.4);
  --nora-submenu-bg: rgba(255, 255, 255, 0.04);
  --nora-submenu-bg-solid: #1e293b;
  --nora-flyout-label-text: #ffffff;
  --nora-submenu-border: rgba(165, 180, 252, 0.55);
  --nora-submenu-text: #f1f5f9;
  --nora-submenu-icon: #cbd5e1;
  --nora-text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
  --nora-scroll-thumb: rgba(148, 163, 184, 0.25);
  --nora-scroll-thumb-hover: rgba(148, 163, 184, 0.45);
  --nora-header-color: #64748b;
  --nora-user-border: rgba(255, 255, 255, 0.06);
  --nora-user-text: #e2e8f0;
}

/* Light skins → flip to white sidebar with dark text */
.skin-blue-light,
.skin-black-light,
.skin-purple-light,
.skin-green-light,
.skin-red-light,
.skin-yellow-light,
.skin-white {
  --nora-side-bg: linear-gradient(180deg, #ffffff 0%, #f8fafc 60%, #f1f5f9 100%);
  --nora-side-border: rgba(15, 23, 42, 0.08);
  --nora-text: #1e293b;
  --nora-text-strong: #0f172a;
  --nora-text-muted: #64748b;
  --nora-icon-bg: rgba(99, 102, 241, 0.08);
  --nora-icon: #475569;
  --nora-hover-bg: rgba(99, 102, 241, 0.1);
  --nora-active-bg: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
  --nora-active-text: #ffffff;
  --nora-active-shadow: 0 4px 14px rgba(99, 102, 241, 0.35);
  --nora-submenu-bg: rgba(15, 23, 42, 0.03);
  --nora-submenu-bg-solid: #ffffff;
  --nora-flyout-label-text: #ffffff;
  --nora-submenu-border: rgba(99, 102, 241, 0.4);
  --nora-submenu-text: #1e293b;
  --nora-submenu-icon: #475569;
  --nora-text-shadow: none;
  --nora-scroll-thumb: rgba(15, 23, 42, 0.2);
  --nora-scroll-thumb-hover: rgba(15, 23, 42, 0.35);
  --nora-header-color: #475569;
  --nora-user-border: rgba(15, 23, 42, 0.08);
  --nora-user-text: #1e293b;
}

/* ---------- Sidebar Shell ---------- */
.main-sidebar,
.left-side {
  background: var(--nora-side-bg) !important;
  box-shadow: 2px 0 24px rgba(0, 0, 0, 0.12);
  overflow-x: hidden !important;
  border-right: 1px solid var(--nora-side-border);
}

.main-sidebar .sidebar,
.main-sidebar .sidebar-menu {
  overflow-x: hidden !important;
  background: transparent !important;
}

/* Logo / Brand area */
.main-header .logo,
.main-sidebar .logo {
  background: linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%) !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  letter-spacing: 0.3px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
.main-header .logo:hover {
  background: linear-gradient(135deg, #4338ca 0%, #6d28d9 100%) !important;
}

/* Custom scrollbar */
.main-sidebar::-webkit-scrollbar { width: 6px; }
.main-sidebar::-webkit-scrollbar-track { background: transparent; }
.main-sidebar::-webkit-scrollbar-thumb {
  background: var(--nora-scroll-thumb);
  border-radius: 3px;
}
.main-sidebar::-webkit-scrollbar-thumb:hover { background: var(--nora-scroll-thumb-hover); }

/* ---------- Section Header (li.header) ---------- */
.sidebar-menu > li.header {
  background: transparent !important;
  color: var(--nora-header-color) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 18px 20px 8px !important;
  border: none !important;
}

/* ---------- Top-level Menu Items ---------- */
.sidebar-menu > li {
  margin: 1px 8px !important;
  border-radius: 8px;
  transition: background 120ms ease;
}

.sidebar-menu > li > a {
  display: flex !important;
  align-items: center;
  padding: 7px 10px !important;
  border-radius: 8px !important;
  color: var(--nora-text) !important;
  background: transparent !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.2px;
  border-left: none !important;
  transition: background 120ms ease, color 120ms ease;
  position: relative;
  text-shadow: var(--nora-text-shadow);
  line-height: 1.25 !important;
}

.sidebar-menu > li > a > span {
  color: inherit !important;
}

/* Hover state — fast, no transform jitter */
.sidebar-menu > li > a:hover {
  background: var(--nora-hover-bg) !important;
  color: var(--nora-text-strong) !important;
}

/* Active standalone item (no submenu) — full gradient highlight */
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a,
.main-sidebar .sidebar-menu > li.active:not(.treeview):hover > a {
  background: var(--nora-active-bg) !important;
  color: var(--nora-active-text) !important;
  font-weight: 700 !important;
  box-shadow: var(--nora-active-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.15);
  transform: none;
}

.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > span {
  color: var(--nora-active-text) !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.35) !important;
}

/* Active parent/open group — respect theme text color */
.main-sidebar .sidebar-menu > li.treeview.active > a,
.main-sidebar .sidebar-menu > li.treeview.menu-open > a,
.main-sidebar .sidebar-menu > li.treeview.active:hover > a {
  background: var(--nora-hover-bg) !important;
  color: var(--nora-text-strong) !important;
  font-weight: 700 !important;
  box-shadow: none;
  transform: none;
}

.main-sidebar .sidebar-menu > li.treeview.active > a > span,
.main-sidebar .sidebar-menu > li.treeview.menu-open > a > span {
  color: var(--nora-text-strong) !important;
  text-shadow: var(--nora-text-shadow) !important;
}

.skin-blue-light .main-sidebar .sidebar-menu > li.treeview.active > a,
.skin-black-light .main-sidebar .sidebar-menu > li.treeview.active > a,
.skin-purple-light .main-sidebar .sidebar-menu > li.treeview.active > a,
.skin-green-light .main-sidebar .sidebar-menu > li.treeview.active > a,
.skin-red-light .main-sidebar .sidebar-menu > li.treeview.active > a,
.skin-yellow-light .main-sidebar .sidebar-menu > li.treeview.active > a,
.skin-white .main-sidebar .sidebar-menu > li.treeview.active > a,
.skin-blue-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a,
.skin-black-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a,
.skin-purple-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a,
.skin-green-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a,
.skin-red-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a,
.skin-yellow-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a,
.skin-white .main-sidebar .sidebar-menu > li.treeview.menu-open > a {
  color: #0f172a !important;
}

.skin-blue-light .main-sidebar .sidebar-menu > li.treeview.active > a > span,
.skin-black-light .main-sidebar .sidebar-menu > li.treeview.active > a > span,
.skin-purple-light .main-sidebar .sidebar-menu > li.treeview.active > a > span,
.skin-green-light .main-sidebar .sidebar-menu > li.treeview.active > a > span,
.skin-red-light .main-sidebar .sidebar-menu > li.treeview.active > a > span,
.skin-yellow-light .main-sidebar .sidebar-menu > li.treeview.active > a > span,
.skin-white .main-sidebar .sidebar-menu > li.treeview.active > a > span,
.skin-blue-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a > span,
.skin-black-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a > span,
.skin-purple-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a > span,
.skin-green-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a > span,
.skin-red-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a > span,
.skin-yellow-light .main-sidebar .sidebar-menu > li.treeview.menu-open > a > span,
.skin-white .main-sidebar .sidebar-menu > li.treeview.menu-open > a > span {
  color: #0f172a !important;
  text-shadow: none !important;
}

/* Active indicator bar */
.main-sidebar .sidebar-menu > li.active > a::before,
.main-sidebar .sidebar-menu > li.menu-open > a::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 8px;
  bottom: 8px;
  width: 3px;
  background: #6366f1;
  border-radius: 0 3px 3px 0;
  box-shadow: 0 0 8px rgba(99, 102, 241, 0.6);
}

/* ---------- Icon Styling ---------- */
.sidebar-menu > li > a > i,
.sidebar-menu > li > a > .fa,
.sidebar-menu > li > a > .fas,
.sidebar-menu > li > a > .far,
.sidebar-menu > li > a > .fab {
  font-size: 14px !important;
  width: 28px !important;
  height: 28px !important;
  line-height: 28px !important;
  text-align: center;
  margin-right: 10px !important;
  border-radius: 7px;
  background: var(--nora-icon-bg);
  color: var(--nora-icon) !important;
  transition: background 120ms ease, color 120ms ease;
  flex-shrink: 0;
}

.sidebar-menu > li:hover > a > i {
  background: rgba(99, 102, 241, 0.18);
  color: #6366f1 !important;
}

.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > i,
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .fa,
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .fas,
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .far,
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .fab {
  background: rgba(255, 255, 255, 0.2) !important;
  color: #ffffff !important;
}

.main-sidebar .sidebar-menu > li.treeview.active > a > i,
.main-sidebar .sidebar-menu > li.treeview.active > a > .fa,
.main-sidebar .sidebar-menu > li.treeview.menu-open > a > i,
.main-sidebar .sidebar-menu > li.treeview.menu-open > a > .fa,
.main-sidebar .sidebar-menu > li.treeview.active > a > .fas,
.main-sidebar .sidebar-menu > li.treeview.active > a > .far,
.main-sidebar .sidebar-menu > li.treeview.active > a > .fab,
.main-sidebar .sidebar-menu > li.treeview.menu-open > a > .fas,
.main-sidebar .sidebar-menu > li.treeview.menu-open > a > .far,
.main-sidebar .sidebar-menu > li.treeview.menu-open > a > .fab {
  background: rgba(99, 102, 241, 0.16) !important;
  color: #6366f1 !important;
}

/* Distinct icon tints (subtle) for visual variety */
.sidebar-menu > li:nth-child(1)  > a > i { color: #60a5fa !important; }
.sidebar-menu > li:nth-child(2)  > a > i { color: #c084fc !important; }
.sidebar-menu > li:nth-child(3)  > a > i { color: #2dd4bf !important; }
.sidebar-menu > li:nth-child(4)  > a > i { color: #fb7185 !important; }
.sidebar-menu > li:nth-child(5)  > a > i { color: #fbbf24 !important; }
.sidebar-menu > li:nth-child(6)  > a > i { color: #4ade80 !important; }
.sidebar-menu > li:nth-child(7)  > a > i { color: #94a3b8 !important; }
.sidebar-menu > li:nth-child(8)  > a > i { color: #5eead4 !important; }
.sidebar-menu > li:nth-child(9)  > a > i { color: #fb923c !important; }
.sidebar-menu > li:nth-child(10) > a > i { color: #a78bfa !important; }
.sidebar-menu > li:nth-child(11) > a > i { color: #34d399 !important; }
.sidebar-menu > li:nth-child(12) > a > i { color: #f87171 !important; }
.sidebar-menu > li:nth-child(13) > a > i { color: #fdba74 !important; }
.sidebar-menu > li:nth-child(14) > a > i { color: #818cf8 !important; }
.sidebar-menu > li:nth-child(15) > a > i { color: #facc15 !important; }
.sidebar-menu > li:nth-child(16) > a > i { color: #cbd5e1 !important; }

.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > i,
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .fa,
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .fas,
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .far,
.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .fab {
  color: #ffffff !important;
}

/* ---------- Caret / Chevron ---------- */
.sidebar-menu > li > a > .pull-right-container {
  position: static !important;
  margin-left: auto !important;
  display: flex;
  align-items: center;
  top: auto !important;
  right: auto !important;
}

.sidebar-menu > li > a > .pull-right-container > .fa-angle-left,
.sidebar-menu > li > a > .pull-right-container > .pull-right {
  font-size: 12px !important;
  color: var(--nora-text-muted) !important;
  transition: transform 250ms ease, color 200ms ease;
  margin: 0 !important;
  background: transparent !important;
  width: auto !important;
  height: auto !important;
  line-height: 1 !important;
}

.main-sidebar .sidebar-menu > li.treeview.menu-open > a > .pull-right-container > .fa-angle-left,
.main-sidebar .sidebar-menu > li.treeview.active > a > .pull-right-container > .fa-angle-left {
  transform: rotate(-90deg);
  color: #6366f1 !important;
}

.sidebar-menu > li:hover > a > .pull-right-container > .fa-angle-left {
  color: var(--nora-text-strong) !important;
}

.main-sidebar .sidebar-menu > li.active:not(.treeview) > a > .pull-right-container > .fa-angle-left {
  color: #ffffff !important;
}

/* ---------- Treeview Submenu ---------- */
.sidebar-menu .treeview-menu {
  background: var(--nora-submenu-bg) !important;
  margin: 3px 0 2px !important;
  padding: 3px 0 3px 0 !important;
  border-radius: 8px;
  border-left: 2px solid var(--nora-submenu-border);
  margin-left: 18px !important;
  margin-right: 4px !important;
}

.sidebar-menu .treeview-menu > li {
  margin: 0 6px !important;
}

.sidebar-menu .treeview-menu > li > a {
  display: flex !important;
  align-items: center;
  padding: 6px 12px 6px 14px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--nora-submenu-text) !important;
  border-radius: 6px !important;
  transition: background 120ms ease, color 120ms ease;
  letter-spacing: 0.1px;
  text-shadow: var(--nora-text-shadow);
  line-height: 1.25 !important;
}

.sidebar-menu .treeview-menu > li > a > i {
  font-size: 12px !important;
  width: 16px !important;
  margin-right: 8px !important;
  color: var(--nora-submenu-icon) !important;
  background: transparent !important;
  height: auto !important;
  line-height: 1 !important;
  border-radius: 0;
}

/* Submenu hover — no padding shift to keep it stable */
.sidebar-menu .treeview-menu > li > a:hover {
  background: rgba(99, 102, 241, 0.22) !important;
  color: var(--nora-text-strong) !important;
}
.sidebar-menu .treeview-menu > li > a:hover > i {
  color: #6366f1 !important;
}

/* Submenu active */
.sidebar-menu .treeview-menu > li.active > a,
.sidebar-menu .treeview-menu > li.active > a:hover {
  background: rgba(99, 102, 241, 0.35) !important;
  color: var(--nora-text-strong) !important;
  font-weight: 700 !important;
  position: relative;
}

.sidebar-menu .treeview-menu > li.active > a::before {
  content: "";
  position: absolute;
  left: -8px;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #818cf8;
  box-shadow: 0 0 8px rgba(129, 140, 248, 0.8);
}

.sidebar-menu .treeview-menu > li.active > a > i {
  color: #6366f1 !important;
}

/* Nested treeview (3rd level) */
.sidebar-menu .treeview-menu .treeview-menu {
  background: rgba(0, 0, 0, 0.06) !important;
  margin-left: 12px !important;
  border-left: 1px dashed rgba(99, 102, 241, 0.3);
}

/* ---------- Collapsed (mini) sidebar ---------- */
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li > a {
  padding: 9px 0 !important;
  min-height: 46px !important;
  height: 46px !important;
  justify-content: center;
  align-items: center;
  display: flex !important;
  overflow: visible !important;
}
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li {
  margin: 2px 6px !important;
}
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li > a > i {
  margin-right: 0 !important;
}

/* Hide labels & chevrons inline in collapsed mode (they re-appear as floating tile on hover) */
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li > a > span:not(.pull-right-container),
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li > a > .pull-right-container {
  display: none !important;
}

/* Hide the active indicator bar in collapsed mode (no room for it) */
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.active > a::before,
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.menu-open > a::before {
  display: none !important;
}

/* Active state in collapsed mode — compact rounded tile around icon only (idle, not interacting) */
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.active:not(.treeview):not(:hover):not(:focus-within) > a {
  background: var(--nora-active-bg) !important;
  color: #ffffff !important;
  border-radius: 10px !important;
  box-shadow: var(--nora-active-shadow) !important;
}

/* Active treeview parent in collapsed mode (idle) — softer highlight */
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.active:not(:hover):not(:focus-within):not(.menu-open) > a,
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open:not(:hover):not(:focus-within) > a {
  background: var(--nora-hover-bg) !important;
  border-radius: 10px !important;
  box-shadow: none !important;
}

/* When hovering, focusing, or menu-open in collapsed mode — icon <a> stays transparent so the floating purple label doesn't double-up */
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li:hover > a,
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li:focus-within > a,
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open > a,
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.active:hover > a,
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.active:focus-within > a {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  color: var(--nora-text-strong) !important;
  box-shadow: none !important;
}

/* Icon itself gets a subtle pill when interacting */
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li:hover > a > i,
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li:focus-within > a > i,
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open > a > i {
  background: var(--nora-hover-bg) !important;
  color: #6366f1 !important;
}

/* Icon contrast in active idle state */
.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.active:not(.treeview):not(:hover):not(:focus-within) > a > i {
  background: rgba(255, 255, 255, 0.18) !important;
  color: #ffffff !important;
}

/* ---------- Hover fly-out submenu in collapsed mode ---------- */
/* Allow fly-out to escape the sidebar bounds */
body.sidebar-collapse .main-sidebar,
body.sidebar-collapse .main-sidebar .sidebar,
body.sidebar-collapse .main-sidebar .sidebar-menu {
  overflow: visible !important;
}

/* Each top-level li becomes a positioning anchor */
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li {
  position: relative !important;
}

/* Floating label tile when hovering or focusing a top-level item (collapsed) */
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li:hover > a > span:not(.pull-right-container),
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li:focus-within > a > span:not(.pull-right-container),
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open > a > span:not(.pull-right-container) {
  display: inline-block !important;
  position: absolute !important;
  top: 0 !important;
  left: 50px !important;
  width: 230px !important;
  min-height: 42px !important;
  padding: 11px 14px !important;
  background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%) !important;
  color: #ffffff !important;
  font-weight: 600 !important;
  font-size: 13.5px !important;
  border-radius: 0 8px 0 0 !important;
  box-shadow: 4px 0 12px rgba(15, 23, 42, 0.18) !important;
  z-index: 1051 !important;
  text-align: left !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  visibility: visible !important;
  opacity: 1 !important;
  transition: none !important;
  animation: none !important;
  transform: none !important;
}

/* Hide the angle arrow container in collapsed mode */
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li > a > .pull-right-container {
  display: none !important;
}

/* Invisible hover/focus bridge so moving from icon → submenu doesn't break state */
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:hover::after,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:focus-within::after,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50px;
  width: 220px;
  height: 100%;
  min-height: 60px;
  z-index: 1049;
  pointer-events: auto;
}

/* Fly-out submenu stays open on hover, focus/click, or AdminLTE menu-open state */
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:hover > .treeview-menu,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:focus-within > .treeview-menu,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open > .treeview-menu,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview > .treeview-menu:hover,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview > .treeview-menu:focus-within {
  display: block !important;
  position: absolute !important;
  width: 230px !important;
  left: 50px !important;
  top: 42px !important;
  padding: 6px 0 !important;
  margin: 0 !important;
  background: #ffffff !important;
  background-color: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.12) !important;
  border-top: none !important;
  border-radius: 0 8px 8px 8px !important;
  box-shadow: 6px 8px 24px rgba(15, 23, 42, 0.22) !important;
  z-index: 1050 !important;
  max-height: calc(100vh - 100px) !important;
  overflow-y: auto !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transition: none !important;
  animation: none !important;
}

body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:hover > .treeview-menu > li > a,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:focus-within > .treeview-menu > li > a,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open > .treeview-menu > li > a {
  padding: 9px 16px !important;
  color: #1e293b !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
  display: block !important;
  background: transparent !important;
  text-shadow: none !important;
  transition: none !important;
}

/* Hide the AdminLTE default arrow prefix in fly-out submenu */
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview > .treeview-menu > li > a::before {
  display: none !important;
  content: none !important;
}

body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:hover > .treeview-menu > li > a:hover,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:focus-within > .treeview-menu > li > a:hover,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open > .treeview-menu > li > a:hover {
  background: rgba(99, 102, 241, 0.1) !important;
  color: #6366f1 !important;
}

body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:hover > .treeview-menu > li.active > a,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview:focus-within > .treeview-menu > li.active > a,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview.menu-open > .treeview-menu > li.active > a {
  background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%) !important;
  color: #ffffff !important;
}

/* Floating label tile — disable any animation/transition for instant snap */
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li:hover > a,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li:focus-within > a,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li > a,
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li > a > i {
  transition: none !important;
  animation: none !important;
  transform: none !important;
}

/* User panel polish */
.user-panel {
  border-bottom: 1px solid var(--nora-user-border) !important;
  padding: 14px 12px !important;
}
.user-panel .info,
.user-panel .info > a {
  color: var(--nora-user-text) !important;
  font-weight: 500 !important;
}

/* Sidebar form (search) */
.sidebar-form {
  margin: 12px !important;
  border-radius: 8px !important;
  border: 1px solid var(--nora-side-border) !important;
  background: var(--nora-submenu-bg) !important;
}
.sidebar-form input[type="text"] {
  background: transparent !important;
  color: var(--nora-text) !important;
  border: none !important;
}
.sidebar-form .btn {
  background: transparent !important;
  color: var(--nora-text-muted) !important;
  border: none !important;
}

/* ============================================
   FORCE submenu icons to render their real glyph
   (kills the generic "→" prefix once and for all)
   ============================================ */
.main-sidebar .sidebar-menu .treeview-menu > li > a::before,
.main-sidebar .sidebar-menu .treeview-menu > li > a::after {
  content: none !important;
  display: none !important;
}

.main-sidebar .sidebar-menu .treeview-menu > li > a > i,
.main-sidebar .sidebar-menu .treeview-menu > li > a > .fa,
.main-sidebar .sidebar-menu .treeview-menu > li > a > .fas,
.main-sidebar .sidebar-menu .treeview-menu > li > a > .far,
.main-sidebar .sidebar-menu .treeview-menu > li > a > .fab {
  display: inline-block !important;
  visibility: visible !important;
  opacity: 1 !important;
  width: 18px !important;
  min-width: 18px !important;
  margin-right: 10px !important;
  font-size: 13px !important;
  text-align: center !important;
  color: var(--nora-submenu-icon, #94a3b8) !important;
}

/* Apply also inside the collapsed-mode fly-out submenu */
body.sidebar-mini.sidebar-collapse .main-sidebar .sidebar-menu > li.treeview > .treeview-menu > li > a > i {
  display: inline-block !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: #6366f1 !important;
  margin-right: 10px !important;
  width: 18px !important;
  text-align: center !important;
}