/*
 * Custom stylesheet for Connex/FXN Connex
 * Added to handle text truncation for long sidebar menu titles
 */

/* Sidebar primary menu text truncation */
.sidebar ul.nav li a {
  display: flex !important;
  align-items: center;
  width: 100%;
}

.sidebar ul.nav li a .menu-text {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-inline-end: 4px;
}

/* Sidebar submenu text truncation */
.sidebar ul.nav li .nav-second-level li a {
  display: flex !important;
  align-items: center;
  width: 100%;
}

.sidebar ul.nav li .nav-second-level li a .sub-menu-text {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-inline-end: 8px;
}

/* Ensure arrows and badges don't shrink, align correctly, and have margin */
.sidebar ul.nav li a .arrow,
.sidebar ul.nav li a .badge,
.sidebar ul.nav li .nav-second-level li a .badge {
  flex-shrink: 0;
  margin-inline-start: auto;
  float: none !important;
  padding-top: 0 !important;
  position: static !important;
}

/* Add specific alignment/margin for arrow */
.sidebar ul.nav li a .arrow {
  margin-inline-start: 8px;
}

/* Prevent menu icons from shrinking, which breaks alignment for items without content */
.sidebar ul.nav li a .menu-icon {
  flex-shrink: 0;
}

/* Hide empty menu icons in the sidebar to prevent unnecessary blank space and fix alignment */
.sidebar ul.nav li a i.menu-icon:not([class*="fa"]):not([class*="la"]):not([class*="glyph"]):not([class*="si"]) {
  display: none !important;
}

/* ==========================================
   Modern & Premium Column Visibility Dropdown
   ========================================== */

/* The dropdown background container */
div.dt-button-collection {
  background-color: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  border-radius: 12px !important;
  box-shadow: 0 10px 25px -5px rgba(15, 23, 42, 0.1), 0 8px 10px -6px rgba(15, 23, 42, 0.05) !important;
  padding: 8px !important;
  animation: dt-dropdown-fade-in 0.22s cubic-bezier(0.16, 1, 0.3, 1) !important;
  z-index: 9999 !important;
  margin-top: 6px !important;
}

/* Clear default list and menu styling */
div.dt-button-collection ul.dropdown-menu {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
  min-width: 230px !important;
}

/* Spacing between list items */
div.dt-button-collection ul.dropdown-menu>li {
  margin: 2px 0 !important;
}

/* Dropdown buttons in inactive state */
div.dt-button-collection ul.dropdown-menu>li>a,
div.dt-button-collection a.dt-button.buttons-columnVisibility {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 10px 14px !important;
  color: #475569 !important;
  /* Cool slate grey */
  font-family: inherit !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  border-radius: 8px !important;
  background: transparent !important;
  border: none !important;
  transition: all 0.2s ease-in-out !important;
  cursor: pointer !important;
  position: relative !important;
  text-decoration: none !important;
  text-align: left !important;
  box-shadow: none !important;
}

/* Hover effects with subtle sliding animation */
div.dt-button-collection ul.dropdown-menu>li>a:hover,
div.dt-button-collection a.dt-button.buttons-columnVisibility:hover {
  background-color: #f1f5f9 !important;
  color: #0f172a !important;
  /* Sleek dark slate text */
  padding-left: 18px !important;
}

/* Active selected state (when column is visible) */
div.dt-button-collection ul.dropdown-menu>li.active>a,
div.dt-button-collection a.dt-button.buttons-columnVisibility.active {
  background-color: #eff6ff !important;
  /* Soft blue tint */
  color: #2563eb !important;
  /* Premium brand blue */
  font-weight: 600 !important;
  box-shadow: none !important;
}

/* Right-aligned checkmark for active items */
div.dt-button-collection ul.dropdown-menu>li.active>a::after,
div.dt-button-collection a.dt-button.buttons-columnVisibility.active::after {
  content: "\2713" !important;
  font-family: inherit !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  color: #2563eb !important;
  margin-left: auto !important;
  display: inline-block !important;
}

/* Backdrop shadow helper */
div.dt-button-background {
  background: rgba(15, 23, 42, 0.05) !important;
  backdrop-filter: blur(1px) !important;
  transition: opacity 0.2s ease-in-out !important;
}

/* Smooth keyframe entrance */
@keyframes dt-dropdown-fade-in {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}