/**
 * Mountain Mojo Divi Mobile Menu Enhancer
 * Mobile-only styling for Divi menu module/header mobile menus.
 */

@media (max-width: 980px) {
  /* Pre-JS hamburger styling prevents the default Divi icon from flashing on initial page load. */
  body .et_mobile_nav_menu .mobile_nav .mobile_menu_bar {
    position: relative;
    width: 52px;
    height: 52px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border: 2px solid #D40029;
    border-radius: 0;
    background: #000;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 1 !important;
    cursor: pointer;
    transition: transform 220ms ease, background-color 220ms ease, border-color 220ms ease;
    isolation: isolate;
  }

  body .et_mobile_nav_menu .mobile_nav .mobile_menu_bar:hover,
  body .et_mobile_nav_menu .mobile_nav .mobile_menu_bar:focus-visible {
    background: #D40029;
    border-color: #fff;
    outline: none;
    transform: translateY(-1px);
  }

  body .et_mobile_nav_menu .mobile_nav .mobile_menu_bar::before,
  body .et_mobile_nav_menu .mobile_nav .mobile_menu_bar::after {
    content: '' !important;
    position: absolute !important;
    left: 50% !important;
    width: 24px;
    height: 2px;
    display: block !important;
    background: #fff;
    border-radius: 0;
    font-family: inherit !important;
    speak: none;
    transform: translateX(-50%);
    transition: top 220ms ease, transform 220ms ease, box-shadow 220ms ease;
  }

  body .et_mobile_nav_menu .mobile_nav .mobile_menu_bar::before {
    top: 17px;
    box-shadow: 0 8px 0 #fff;
  }

  body .et_mobile_nav_menu .mobile_nav .mobile_menu_bar::after {
    top: 33px;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced {
    position: relative;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mobile_menu_bar {
    width: 52px;
    height: 52px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border: 2px solid #D40029;
    border-radius: 0;
    background: #000;
    cursor: pointer;
    transition: transform 220ms ease, background-color 220ms ease, border-color 220ms ease;
    isolation: isolate;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mobile_menu_bar:hover,
  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mobile_menu_bar:focus-visible {
    background: #D40029;
    border-color: #fff;
    outline: none;
    transform: translateY(-1px);
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mobile_menu_bar::before,
  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mobile_menu_bar::after {
    content: none !important;
    display: none !important;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced.mmg-menu-open .mobile_menu_bar,
  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced.opened .mobile_menu_bar {
    background: #D40029;
    border-color: #fff;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mmg-hamburger-lines {
    position: relative;
    width: 24px;
    height: 18px;
    display: block;
    pointer-events: none;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mmg-hamburger-lines span {
    position: absolute;
    left: 0;
    width: 24px;
    height: 2px;
    background: #fff;
    border-radius: 0;
    transform-origin: center;
    transition: top 220ms ease, transform 220ms ease, opacity 160ms ease, width 220ms ease;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mmg-hamburger-lines span:nth-child(1) {
    top: 0;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mmg-hamburger-lines span:nth-child(2) {
    top: 8px;
    width: 18px;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mmg-hamburger-lines span:nth-child(3) {
    top: 16px;
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced.mmg-menu-open .mmg-hamburger-lines span:nth-child(1),
  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced.opened .mmg-hamburger-lines span:nth-child(1) {
    top: 8px;
    transform: rotate(45deg);
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced.mmg-menu-open .mmg-hamburger-lines span:nth-child(2),
  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced.opened .mmg-hamburger-lines span:nth-child(2) {
    opacity: 0;
    transform: translateX(8px);
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced.mmg-menu-open .mmg-hamburger-lines span:nth-child(3),
  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced.opened .mmg-hamburger-lines span:nth-child(3) {
    top: 8px;
    transform: rotate(-45deg);
  }

  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mobile_menu_bar:focus-visible,
  body .mmg-divi-mobile-panel .mmg-submenu-toggle:focus-visible,
  body .mmg-divi-mobile-panel a:focus-visible {
    outline: none;
    box-shadow: inset 0 0 0 2px #fff, inset 0 0 0 4px #D40029;
  }

  body .mmg-divi-mobile-panel.et_mobile_menu {
    display: none !important;
    position: fixed !important;
    top: var(--mmg-mobile-menu-top, 82px) !important;
    left: max(12px, env(safe-area-inset-left)) !important;
    right: max(12px, env(safe-area-inset-right)) !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    max-height: calc(100dvh - var(--mmg-mobile-menu-top, 82px) - 14px) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 10px 0 !important;
    border: 2px solid #D40029 !important;
    border-radius: 0 !important;
    background: #000 !important;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.38) !important;
    z-index: 999999 !important;
    overscroll-behavior: contain;
  }

  body .mmg-divi-mobile-panel.et_mobile_menu.mmg-menu-open {
    display: block !important;
    animation: mmgMobileMenuIn 220ms ease both;
  }

  body.admin-bar .mmg-divi-mobile-panel.et_mobile_menu {
    max-height: calc(100dvh - var(--mmg-mobile-menu-top, 82px) - 46px) !important;
  }

  body .mmg-divi-mobile-panel,
  body .mmg-divi-mobile-panel ul,
  body .mmg-divi-mobile-panel li {
    list-style: none !important;
  }

  body .mmg-divi-mobile-panel li {
    position: relative;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  body .mmg-divi-mobile-panel > li + li {
    border-top: 1px solid rgba(255, 255, 255, 0.13) !important;
  }

  body .mmg-divi-mobile-panel a {
    color: #fff !important;
    background: transparent !important;
    border: 0 !important;
    opacity: 1 !important;
    font-weight: 700;
    line-height: 1.25;
    text-decoration: none;
    transition: color 180ms ease, background-color 180ms ease, padding-left 180ms ease;
  }

  body .mmg-divi-mobile-panel > li > a {
    min-height: 52px;
    display: flex !important;
    align-items: center;
    padding: 15px 62px 15px 20px !important;
    font-size: 17px;
  }

  body .mmg-divi-mobile-panel > li:not(.menu-item-has-children) > a,
  body .mmg-divi-mobile-panel > li:not(.mmg-has-toggle) > a {
    padding-right: 20px !important;
  }

  body .mmg-divi-mobile-panel a:hover,
  body .mmg-divi-mobile-panel a:focus-visible {
    color: #fff !important;
    background: #D40029 !important;
    outline: none;
  }

  body .mmg-divi-mobile-panel .mmg-submenu-toggle {
    position: absolute;
    top: 7px;
    right: 10px;
    width: 42px;
    height: 42px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, 0.32);
    border-radius: 0;
    background: #fff;
    color: #000;
    cursor: pointer;
    z-index: 3;
    padding: 0 !important;
    transition: transform 180ms ease, background-color 180ms ease, color 180ms ease, border-color 180ms ease;
  }

  body .mmg-divi-mobile-panel .mmg-submenu-toggle:hover,
  body .mmg-divi-mobile-panel .mmg-submenu-toggle[aria-expanded='true'] {
    background: #D40029;
    border-color: #D40029;
    color: #fff;
  }

  body .mmg-divi-mobile-panel .mmg-submenu-toggle::before,
  body .mmg-divi-mobile-panel .mmg-submenu-toggle::after {
    content: '';
    position: absolute;
    width: 14px;
    height: 2px;
    background: currentColor;
    border-radius: 0;
    transition: transform 180ms ease;
  }

  body .mmg-divi-mobile-panel .mmg-submenu-toggle::after {
    transform: rotate(90deg);
  }

  body .mmg-divi-mobile-panel .mmg-submenu-toggle[aria-expanded='true']::after {
    transform: rotate(0deg);
  }

  body .mmg-divi-mobile-panel .sub-menu,
  body .mmg-divi-mobile-panel li.menu-item-has-children > .sub-menu {
    display: none !important;
    margin: 0 !important;
    padding: 4px 0 12px 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: rgba(255, 255, 255, 0.06) !important;
  }

  body .mmg-divi-mobile-panel li.mmg-submenu-open > .sub-menu {
    display: block !important;
    animation: mmgSubmenuIn 180ms ease both;
  }

  body .mmg-divi-mobile-panel .sub-menu li + li {
    border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
  }

  body .mmg-divi-mobile-panel .sub-menu a {
    display: block !important;
    padding: 12px 18px 12px 34px !important;
    color: rgba(255, 255, 255, 0.92) !important;
    font-size: 15px;
    font-weight: 600;
  }

  body .mmg-divi-mobile-panel .sub-menu a::before {
    content: '';
    display: inline-block;
    width: 7px;
    height: 7px;
    margin-right: 10px;
    border-radius: 0;
    background: #D40029;
    transform: translateY(-1px);
  }

  body .mmg-divi-mobile-panel li.mmg-submenu-open > a {
    background: #D40029 !important;
  }
}

@keyframes mmgMobileMenuIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }

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

@keyframes mmgSubmenuIn {
  from {
    opacity: 0;
    transform: translateY(-6px);
  }

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

@media (max-width: 980px) and (prefers-reduced-motion: reduce) {
  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mobile_menu_bar,
  body .et_mobile_nav_menu .mobile_nav.mmg-mobile-nav-enhanced .mobile_menu_bar *,
  body .mmg-divi-mobile-panel,
  body .mmg-divi-mobile-panel *,
  body .mmg-divi-mobile-panel .mmg-submenu-toggle,
  body .mmg-divi-mobile-panel .mmg-submenu-toggle::before,
  body .mmg-divi-mobile-panel .mmg-submenu-toggle::after {
    animation: none !important;
    transition: none !important;
  }
}
