/* ===========================================
 * Mega Menu Styling
 * Dependencies: mega-menu.js
 * Usage: Make sure to enable mega-menu function in functions.php 
 * =========================================== */

.js-mega-menu { 
  position: relative !important; 
}

.js-mega-dropdown {
  position: absolute !important;
  top: -500% !important;
  left: 50% !important; /* Center horizontally */
  transform: translateX(-50%) !important; /* Perfect center alignment */
  background: #fff !important; 
  border: 1px solid #ddd !important;
  box-shadow: rgba(0, 0, 0, 0.16) 0px 10px 36px 0px, rgba(0, 0, 0, 0.06) 0px 0px 0px 1px;
  border-radius: 8px;
  opacity: 0 !important; 
  visibility: hidden !important;
  width: 1200px;
  max-width: 95vw; /* Prevent overflow on smaller screens */
  pointer-events: none !important; 
  z-index: 999999 !important;
  margin-top: 16px !important; 
  transition: opacity 80ms linear !important;
  transition-delay: 150ms !important
}

/* Create invisible bridge to eliminate hover gaps */
.js-mega-dropdown:before {
    content: '';
    position: absolute;
    top: -16px;
    left: 0;
    right: 0;
    height: 16px;
    background: transparent;
}

.js-mega-menu:hover .js-mega-dropdown,
.js-mega-menu:focus-within .js-mega-dropdown,
.js-mega-dropdown:hover {
  opacity: 1 !important; 
  visibility: visible !important;
  pointer-events: auto !important;
  top: 100% !important;
}

.js-mega-inner {
  padding: 25px 30px !important; 
  display: flex !important;
}

.js-mega-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 25px !important; 
  margin: 0 !important; 
  padding: 0 !important; 
  list-style: none !important;
  width: 100%;
}

.js-mega-column h4 {
  font-weight: 600 !important; 
  margin-bottom: 12px !important; 
  padding-bottom: 8px !important;
  font-size: 18px !important; 
  color: var(--global-color-15);
}

.js-mega-column ul { 
  margin: 0 !important; 
  padding: 0 !important; 
  list-style: none !important;
  background: none !important;
  box-shadow: none !important;
}

.js-mega-column li { 
  margin-bottom: 6px !important; 
}

.js-mega-column a {
  display: block !important; 
  color: var(--global-color-15); 
  text-decoration: none !important;
  padding: 6px 0 !important; 
  font-size: 16px !important; 
  transition: color 0.15s ease !important;
  pointer-events: auto !important; 
  cursor: pointer !important;
}

.js-mega-column a:hover { 
  color: var(--primary-1); 
}

/* Override theme defaults that might interfere */
.main-navigation .js-mega-dropdown ul {
  float: none !important;
  position: static !important;
  left: auto !important;
  top: auto !important;
  opacity: 1 !important;
  visibility: visible !important;
  height: auto !important;
  overflow: visible !important;
}

.main-navigation .js-mega-menu .js-mega-dropdown {
  position: absolute !important;
  float: none !important;
}

/* Ensure parent containers allow overflow */
.main-navigation, 
.main-navigation ul, 
.main-navigation li { 
  overflow: visible !important; 
}

/* Mobile responsive */
@media (max-width: 768px) {
  .js-mega-dropdown {
    position: static !important; 
    transform: none !important; 
    opacity: 1 !important;
    visibility: visible !important; 
    pointer-events: auto !important;
    box-shadow: none !important; 
    border: none !important; 
    border-top: 1px solid #eee !important;
    min-width: auto !important; 
    max-width: none !important;
    width: 100% !important;
  }
  
  .js-mega-grid { 
    grid-template-columns: 1fr !important; 
    gap: 20px !important; 
  }
  
  .js-mega-menu::after {
    display: none; /* Remove bridge on mobile */
  }
}

/* Alternative positioning for specific menu items if needed */
.js-mega-menu.align-left .js-mega-dropdown {
  left: 0 !important;
  transform: none !important;
}

.js-mega-menu.align-right .js-mega-dropdown {
  right: 0 !important;
  left: auto !important;
  transform: none !important;
}
