/* Mega Menu Styles */

/* Main mega menu container */
.mega-menu {
  position: absolute !important;
  top: 100% !important;
  left: 0%;
  background-color: #fff !important;
  border-radius: 20px !important;
  border: 2px dashed #5a2c86 !important;
  padding: 30px !important;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1) !important;
  z-index: 9999 !important;
  display: none !important;
  width: 750px;
  max-width: 750px !important;
  margin: 0 auto !important;
  margin-top: 0px !important;
  overflow: hidden !important; /* Prevent content from extending beyond borders */
  box-sizing: border-box !important; /* Include padding in width calculation */
}

/* Position for the mega menu parent */
.nav-item.has-mega-menu {
  position: relative !important;
}

/* Show mega menu on hover */
.nav-item.has-mega-menu:hover .mega-menu,
.nav-item.has-mega-menu:focus-within .mega-menu {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 9999 !important;
}

/* Override any theme-specific dropdown behavior */
.nav-item.has-mega-menu .dropdown-menu {
  display: none !important;
}

.nav-item.has-mega-menu:hover .dropdown-menu {
  display: none !important;
}

/* Force display for debugging */
.debug-show-mega-menu .mega-menu {
  display: block !important;
}

/* Mega menu title */
.mega-menu-title {
    color: #411A50;
    font-family: 'Georama', sans-serif !important;
    font-size: 26px;
    font-weight: 700 !important;
    line-height: 105%;
    letter-spacing: -0.03em;
    margin-bottom: 30px;
    text-decoration: none;
}

/* Mega menu grid */
.mega-menu-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 30px !important;
  margin-top: 20px !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* Mega menu item */
.mega-menu-item {
  display: flex !important;
  align-items: center !important;
  padding: 0px !important;
  border-radius: 15px !important;
  transition: all 0.3s ease !important;
  text-decoration: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.mega-menu-item:hover,
.mega-menu-item:focus {
  background-color: transparent !important;
}

/* Mega menu item icon container */
.mega-menu-icon {
  width: 93px !important;
  margin-right: 15px !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Mega menu image icons */
.mega-menu-icon img {
  width: 93px !important;
  height: auto !important;
  object-fit: contain !important;
  border-radius: 17px !important;
  border: 2px dashed #5a2c86 !important;
  padding: 0px !important;
}

/* Mega menu item content */
.mega-menu-content {
  flex-grow: 1;
  overflow: hidden !important;
  width: calc(100% - 108px) !important; /* 93px icon width + 15px margin */
  box-sizing: border-box !important;
}

/* Mega menu item title */
.mega-menu-item-title {
  color: #411A50 !important;
  font-family: 'Georama', sans-serif !important;
  font-size: 19px !important;
  font-weight: 700 !important;
  line-height: 105% !important; /* 19.95px */
  letter-spacing: -0.57px !important;
  margin-bottom: 5px !important;
  padding: 0 !important;
  position: relative !important;
  display: inline-block !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Arrow for mega menu item title */
.mega-menu-item-title::after {
  content: "⇢" !important;
  position: relative !important;
  display: inline-block !important;
  margin-left: 1rem !important;
  opacity: 0 !important;
  transform: translateX(-5px) !important;
  transition: all 0.3s ease !important;
  font-weight: bold !important;
  font-size: 1.2em !important;
}

.mega-menu-item:hover .mega-menu-item-title::after,
.mega-menu-item:focus .mega-menu-item-title::after {
  opacity: 1 !important;
  transform: translateX(0) !important;
}

/* Mega menu item description */
.mega-menu-item-desc {
  color: #333;
  font-size: 0.9rem;
  line-height: 1.4;
  opacity: 0.66;
  transition: opacity 0.3s ease;
  margin-bottom: 0;
}

.mega-menu-item:hover .mega-menu-item-desc,
.mega-menu-item:focus .mega-menu-item-desc {
  opacity: 1;
}

/* Down arrow for dropdown indicator - only for Who We Serve */
.nav-link::after {
  content: none !important;
}

.has-mega-menu .nav-link::after {
  content: "" !important;
  display: inline-block !important;
  margin-left: 5px !important;
  width: 0 !important;
  height: 0 !important;
  border-left: 5px solid transparent !important;
  border-right: 5px solid transparent !important;
  border-top: 5px solid currentColor !important;
  vertical-align: middle !important;
}

/* Accessibility */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* Mobile menu styles */
.text-purple {
  color: #5a2c86 !important;
}

.mobile-dropdown-indicator {
  font-size: 12px;
  color: #5a2c86;
  transition: transform 0.3s ease;
}

.nav-item.dropdown .nav-link[aria-expanded="true"] .mobile-dropdown-indicator {
  transform: rotate(180deg);
}

#mobileWhoWeServe .list-unstyled a:hover .text-purple,
#mobileWhoWeServe .list-unstyled a:focus .text-purple {
  text-decoration: underline;
}

/* Responsive styles */
@media (max-width: 991.98px) {
  .mega-menu {
    display: none !important;
  }
}
