/**
 * @file
 * Dynamic menu styling for horizontal menu with dropdowns.
 * Includes responsive mobile menu with hamburger toggle.
 */

/* Reset and base styles for all menus */
.region-header .menu {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.gin-secondary-toolbar {
  margin-top: 57px !important;
}

/* ============================================
   DESKTOP STYLES (768px and above)
   ============================================ */

@media (min-width: 768px) {
  /* Hide mobile menu toggle on desktop */
  .mobile-menu-toggle {
    display: none !important;
  }


  /* FORCE horizontal layout for root menu ONLY - multiple selectors for higher specificity */
  .region-header nav > .menu,
  .region-header .block > .menu,
  .region-header div[id*="block"] > .menu {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    background: linear-gradient(135deg, #4a6fa5 0%, #5a7fb5 100%) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
    border-radius: 6px !important;
    padding: 0 !important;
  }

/* Always sticky menu wrapper */
.region-header nav,
.region-header .block,
.region-header div[id*="block"] {
  position: fixed !important;
  top: 60px !important;
  left: auto !important;
  right: auto !important;
  z-index: 200 !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25) !important;
  width: auto !important;
}

/* Adjust top position when admin toolbar is horizontal */
body.toolbar-horizontal .region-header nav,
body.toolbar-horizontal .region-header .block,
body.toolbar-horizontal .region-header div[id*="block"] {
  top: 60px !important;
}

/* Adjust top position when admin toolbar is vertical (sidebar) */
body.toolbar-vertical .region-header nav,
body.toolbar-vertical .region-header .block,
body.toolbar-vertical .region-header div[id*="block"] {
  top: 0 !important;
}


/* First level menu items */
.region-header nav .menu > .menu-item,
.region-header .block .menu > .menu-item,
.region-header div[id*="block"] > .menu > .menu-item {
  position: relative !important;
  margin: 0 !important;
  padding: 0 !important;
  border-right: 1px solid rgba(255, 255, 255, 0.2) !important;
  display: block !important;
  float: none !important;
  transition: background-color 0.2s ease !important;
}

.region-header nav .menu > .menu-item:first-child,
.region-header .block .menu > .menu-item:first-child,
.region-header div[id*="block"] > .menu > .menu-item:first-child {
  border-top-left-radius: 6px !important;
  border-bottom-left-radius: 6px !important;
}

.region-header nav .menu > .menu-item:last-child,
.region-header .block .menu > .menu-item:last-child,
.region-header div[id*="block"] > .menu > .menu-item:last-child {
  border-right: none !important;
  border-top-right-radius: 6px !important;
  border-bottom-right-radius: 6px !important;
}

/* Styling for both links and spans in first level */
.region-header nav .menu > .menu-item > a,
.region-header nav .menu > .menu-item > span,
.region-header .block .menu > .menu-item > a,
.region-header .block .menu > .menu-item > span,
.region-header div[id*="block"] > .menu > .menu-item > a,
.region-header div[id*="block"] > .menu > .menu-item > span {
  display: block !important;
  padding: 12px 20px !important;
  text-decoration: none !important;
  color: #ffffff !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  font-weight: 500 !important;
  transition: all 0.2s ease !important;
}

/* Arrow indicator for items with children */
.region-header .menu-item--expanded > a::after,
.region-header .menu-item--expanded > span::after {
  content: ' ▼' !important;
  font-size: 0.7em !important;
  margin-left: 8px !important;
  opacity: 0.8 !important;
}

/* FORCE hide all nested menus by default */
.region-header .menu .menu {
  display: none !important;
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  min-width: 220px !important;
  z-index: 10002 !important;
  background: #ffffff !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
  border-radius: 4px !important;
  overflow: visible !important;
  margin-top: -2px !important;
  flex-direction: column !important;
  height: auto !important;
  max-height: none !important;
  clip: auto !important;
  clip-path: none !important;
}

/* FORCE show first level nested menu on hover - MAXIMUM SPECIFICITY */
.region-header nav .menu > .menu-item:hover > .menu,
.region-header nav .menu > .menu-item.menu-item--expanded:hover > .menu,
.region-header .block .menu > .menu-item:hover > .menu,
.region-header .block .menu > .menu-item.menu-item--expanded:hover > .menu,
.region-header div[id*="block"] > .menu > .menu-item:hover > .menu,
.region-header div[id*="block"] > .menu > .menu-item.menu-item--expanded:hover > .menu,
.region-header nav > .menu > .menu-item:hover > .menu,
.region-header nav > .menu > .menu-item.menu-item--expanded:hover > .menu,
.region-header .block > .menu > .menu-item:hover > .menu,
.region-header .block > .menu > .menu-item.menu-item--expanded:hover > .menu,
.region-header nav > .menu > .menu-item:hover > ul.menu,
.region-header .block > .menu > .menu-item:hover > ul.menu {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* FORCE show deeper nested menus on hover - MAXIMUM SPECIFICITY */
.region-header .menu .menu .menu-item:hover > .menu,
.region-header .menu .menu .menu-item.menu-item--expanded:hover > .menu,
.region-header .menu .menu .menu-item:hover > ul.menu,
.region-header .menu .menu .menu-item.menu-item--expanded:hover > ul.menu,
.region-header .menu ul.menu .menu-item:hover > ul.menu,
.region-header .menu ul.menu .menu-item.menu-item--expanded:hover > ul.menu {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Nested menu items styling */
.region-header .menu .menu .menu-item {
  position: relative !important;
  border-bottom: 1px solid #e8e8e8 !important;
  display: block !important;
  width: 100% !important;
  transition: background-color 0.2s ease !important;
}

.region-header .menu .menu .menu-item:last-child {
  border-bottom: none !important;
}

/* Styling for both links and spans in nested items */
.region-header .menu .menu .menu-item > a,
.region-header .menu .menu .menu-item > span {
  display: block !important;
  padding: 12px 18px !important;
  text-decoration: none !important;
  color: #333333 !important;
  cursor: pointer !important;
  width: 100% !important;
  box-sizing: border-box !important;
  font-weight: 400 !important;
  transition: all 0.2s ease !important;
}

/* Arrow for nested items with children - point right */
.region-header .menu .menu .menu-item--expanded > a::after,
.region-header .menu .menu .menu-item--expanded > span::after {
  content: ' ▶' !important;
  font-size: 0.7em !important;
  margin-left: 8px !important;
  float: right !important;
  opacity: 0.6 !important;
}

/* Position deeper nested menus to the right */
.region-header .menu .menu .menu {
  top: -2px !important;
  left: calc(100% - 2px) !important;
  margin-top: 0 !important;
}

/* Show all nested menus on hover - multiple rules for maximum compatibility */
.region-header .menu .menu .menu-item:hover > .menu,
.region-header .menu .menu .menu-item:hover > ul.menu {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.region-header .menu .menu-item:hover > .menu,
.region-header .menu .menu-item:hover > ul.menu {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Keep parent menu visible when hovering over child - all levels */
.region-header .menu-item--expanded:hover > .menu,
.region-header .menu-item--expanded > .menu:hover,
.region-header .menu .menu-item--expanded:hover > .menu,
.region-header .menu .menu-item--expanded > .menu:hover,
.region-header .menu-item--expanded:hover > ul.menu,
.region-header .menu-item--expanded > ul.menu:hover,
.region-header .menu .menu-item--expanded:hover > ul.menu,
.region-header .menu .menu-item--expanded > ul.menu:hover {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Keep nested submenus visible when hovering */
.region-header .menu .menu:hover,
.region-header .menu ul.menu:hover {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Ensure pointer events work on nested menus */
.region-header .menu .menu,
.region-header .menu ul.menu {
  pointer-events: auto !important;
}

.region-header .menu .menu-item:hover > .menu,
.region-header .menu .menu-item:hover > ul.menu {
  pointer-events: auto !important;
}

/* Hover effects for first level */
.region-header nav .menu > .menu-item:hover,
.region-header .block .menu > .menu-item:hover,
.region-header div[id*="block"] > .menu > .menu-item:hover {
  background-color: rgba(255, 255, 255, 0.15) !important;
}

.region-header nav .menu > .menu-item > a:hover,
.region-header nav .menu > .menu-item > span:hover,
.region-header .block .menu > .menu-item > a:hover,
.region-header .block .menu > .menu-item > span:hover,
.region-header div[id*="block"] > .menu > .menu-item > a:hover,
.region-header div[id*="block"] > .menu > .menu-item > span:hover {
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

/* Hover effects for nested items */
.region-header .menu .menu .menu-item:hover {
  background-color: #f0f5fa !important;
}

.region-header .menu .menu .menu-item > a:hover,
.region-header .menu .menu .menu-item > span:hover {
  color: #4a6fa5 !important;
  padding-left: 22px !important;
}

/* Active trail styling */
.region-header .menu-item--active-trail > a,
.region-header nav .menu > .menu-item--active-trail > a,
.region-header .block .menu > .menu-item--active-trail > a,
.region-header div[id*="block"] > .menu > .menu-item--active-trail > a {
  background-color: rgba(255, 255, 255, 0.2) !important;
  font-weight: 600 !important;
}

.region-header .menu .menu .menu-item--active-trail > a {
  color: #4a6fa5 !important;
  font-weight: 600 !important;
  background-color: #f0f5fa !important;
}

/* NUCLEAR OPTION - Force nested menus to display with absolute maximum specificity */
html body .region-header nav .menu > li.menu-item--expanded:hover > ul.menu,
html body .region-header .block .menu > li.menu-item--expanded:hover > ul.menu,
html body .region-header [id*="block"] > ul.menu > li.menu-item--expanded:hover > ul.menu,
html body .region-header nav > ul.menu > li.menu-item--expanded:hover > ul.menu,
html body .region-header .block > ul.menu > li.menu-item--expanded:hover > ul.menu {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  height: auto !important;
  overflow: visible !important;
  clip: auto !important;
  clip-path: none !important;
}

/* NUCLEAR OPTION - Force deeper nested menus */
html body .region-header ul.menu ul.menu li.menu-item--expanded:hover > ul.menu,
html body .region-header .menu .menu li.menu-item--expanded:hover > ul.menu,
html body .region-header ul.menu li.menu-item:hover > ul.menu {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  height: auto !important;
  overflow: visible !important;
  clip: auto !important;
  clip-path: none !important;
  max-height: none !important;
}

} /* End of desktop media query (min-width: 768px) */

/* ============================================
   MOBILE STYLES (below 768px)
   ============================================ */

@media (max-width: 767px) {
  /* Mobile menu toggle button (hamburger icon) */
  .mobile-menu-toggle {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    background: linear-gradient(135deg, #4a6fa5 0%, #5a7fb5 100%) !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    padding: 0 !important;
    margin-left: 15px !important;
    position: relative !important;
    z-index: 10003 !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
    transition: background-color 0.3s ease !important;
  }

  .mobile-menu-toggle:hover {
    background: linear-gradient(135deg, #5a7fb5 0%, #6a8fc5 100%) !important;
  }

  /* Hamburger icon - three horizontal lines */
  .mobile-menu-toggle .hamburger {
    width: 24px !important;
    height: 18px !important;
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
  }

  .mobile-menu-toggle .hamburger span {
    display: block !important;
    width: 100% !important;
    height: 3px !important;
    background: #ffffff !important;
    border-radius: 2px !important;
    transition: all 0.3s ease !important;
  }

  /* Animate hamburger to X when menu is open */
  .mobile-menu-toggle.active .hamburger span:nth-child(1) {
    transform: translateY(7.5px) rotate(45deg) !important;
  }

  .mobile-menu-toggle.active .hamburger span:nth-child(2) {
    opacity: 0 !important;
  }

  .mobile-menu-toggle.active .hamburger span:nth-child(3) {
    transform: translateY(-7.5px) rotate(-45deg) !important;
  }

  /* Hide menu wrapper positioning on mobile */
  .region-header nav,
  .region-header .block,
  .region-header div[id*="block"] {
    position: fixed !important;
    top: 60px !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 10001 !important;
    width: 100% !important;
    max-width: 100% !important;
    box-shadow: none !important;
  }

  /* Mobile menu container - hidden by default */
  .region-header nav > .menu,
  .region-header .block > .menu,
  .region-header div[id*="block"] > .menu {
    display: none !important;
    position: fixed !important;
    top: 104px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: #ffffff !important;
    flex-direction: column !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow-y: auto !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25) !important;
    border-radius: 0 !important;
    z-index: 10000 !important;
  }

  /* Show menu when toggle is active */
  .region-header nav.mobile-menu-open > .menu,
  .region-header .block.mobile-menu-open > .menu,
  .region-header div[id*="block"].mobile-menu-open > .menu {
    display: flex !important;
  }

  /* First level menu items - vertical layout */
  .region-header nav .menu > .menu-item,
  .region-header .block .menu > .menu-item,
  .region-header div[id*="block"] > .menu > .menu-item {
    position: relative !important;
    margin: 0 !important;
    padding: 0 !important;
    border-bottom: 1px solid #e8e8e8 !important;
    border-right: none !important;
    border-radius: 0 !important;
    display: block !important;
    width: 100% !important;
  }

  .region-header nav .menu > .menu-item:first-child,
  .region-header .block .menu > .menu-item:first-child,
  .region-header div[id*="block"] > .menu > .menu-item:first-child {
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
  }

  .region-header nav .menu > .menu-item:last-child,
  .region-header .block .menu > .menu-item:last-child,
  .region-header div[id*="block"] > .menu > .menu-item:last-child {
    border-bottom: none !important;
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
  }

  /* First level links and spans */
  .region-header nav .menu > .menu-item > a,
  .region-header nav .menu > .menu-item > span,
  .region-header .block .menu > .menu-item > a,
  .region-header .block .menu > .menu-item > span,
  .region-header div[id*="block"] > .menu > .menu-item > a,
  .region-header div[id*="block"] > .menu > .menu-item > span {
    display: block !important;
    padding: 16px 20px !important;
    text-decoration: none !important;
    color: #333333 !important;
    white-space: normal !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    font-size: 16px !important;
    background: #ffffff !important;
    transition: background-color 0.2s ease !important;
  }

  /* Hover/active state for first level items */
  .region-header nav .menu > .menu-item:hover,
  .region-header .block .menu > .menu-item:hover,
  .region-header div[id*="block"] > .menu > .menu-item:hover {
    background-color: #f0f5fa !important;
  }

  .region-header nav .menu > .menu-item > a:hover,
  .region-header nav .menu > .menu-item > span:hover,
  .region-header .block .menu > .menu-item > a:hover,
  .region-header .block .menu > .menu-item > span:hover,
  .region-header div[id*="block"] > .menu > .menu-item > a:hover,
  .region-header div[id*="block"] > .menu > .menu-item > span:hover {
    background-color: #f0f5fa !important;
    color: #4a6fa5 !important;
  }

  /* Arrow indicator for items with children - points right when closed */
  .region-header .menu-item--expanded > a::after,
  .region-header .menu-item--expanded > span::after {
    content: ' ▶' !important;
    font-size: 0.8em !important;
    margin-left: 8px !important;
    float: right !important;
    opacity: 0.6 !important;
    transition: transform 0.3s ease !important;
  }

  /* Arrow points down when expanded */
  .region-header .menu-item--expanded.mobile-submenu-open > a::after,
  .region-header .menu-item--expanded.mobile-submenu-open > span::after {
    transform: rotate(90deg) !important;
  }

  /* Nested menus - accordion style, hidden by default */
  .region-header .menu .menu {
    display: none !important;
    position: static !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #f9f9f9 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    overflow: visible !important;
    width: 100% !important;
    z-index: auto !important;
  }

  /* Show nested menu when parent has mobile-submenu-open class - MAXIMUM SPECIFICITY */
  html body .region-header .menu-item--expanded.mobile-submenu-open > .menu,
  html body .region-header .menu-item--expanded.mobile-submenu-open > ul.menu,
  html body .region-header li.menu-item--expanded.mobile-submenu-open > .menu,
  html body .region-header li.menu-item--expanded.mobile-submenu-open > ul.menu,
  html body .region-header .menu .menu-item--expanded.mobile-submenu-open > .menu,
  html body .region-header .menu .menu-item--expanded.mobile-submenu-open > ul.menu,
  html body .region-header .menu li.menu-item--expanded.mobile-submenu-open > ul.menu,
  html body .region-header nav .menu-item--expanded.mobile-submenu-open > .menu,
  html body .region-header .block .menu-item--expanded.mobile-submenu-open > .menu {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  /* Nested menu items */
  .region-header .menu .menu .menu-item {
    position: relative !important;
    border-bottom: 1px solid #e0e0e0 !important;
    display: block !important;
    width: 100% !important;
    background: #f9f9f9 !important;
  }

  .region-header .menu .menu .menu-item:last-child {
    border-bottom: none !important;
  }

  /* Nested menu links and spans */
  .region-header .menu .menu .menu-item > a,
  .region-header .menu .menu .menu-item > span {
    display: block !important;
    padding: 14px 20px 14px 40px !important;
    text-decoration: none !important;
    color: #555555 !important;
    cursor: pointer !important;
    width: 100% !important;
    box-sizing: border-box !important;
    font-weight: 400 !important;
    font-size: 15px !important;
    background: #f9f9f9 !important;
    transition: all 0.2s ease !important;
  }

  /* Deeper nested items - increase indentation */
  .region-header .menu .menu .menu .menu-item > a,
  .region-header .menu .menu .menu .menu-item > span {
    padding-left: 60px !important;
    background: #f4f4f4 !important;
  }

  /* Even deeper nesting */
  .region-header .menu .menu .menu .menu .menu-item > a,
  .region-header .menu .menu .menu .menu .menu-item > span {
    padding-left: 80px !important;
    background: #efefef !important;
  }

  /* Hover effects for nested items */
  .region-header .menu .menu .menu-item:hover {
    background-color: #e8f0f8 !important;
  }

  .region-header .menu .menu .menu-item > a:hover,
  .region-header .menu .menu .menu-item > span:hover {
    color: #4a6fa5 !important;
    background-color: #e8f0f8 !important;
  }

  /* Active trail styling for mobile */
  .region-header .menu-item--active-trail > a,
  .region-header nav .menu > .menu-item--active-trail > a,
  .region-header .block .menu > .menu-item--active-trail > a,
  .region-header div[id*="block"] > .menu > .menu-item--active-trail > a {
    background-color: #e8f0f8 !important;
    color: #4a6fa5 !important;
    font-weight: 600 !important;
  }

  .region-header .menu .menu .menu-item--active-trail > a {
    color: #4a6fa5 !important;
    font-weight: 600 !important;
    background-color: #e8f0f8 !important;
  }

  /* Disable hover-based dropdown on mobile */
  .region-header .menu-item--expanded:hover > .menu,
  .region-header .menu-item--expanded > .menu:hover,
  .region-header .menu .menu-item--expanded:hover > .menu,
  .region-header .menu .menu-item--expanded > .menu:hover {
    display: none !important;
  }

  /* IMPORTANT: Only show when explicitly opened with mobile-submenu-open class - MUST COME AFTER HOVER RULES */
  /* Maximum specificity to override everything including hover rules above */
  html body .region-header .menu-item--expanded.mobile-submenu-open > .menu,
  html body .region-header .menu-item--expanded.mobile-submenu-open > ul.menu,
  html body .region-header li.menu-item--expanded.mobile-submenu-open > .menu,
  html body .region-header li.menu-item--expanded.mobile-submenu-open > ul.menu,
  html body .region-header .menu .menu-item--expanded.mobile-submenu-open > .menu,
  html body .region-header .menu .menu-item--expanded.mobile-submenu-open > ul.menu,
  html body .region-header .menu li.menu-item--expanded.mobile-submenu-open > ul.menu,
  html body .region-header nav .menu-item--expanded.mobile-submenu-open > .menu,
  html body .region-header .block .menu-item--expanded.mobile-submenu-open > .menu {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }
}
