/* =========================================
   JOOMLA 6 MENU DESIGN BASE - FINAL
   Reusable Version
========================================= */

html,
body {
  overflow-x: hidden !important;
}

/* Header / Navbar */
.container-header .container-nav,
.container-nav {
  background: #24324f !important;
}

.container-header .navbar {
  padding: 0 15px !important;
}

/* Main Menu */
.container-header .metismenu.mod-menu {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Reset Joomla default spacing */
.container-header .metismenu.mod-menu .metismenu-item {
  padding: 0 !important;
  margin: 0 !important;
  line-height: 1 !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
}

/* Main menu links */
.container-header .metismenu-item.level-1 > a,
.container-header .metismenu-item.level-1 > button {
  min-height: 58px !important;
  padding: 0 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px;
  color: #ffffff !important;
  background: transparent !important;
  border: 0 !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  cursor: pointer;
  transition: background-color .18s ease, color .18s ease;
}

/* Hover / active */
.container-header .metismenu-item.level-1 > a:hover,
.container-header .metismenu-item.level-1 > button:hover {
  color: #ffffff !important;
  background: rgba(255,255,255,.08) !important;
}

.container-header .metismenu-item.level-1.current > a,
.container-header .metismenu-item.level-1.active > a,
.container-header .metismenu-item.level-1.current > button,
.container-header .metismenu-item.level-1.active > button {
  color: #ffffff !important;
  background: rgba(255,255,255,.06) !important;
}

/* Joomla MetisMenu arrows */
.container-header .mm-toggler,
.container-header .mm-toggler-link,
.container-header .mm-toggler-nolink {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  color: inherit !important;
  box-shadow: none !important;
}

.container-header .mm-toggler::after,
.container-header .mm-toggler-link::after,
.container-header .mm-toggler-nolink::after {
  content: "" !important;
  display: inline-block !important;
  width: 6px !important;
  height: 6px !important;
  margin-left: 6px !important;
  border: solid currentColor !important;
  border-width: 0 2px 2px 0 !important;
  transform: rotate(45deg) translateY(-2px) !important;
  transition: transform .18s ease;
}

.container-header .mm-toggler[aria-expanded="true"]::after,
.container-header .mm-toggler-link[aria-expanded="true"]::after,
.container-header .mm-toggler-nolink[aria-expanded="true"]::after {
  transform: rotate(-135deg) translateY(-1px) !important;
}

/* Desktop dropdown */
@media (min-width: 992px) {

  /* Default compact dropdown */
  .container-header .metismenu-item.level-1 > ul {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: auto !important;

    display: grid !important;
    grid-template-columns: 1fr !important;

    width: max-content !important;
    min-width: 240px !important;
    max-width: calc(100vw - 40px) !important;

    padding: 14px !important;
    margin: 0 !important;

    background: #ffffff !important;
    border: 0 !important;
    border-radius: 0 0 14px 14px !important;
    box-shadow:
      0 12px 30px rgba(15,23,42,.14),
      0 2px 8px rgba(15,23,42,.06) !important;

    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(8px);
    transition: opacity .18s ease, transform .18s ease, visibility .18s ease;

    height: auto !important;
    overflow: hidden !important;
    z-index: 2000;
  }

  .container-header .metismenu-item.level-1:hover > ul,
  .container-header .metismenu-item.level-1:focus-within > ul {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
  }

  .container-header .metismenu-item.level-1 > ul.mm-collapse {
    height: auto !important;
  }

  /* 7+ submenu items = automatic mega menu */
  .container-header .metismenu-item.level-1 > ul:has(> li:nth-child(7)) {
    width: 860px !important;
    max-width: calc(100vw - 80px) !important;
    grid-template-columns: repeat(3, minmax(240px, 1fr)) !important;
    gap: 6px 14px !important;
    padding: 18px !important;
  }

  /* Right side protection */
  .container-header .metismenu-item.level-1:nth-last-child(-n+3) > ul {
    left: auto !important;
    right: 0 !important;
  }

  /* Dropdown links */
  .container-header .metismenu-item.level-2 {
    list-style: none;
    margin: 0 !important;
    padding: 0 !important;
  }

  .container-header .metismenu-item.level-2 > a {
    display: block !important;
    padding: 9px 10px !important;
    border-radius: 8px;
    color: #24313a !important;
    font-size: 14px !important;
    font-weight: 500;
    line-height: 1.28;
    text-decoration: none !important;
    white-space: normal !important;
    transition: background-color .16s ease, color .16s ease, transform .16s ease;
  }

  .container-header .metismenu-item.level-2 > a:hover {
    background: #eef4ff !important;
    color: #1f3b73 !important;
    transform: translateX(2px);
  }

  /* Remove focus outline box */
  .container-header .metismenu-item.level-1 > a:focus,
  .container-header .metismenu-item.level-1 > button:focus,
  .container-header .metismenu-item.level-1 > a:focus-visible,
  .container-header .metismenu-item.level-1 > button:focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }
}

/* Mobile */
@media (max-width: 991.98px) {

  .container-header .container-nav {
    padding: 8px 15px !important;
    background: #24324f !important;
  }

  .container-header .navbar-toggler {
    margin-left: auto;
    border: 1px solid rgba(255,255,255,.35) !important;
    border-radius: 10px;
    padding: 8px 10px;
    color: #ffffff !important;
    background: rgba(255,255,255,.08) !important;
  }

  .container-header .navbar-collapse {
    margin-top: 10px;
    background: #ffffff;
    border-radius: 14px;
    box-shadow:
      0 12px 28px rgba(0,0,0,.12),
      0 2px 8px rgba(0,0,0,.05);
    overflow: hidden;
  }

  .container-header .metismenu.mod-menu {
    display: block !important;
    padding: 8px !important;
  }

  .container-header .metismenu.mod-menu .metismenu-item,
  .container-header .metismenu-item.level-1 {
    display: block !important;
    width: 100%;
  }

  .container-header .metismenu-item.level-1 > a,
  .container-header .metismenu-item.level-1 > button {
    width: 100%;
    min-height: 46px !important;
    padding: 12px 14px !important;
    justify-content: space-between !important;
    border-radius: 10px;
    color: #172026 !important;
  }

  .container-header .metismenu-item.level-1 > a:hover,
  .container-header .metismenu-item.level-1 > button:hover,
  .container-header .metismenu-item.level-1.current > a,
  .container-header .metismenu-item.level-1.active > a,
  .container-header .metismenu-item.level-1.current > button,
  .container-header .metismenu-item.level-1.active > button {
    background: #eef4ff !important;
    color: #1f3b73 !important;
  }

  .container-header .metismenu-item.level-1.deeper.parent {
    display: block !important;
  }

  .container-header .metismenu-item.level-1.deeper.parent > a {
    width: calc(100% - 44px);
    justify-content: flex-start !important;
  }

  .container-header .metismenu-item.level-1.deeper.parent > .mm-toggler-link {
    width: 40px !important;
    min-height: 46px !important;
    float: right;
    color: #172026 !important;
    padding: 0 !important;
  }

  .container-header .metismenu-item.level-1 > ul {
    position: static !important;
    width: 100% !important;
    padding: 6px 0 8px 12px !important;
    margin: 0 !important;
    background: #f8fbfc !important;
    border-radius: 10px;
    box-shadow: none !important;
    border: 0 !important;
  }

  .container-header .metismenu-item.level-2 > a {
    display: block !important;
    padding: 10px 12px !important;
    color: #24313a !important;
    font-size: 14px !important;
    text-decoration: none !important;
    border-radius: 8px;
  }

  .container-header .metismenu-item.level-2.current > a,
  .container-header .metismenu-item.level-2.active > a,
  .container-header .metismenu-item.level-2 > a:hover {
    background: #eef4ff !important;
    color: #1f3b73 !important;
    font-weight: 500 !important;
  }
}

/* Safe Num2Word-style header fix */
.container-header,
.container-header > .grid-child:first-child {
  background: #ffffff !important;
}

.container-header > .grid-child:first-child {
  max-width: 1180px;
  margin: 0 auto;
  padding: 14px 15px 10px !important;
  justify-content: flex-start !important;
}

.container-header .navbar-brand {
  margin: 0 !important;
}

.container-header .site-title,
.container-header .navbar-brand a {
  color: #d9a520 !important;
  font-size: 40px !important;
  font-weight: 800 !important;
  line-height: 1.05 !important;
  text-decoration: none !important;
}

/* Keep menu visible */
.container-header .container-nav {
  background: #24324f !important;
  padding: 0 !important;
}