/**
 * ModernMenu Frontend Styles
 */

/* Reset - High specificity to override theme styles */
.modern-menu-wrapper,
.modern-menu-wrapper *,
.modern-menu-mobile,
.modern-menu-mobile *,
.modern-menu-wrapper *::before,
.modern-menu-wrapper *::after,
.modern-menu-mobile *::before,
.modern-menu-mobile *::after {
    box-sizing: border-box !important;
}

/* Remove all list styling */
.modern-menu-wrapper ul,
.modern-menu-wrapper ol,
.modern-menu-wrapper li,
.modern-menu-mobile ul,
.modern-menu-mobile ol,
.modern-menu-mobile li,
.modern-menu-wrapper .modern-menu-list,
.modern-menu-wrapper .modern-menu-submenu,
.modern-menu-mobile .modern-menu-list,
.modern-menu-mobile .modern-menu-submenu,
ul.modern-menu-list,
ul.modern-menu-submenu,
.modern-menu-nav ul,
.modern-menu-nav li,
.modern-menu-mobile-nav ul,
.modern-menu-mobile-nav li {
    list-style: none !important;
    list-style-type: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.modern-menu-wrapper li::before,
.modern-menu-wrapper li::after,
.modern-menu-wrapper li::marker,
.modern-menu-mobile li::before,
.modern-menu-mobile li::after,
.modern-menu-mobile li::marker,
.modern-menu-list li::before,
.modern-menu-list li::marker,
.modern-menu-submenu li::before,
.modern-menu-submenu li::marker {
    content: none !important;
    display: none !important;
}

/* ========================================
   DESKTOP MENU
   ======================================== */

.modern-menu-wrapper {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    padding: var(--mm-desktop-padding-top, 15px) var(--mm-desktop-padding-right, 30px) var(--mm-desktop-padding-bottom, 15px) var(--mm-desktop-padding-left, 30px);
    background: var(--mm-desktop-bg, #ffffff);
    position: relative;
    font-family: var(--mm-desktop-font, inherit);
    font-weight: var(--mm-desktop-font-weight, 400);
    font-size: var(--mm-desktop-font-size, 16px);
    color: var(--mm-desktop-text, #333333);
    position: relative;
    z-index: 1000;
    transition: all 0.3s ease;
}

/* Logo */
.modern-menu-logo {
    flex-shrink: 0;
}

.modern-menu-logo a {
    display: block;
    line-height: 0;
}

.modern-menu-logo img {
    max-height: 50px;
    width: auto;
    display: block;
    transition: max-height 0.3s ease;
}

/* Navigation */
.modern-menu-nav {
    flex: 1;
}

.modern-menu-list,
ul.modern-menu-list,
.modern-menu-nav > ul {
    list-style: none !important;
    list-style-type: none !important;
    display: flex !important;
    align-items: center;
    gap: 5px;
    margin: 0 !important;
    padding: 0 !important;
}

.modern-menu-item,
.modern-menu-list > li {
    position: relative;
    list-style: none !important;
    list-style-type: none !important;
}

.modern-menu-item > a {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 16px;
    color: var(--mm-desktop-link, #333333) !important;
    text-decoration: none !important;
    transition: color 0.2s ease;
    white-space: nowrap;
}

.modern-menu-item > a:hover,
.modern-menu-item > a:focus,
.modern-menu-item.current-menu-item > a {
    color: var(--mm-desktop-hover, #0073aa) !important;
}

/* Submenu Toggle Arrow */
.submenu-toggle {
    display: inline-flex;
    transition: transform 0.2s ease;
}

.submenu-toggle svg {
    width: 12px;
    height: 12px;
}

.modern-menu-item:hover > a .submenu-toggle {
    transform: rotate(180deg);
}

/* Dropdown/Submenu */
.modern-menu-submenu,
ul.modern-menu-submenu,
.modern-menu-wrapper .modern-menu-submenu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: var(--mm-desktop-bg, #ffffff);
    border-radius: 6px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
    padding: 8px 0 !important;
    margin: 0 !important;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.25s ease;
    list-style: none !important;
    list-style-type: none !important;
    z-index: 1001;
}

.modern-menu-submenu li,
.modern-menu-submenu .modern-menu-item {
    list-style: none !important;
    list-style-type: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.modern-menu-item:hover > .modern-menu-submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.modern-menu-submenu .modern-menu-item > a {
    padding: 10px 20px;
}

.modern-menu-submenu .modern-menu-item > a:hover {
    background: rgba(0, 0, 0, 0.03);
}

/* Nested Submenu */
.modern-menu-submenu .modern-menu-submenu {
    top: 0;
    left: 100%;
    margin-left: 5px;
}

.modern-menu-submenu .modern-menu-item:hover > .modern-menu-submenu {
    transform: translateX(0);
}

/* Vertical Layout */
.modern-menu-wrapper.layout-vertical {
    flex-direction: column;
    align-items: stretch;
    padding: 20px;
}

.modern-menu-wrapper.layout-vertical .modern-menu-logo {
    margin-bottom: 20px;
    text-align: center;
}

.modern-menu-wrapper.layout-vertical .modern-menu-nav {
    width: 100%;
}

.modern-menu-wrapper.layout-vertical .modern-menu-list {
    flex-direction: column;
    align-items: stretch;
}

.modern-menu-wrapper.layout-vertical .modern-menu-item > a {
    padding: 12px 16px;
    justify-content: space-between;
}

.modern-menu-wrapper.layout-vertical .modern-menu-submenu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    background: rgba(0, 0, 0, 0.02);
    border-radius: 0;
    padding-left: 20px;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.modern-menu-wrapper.layout-vertical .modern-menu-item.submenu-open > .modern-menu-submenu {
    max-height: 500px;
}

/* Placeholder for sticky menu - reserves space when menu is fixed */
.modern-menu-placeholder {
    display: none; /* Hidden by default, shown via JS when sticky */
    visibility: hidden; /* Takes up space but invisible */
    pointer-events: none;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    width: 100%;
}

/* Sticky State - No animation, just fixed position */
.modern-menu-wrapper.is-sticky,
.modern-menu-mobile-header.is-sticky {
    /* Menu becomes fixed - placeholder holds its place in the flow */
}

/* Sticky Logo - Scale to fit within available space */
.modern-menu-wrapper.is-sticky .modern-menu-logo {
    display: flex;
    align-items: center;
    height: 100%;
}

.modern-menu-wrapper.is-sticky .modern-menu-logo img {
    height: auto;
    max-height: 100%;
    width: auto;
    transition: max-height 0.3s ease;
}

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

/* ========================================
   MOBILE MENU
   ======================================== */

.modern-menu-mobile {
    display: none;
}

@media (max-width: 768px) {
    .modern-menu-mobile {
        display: block;
    }
}

/* Mobile Header */
.modern-menu-mobile-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--mm-mobile-padding-top, 12px) var(--mm-mobile-padding-right, 20px) var(--mm-mobile-padding-bottom, 12px) var(--mm-mobile-padding-left, 20px);
    background: var(--mm-mobile-bg, #ffffff);
    position: relative;
    z-index: 1000;
}

.modern-menu-mobile-header .modern-menu-logo img {
    max-height: 40px;
}

/* Mobile Header Layout Positions */
/* Default: Logo left, button right */
.modern-menu-mobile-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Logo Positions */
.modern-menu-mobile-header.logo-left .modern-menu-logo {
    order: 1;
    margin-right: auto;
}

.modern-menu-mobile-header.logo-center .modern-menu-logo {
    order: 2;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

.modern-menu-mobile-header.logo-right .modern-menu-logo {
    order: 3;
    margin-left: auto;
}

/* Button Positions */
.modern-menu-mobile-header.button-left .modern-menu-hamburger {
    order: 1;
    margin-right: auto;
}

.modern-menu-mobile-header.button-right .modern-menu-hamburger {
    order: 3;
    margin-left: auto;
}

/* Combined positioning adjustments */
.modern-menu-mobile-header.logo-left.button-left .modern-menu-logo {
    order: 2;
    margin-right: 0;
    margin-left: auto;
}

.modern-menu-mobile-header.logo-right.button-right .modern-menu-logo {
    order: 1;
    margin-left: 0;
    margin-right: auto;
}

.modern-menu-mobile-header.logo-center .modern-menu-hamburger {
    position: relative;
    z-index: 1;
}

/* Hamburger Button */
.modern-menu-hamburger {
    background: none;
    border: none;
    padding: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--mm-hamburger-color, #333333);
    transition: transform 0.2s ease;
}

.modern-menu-hamburger:hover {
    transform: scale(1.1);
}

.modern-menu-hamburger svg {
    width: var(--mm-hamburger-size, 24px);
    height: var(--mm-hamburger-size, 24px);
}

/* Overlay */
.modern-menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--mm-overlay-color, rgba(0, 0, 0, 0.5));
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    z-index: 99998;
}

.modern-menu-mobile.is-open .modern-menu-overlay {
    opacity: 1;
    visibility: visible;
}

/* Mobile Navigation Panel */
.modern-menu-mobile-nav {
    position: fixed;
    background: var(--mm-mobile-bg, #ffffff);
    z-index: 99999;
    overflow-y: auto;
    padding: 60px 30px 30px;
    font-family: var(--mm-mobile-font, inherit);
    font-weight: var(--mm-mobile-font-weight, 400);
    font-size: var(--mm-mobile-font-size, 18px);
}

/* Fullscreen Type */
.modern-menu-mobile-nav.type-fullscreen {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transform: scale(0.95);
    transition: all 0.3s ease;
}

.modern-menu-mobile.is-open .modern-menu-mobile-nav.type-fullscreen {
    opacity: 1;
    visibility: visible;
    transform: scale(1);
}

/* Slide from Left */
.modern-menu-mobile-nav.type-slide-left {
    top: 0;
    left: 0;
    bottom: 0;
    width: 300px;
    max-width: 85%;
    transform: translateX(-100%);
    transition: transform 0.3s ease;
}

.modern-menu-mobile.is-open .modern-menu-mobile-nav.type-slide-left {
    transform: translateX(0);
}

/* Slide from Right */
.modern-menu-mobile-nav.type-slide-right {
    top: 0;
    right: 0;
    bottom: 0;
    width: 300px;
    max-width: 85%;
    transform: translateX(100%);
    transition: transform 0.3s ease;
}

.modern-menu-mobile.is-open .modern-menu-mobile-nav.type-slide-right {
    transform: translateX(0);
}

/* Slide from Top */
.modern-menu-mobile-nav.type-slide-top {
    top: 0;
    left: 0;
    right: 0;
    max-height: 80vh;
    transform: translateY(-100%);
    transition: transform 0.3s ease;
}

.modern-menu-mobile.is-open .modern-menu-mobile-nav.type-slide-top {
    transform: translateY(0);
}

/* Close Button */
.modern-menu-close {
    position: absolute;
    top: 15px;
    background: none;
    border: none;
    padding: 10px;
    cursor: pointer;
    color: var(--mm-mobile-text, #333333);
    transition: transform 0.2s ease;
    z-index: 10;
}

/* Close Button Position */
.modern-menu-mobile-nav.close-right .modern-menu-close {
    right: 15px;
    left: auto;
}

.modern-menu-mobile-nav.close-left .modern-menu-close {
    left: 15px;
    right: auto;
}

.modern-menu-close:hover {
    transform: rotate(90deg);
}

.modern-menu-close svg {
    width: var(--mm-close-size, 24px);
    height: var(--mm-close-size, 24px);
}

/* Mobile Menu List */
.modern-menu-mobile-nav .modern-menu-list,
.modern-menu-mobile-nav ul,
.modern-menu-mobile .modern-menu-list {
    list-style: none !important;
    list-style-type: none !important;
    display: flex !important;
    flex-direction: column;
    gap: 5px;
    margin: 0 !important;
    padding: 0 !important;
    width: 100%;
}

.modern-menu-mobile-nav .modern-menu-item,
.modern-menu-mobile-nav li,
.modern-menu-mobile .modern-menu-item {
    position: relative;
    list-style: none !important;
    list-style-type: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.modern-menu-mobile-nav .modern-menu-item > a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 15px 10px !important;
    color: var(--mm-mobile-link, #333333) !important;
    text-decoration: none !important;
    transition: color 0.2s ease;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    position: relative;
}

/* Mobile Menu Alignment */
.modern-menu-mobile-nav.align-left .modern-menu-list,
.modern-menu-mobile-nav.align-left ul {
    align-items: flex-start !important;
}

.modern-menu-mobile-nav.align-left .modern-menu-item {
    width: 100%;
    text-align: left !important;
}

.modern-menu-mobile-nav.align-left .modern-menu-item > a {
    justify-content: flex-start !important;
    text-align: left !important;
}

.modern-menu-mobile-nav.align-left .modern-menu-item > a .submenu-toggle {
    margin-left: auto;
    position: absolute;
    right: 10px;
}

.modern-menu-mobile-nav.align-center .modern-menu-list,
.modern-menu-mobile-nav.align-center ul {
    align-items: center !important;
}

.modern-menu-mobile-nav.align-center .modern-menu-item {
    width: 100%;
    text-align: center !important;
}

.modern-menu-mobile-nav.align-center .modern-menu-item > a {
    justify-content: center !important;
    text-align: center !important;
}

.modern-menu-mobile-nav.align-center .modern-menu-item > a .submenu-toggle {
    position: absolute;
    right: 10px;
}

.modern-menu-mobile-nav.align-right .modern-menu-list,
.modern-menu-mobile-nav.align-right ul {
    align-items: flex-end !important;
}

.modern-menu-mobile-nav.align-right .modern-menu-item {
    width: 100%;
    text-align: right !important;
}

.modern-menu-mobile-nav.align-right .modern-menu-item > a {
    justify-content: flex-end !important;
    text-align: right !important;
}

.modern-menu-mobile-nav.align-right .modern-menu-item > a .submenu-toggle {
    position: absolute;
    left: 10px;
    right: auto;
}

.modern-menu-mobile-nav .modern-menu-item > a:hover,
.modern-menu-mobile-nav .modern-menu-item > a:focus,
.modern-menu-mobile-nav .modern-menu-item.current-menu-item > a {
    color: var(--mm-mobile-hover, #0073aa) !important;
}

.modern-menu-mobile-nav .submenu-toggle {
    padding: 5px 10px;
    margin: -5px -10px -5px 0;
    transition: transform 0.2s ease;
}

.modern-menu-mobile-nav .modern-menu-item.submenu-open > a .submenu-toggle {
    transform: rotate(180deg);
}

/* Mobile Submenu */
.modern-menu-mobile-nav .modern-menu-submenu,
.modern-menu-mobile-nav ul.modern-menu-submenu,
.modern-menu-mobile .modern-menu-submenu {
    list-style: none !important;
    list-style-type: none !important;
    padding: 0 !important;
    margin: 0 !important;
    padding-left: 20px !important;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    background: rgba(0, 0, 0, 0.02);
}

.modern-menu-mobile-nav .modern-menu-submenu li,
.modern-menu-mobile-nav .modern-menu-submenu .modern-menu-item {
    list-style: none !important;
    list-style-type: none !important;
}

.modern-menu-mobile-nav .modern-menu-item.submenu-open > .modern-menu-submenu {
    max-height: 500px;
}

.modern-menu-mobile-nav .modern-menu-submenu .modern-menu-item > a {
    font-size: 0.9em;
    padding: 12px 10px !important;
}

/* Nested Mobile Submenu */
.modern-menu-mobile-nav .modern-menu-submenu .modern-menu-submenu {
    padding-left: 15px !important;
    background: rgba(0, 0, 0, 0.02);
}

/* Mobile Sticky */
.modern-menu-mobile-header.is-sticky {
    animation: slideDown 0.3s ease;
}

/* ========================================
   UTILITY CLASSES
   ======================================== */

/* Screen Reader Text */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}

/* Body Lock when menu is open */
body.modern-menu-open {
    overflow: hidden;
}

/* Transitions for reduced motion preference */
@media (prefers-reduced-motion: reduce) {
    .modern-menu-wrapper,
    .modern-menu-mobile-nav,
    .modern-menu-overlay,
    .modern-menu-submenu,
    .modern-menu-item > a,
    .submenu-toggle,
    .modern-menu-hamburger,
    .modern-menu-close {
        transition: none !important;
        animation: none !important;
    }
}

/* ========================================
   CTA BUTTONS
   ======================================== */

.modern-menu-cta-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 20px;
    border: 2px solid;
    text-decoration: none !important;
    white-space: nowrap;
    cursor: pointer;
    transition: padding 0.3s ease, font-size 0.3s ease, opacity 0.2s ease, transform 0.2s ease;
    flex-shrink: 0;
}

.modern-menu-cta-button:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

/* Desktop Button Positioning */
.modern-menu-wrapper.has-button {
    gap: 20px;
}

.modern-menu-wrapper.button-right .modern-menu-cta-button {
    order: 10;
    margin-left: auto;
}

.modern-menu-wrapper.button-left .modern-menu-cta-button {
    order: 0;
    margin-right: auto;
}

.modern-menu-wrapper.button-left .modern-menu-nav {
    order: 5;
}

.modern-menu-wrapper.button-left .modern-menu-logo {
    order: 1;
}

/* Mobile Header Button */
.modern-menu-mobile-header.has-header-button {
    gap: 10px;
}

.modern-menu-mobile-header .mobile-header-button {
    padding: 8px 14px;
    font-size: 14px;
}

.modern-menu-mobile-header.header-button-left .mobile-header-button {
    order: -1;
}

.modern-menu-mobile-header.header-button-center .mobile-header-button {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

.modern-menu-mobile-header.header-button-right .mobile-header-button {
    order: 5;
}

/* Button next to hamburger - wrapper for grouping */
.modern-menu-mobile-header .mm-hamburger-group {
    display: flex;
    align-items: center;
}

/* Hamburger group takes the same position as hamburger would */
.modern-menu-mobile-header.button-right .mm-hamburger-group {
    order: 3;
    margin-left: auto;
}

.modern-menu-mobile-header.button-left .mm-hamburger-group {
    order: 1;
    margin-right: auto;
}

/* When hamburger group exists, remove margin from hamburger itself */
.modern-menu-mobile-header .mm-hamburger-group .modern-menu-hamburger {
    margin: 0;
    order: unset;
}

.modern-menu-mobile-header.header-button-left-of-hamburger .mobile-header-button,
.modern-menu-mobile-header.header-button-right-of-hamburger .mobile-header-button {
    /* Remove absolute positioning if any */
    position: static;
    transform: none;
}

/* Mobile Nav Button */
.modern-menu-mobile-button {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.modern-menu-mobile-button .mobile-nav-button {
    width: 100%;
    padding: 15px 25px;
    font-size: 16px;
    text-align: center;
}

/* ========================================
   CUSTOM CSS CLASSES SUPPORT
   Allow custom classes to control menu item visibility
   WordPress adds 'logged-in' class to body when user is logged in
   ======================================== */

/* Always hide items with 'hidden' or 'hide' class */
.modern-menu-item.hidden,
.modern-menu-item.hide {
    display: none !important;
}

/* LOGGED-IN ONLY items: Hide by default, show when user is logged in */
.modern-menu-item.loggedin,
.modern-menu-item.user-logged-in {
    display: none !important;
}

body.logged-in .modern-menu-item.loggedin,
body.logged-in .modern-menu-item.user-logged-in {
    display: list-item !important;
}

/* LOGGED-OUT ONLY items: Show by default, hide when user is logged in */
body.logged-in .modern-menu-item.loggedout,
body.logged-in .modern-menu-item.user-logged-out {
    display: none !important;
}

/* Show items with 'show' or 'visible' class */
.modern-menu-item.show,
.modern-menu-item.visible {
    display: list-item !important;
}

/* Mobile menu items - same rules */
.modern-menu-mobile-nav .modern-menu-item.hidden,
.modern-menu-mobile-nav .modern-menu-item.hide {
    display: none !important;
}

.modern-menu-mobile-nav .modern-menu-item.loggedin,
.modern-menu-mobile-nav .modern-menu-item.user-logged-in {
    display: none !important;
}

body.logged-in .modern-menu-mobile-nav .modern-menu-item.loggedin,
body.logged-in .modern-menu-mobile-nav .modern-menu-item.user-logged-in {
    display: list-item !important;
}

body.logged-in .modern-menu-mobile-nav .modern-menu-item.loggedout,
body.logged-in .modern-menu-mobile-nav .modern-menu-item.user-logged-out {
    display: none !important;
}

