/**
 * Mobile Menu Override Styles
 * Ensures new mobile menu works correctly and overrides desktop styles
 */

/* Reset mobile navigation list - Remove all desktop dropdown styles */
@media (max-width: 981px) {
    /* Force mobile menu containers to use mobile-menu.css styles */
    .mobile-menu-container {
        position: fixed !important;
        top: 0 !important;
        left: -100% !important;
        width: 100% !important;
        max-width: 100% !important;
        height: 100vh !important;
        background: white !important;
        z-index: 9999 !important;
        transition: left 0.3s ease !important;
        overflow-y: auto !important;
        display: flex !important;
        flex-direction: column !important;
        visibility: visible !important;
        opacity: 1 !important;
    }

    .mobile-menu-container.active {
        left: 0 !important;
        display: flex !important;
    }

    /* Force overlay to be visible when active */
    .mobile-menu-overlay.active {
        display: block !important;
    }

    /* Hide mega filter button when mobile menu is open */
    .mobile-menu-container.active ~ * .mfilter-free-button,
    body:has(.mobile-menu-container.active) .mfilter-free-button {
        display: none !important;
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
    }

    /* Mobile navigation list - clean slate */
    .mobile-nav-list {
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
        padding-left: 0 !important;
        width: 100% !important;
        display: block !important;
        flex-direction: column !important;
    }

    /* Mobile navigation items */
    .mobile-nav-item {
        border-bottom: 1px solid #f0f0f0 !important;
        position: relative !important;
        width: 100% !important;
        display: block !important;
    }

    /* Mobile navigation links - Clean mobile-first styling */
    .mobile-nav-link {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 10px 4px 10px 4px !important;
        color: #333 !important;
        text-decoration: none !important;
        font-size: 13px !important;
        font-weight: 500 !important;
        transition: all 0.3s ease !important;
        background: white !important;
        border: none !important;
        box-shadow: none !important;
        position: relative !important;
        width: 100% !important;
        flex-wrap: nowrap !important;
    }

    .mobile-nav-link:hover {
        background: #f8f9fa !important;
        color: #333 !important;
        text-decoration: none !important;
        padding-left: 8px !important;
    }

    .mobile-nav-link:active,
    .mobile-nav-link:focus {
        background: #f0f7ff !important;
        color: #0857bb !important;
    }

    /* Wrapper span containing icon and text */
    .mobile-nav-link > span:first-child {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        flex: 1 !important;
    }

    /* Menu icons and text */
    .mobile-nav-link .fa {
        margin-right: 8px !important;
        width: 14px !important;
        text-align: center !important;
        color: #666 !important;
        font-size: 13px !important;
        flex-shrink: 0 !important;
    }

    .mobile-nav-link .menu-text {
        flex: 1 !important;
        text-align: left !important;
    }

    /* Mobile navigation arrows - HIDDEN */
    .mobile-nav-arrow {
        display: none !important;
    }

    /* Mobile submenus - Clean accordion style */
    .mobile-submenu {
        display: none !important;
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
        padding-left: 0 !important;
        background: #f8f9fa !important;
        width: 100% !important;
        position: static !important;
        box-shadow: none !important;
        border: none !important;
        transform: none !important;
    }

    .mobile-nav-item.expanded .mobile-submenu {
        display: block !important;
        animation: slideDown 0.3s ease !important;
    }

    @keyframes slideDown {
        from {
            opacity: 0;
            max-height: 0;
        }
        to {
            opacity: 1;
            max-height: 1000px;
        }
    }

    /* Mobile submenu items */
    .mobile-submenu-item {
        border-bottom: 1px solid #e8e8e8 !important;
        display: block !important;
        width: 100% !important;
        position: relative !important;
    }

    .mobile-submenu-item:last-child {
        border-bottom: none !important;
    }

    .mobile-submenu-link {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        padding: 12px 16px 12px 24px !important;
        color: #555 !important;
        text-decoration: none !important;
        font-size: 13px !important;
        transition: all 0.3s ease !important;
        background: transparent !important;
        border: none !important;
        width: 100% !important;
        position: relative !important;
    }

    .mobile-submenu-link:hover {
        background: white !important;
        color: #0857bb !important;
        text-decoration: none !important;
        padding-left: 28px !important;
    }

    .mobile-submenu-link .fa {
        margin-right: 8px !important;
        color: #999 !important;
        font-size: 12px !important;
        flex-shrink: 0 !important;
    }

    .mobile-submenu-link strong {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
    }

    /* Category items in submenu */
    .mobile-category-item .mobile-submenu-link {
        font-weight: 600 !important;
        color: #333 !important;
        background: #f0f0f0 !important;
        padding-left: 24px !important;
    }

    .mobile-category-item .mobile-submenu-link:hover {
        background: #e8e8e8 !important;
        padding-left: 28px !important;
    }

    /* Third level submenu */
    .mobile-submenu-level3 {
        background: white !important;
        padding: 0 !important;
        padding-left: 0 !important;
        margin: 0 !important;
        margin-left: 0 !important;
        list-style: none !important;
    }

    .mobile-submenu-level3-link {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        padding: 10px 12px 10px 40px !important;
        font-size: 12px !important;
        color: #666 !important;
        font-weight: 400 !important;
    }

    .mobile-submenu-level3-link:hover {
        padding-left: 44px !important;
        color: #0857bb !important;
    }

    /* Home item special styling */
    .mobile-nav-item.home-item .mobile-nav-link {
        background: #f0f7ff !important;
        color: #0857bb !important;
    }

    .mobile-nav-item.home-item .mobile-nav-link .fa {
        color: #0857bb !important;
    }

    /* CRITICAL: Disable ALL desktop dropdown behaviors in mobile */
    .mobile-nav-list .dropdown,
    .mobile-nav-list .dropdown-menu,
    .mobile-nav-list .mega-dropdown,
    .mobile-nav-list .mega-column-group,
    .mobile-nav-list .mega-menu-grid {
        position: static !important;
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        transform: none !important;
        box-shadow: none !important;
        border: none !important;
        background: transparent !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Disable desktop hover effects completely */
    .mobile-nav-list li:hover > .dropdown-menu,
    .mobile-nav-list .dropdown:hover > .dropdown-menu,
    .mobile-nav-list .dropdown:hover > .mega-dropdown {
        display: none !important;
    }

    /* Force mobile menu button to be visible */
    .mobile-menu-btn {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        position: relative !important;
        background: transparent !important;
        border: none !important;
        padding: 10px !important;
        cursor: pointer !important;
        z-index: 1001 !important;
    }

    /* Mobile menu overlay */
    .mobile-menu-overlay {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background: rgba(0,0,0,0.5) !important;
        z-index: 9998 !important;
        display: none !important;
    }

    .mobile-menu-overlay.active {
        display: block !important;
    }

    /* Mobile menu header */
    .mobile-menu-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 15px 20px !important;
        background: #0857bb !important;
        color: white !important;
        font-size: 16px !important;
        font-weight: 600 !important;
        box-shadow: 0 2px 5px rgba(0,0,0,0.1) !important;
        flex-shrink: 0 !important;
    }

    .mobile-menu-close {
        background: rgba(255,255,255,0.2) !important;
        border: none !important;
        color: white !important;
        font-size: 20px !important;
        cursor: pointer !important;
        width: 36px !important;
        height: 36px !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* Mobile search */
    .mobile-menu-search {
        padding: 15px 20px !important;
        background: #f8f9fa !important;
        border-bottom: 1px solid #e2e8f0 !important;
        flex-shrink: 0 !important;
    }

    .mobile-search-input {
        width: 100% !important;
        padding: 12px 16px !important;
        border: 1px solid #ddd !important;
        border-radius: 8px !important;
        font-size: 16px !important;
        background: white !important;
        outline: none !important;
    }

    /* Mobile menu content area */
    .mobile-menu-content {
        flex: 1 !important;
        overflow-y: auto !important;
        padding: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        -webkit-overflow-scrolling: touch !important;
    }

    /* Mobile menu footer */
    .mobile-menu-footer {
        padding: 20px !important;
        background: #f8f9fa !important;
        border-top: 2px solid #e2e8f0 !important;
        flex-shrink: 0 !important;
    }

    .mobile-quick-links {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 10px !important;
        margin-bottom: 20px !important;
    }

    .mobile-quick-link {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 10px 5px !important;
        color: #666 !important;
        text-decoration: none !important;
        font-size: 13px !important;
        background: white !important;
        border-radius: 8px !important;
        transition: all 0.2s !important;
    }

    .mobile-quick-link:hover {
        background: #e0f2fe !important;
        text-decoration: none !important;
        transform: translateY(-2px) !important;
        color: #666 !important;
    }

    .mobile-quick-link i {
        font-size: 24px !important;
        margin-bottom: 8px !important;
        color: #2563eb !important;
    }

    .mobile-contact-info {
        text-align: center !important;
        font-size: 14px !important;
        color: #666 !important;
    }

    .mobile-contact-info a {
        color: #2563eb !important;
        text-decoration: none !important;
    }
}

/* Desktop - ensure mobile elements are completely hidden */
@media (min-width: 982px) {
    .mobile-menu-btn,
    .mobile-menu-container,
    .mobile-menu-overlay,
    .mobile-nav-center,
    .mobile-nav-spacer {
        display: none !important;
    }
}

/* Tablet adjustments */
@media (min-width: 768px) and (max-width: 981px) {
    .mobile-menu-container {
        width: 400px !important;
        left: -400px !important;
    }

    .mobile-menu-container.active {
        left: 0 !important;
    }
}

/* Hide logo on small and medium screens (below 992px) */
@media (max-width: 991px) {
    .logo {
        display: none !important;
    }
}

/* Hide navigation bar and show mobile menu between 981px and 771px, and below 770px */
@media (max-width: 981px) {
    /* Keep navigation bar visible but hide only desktop nav inside it */
    .mf-navigation-bar {
        display: block !important;
        height: 0 !important;
        overflow: visible !important;
        padding: 0 !important;
        margin: 0 !important;
        border: none !important;
    }

    /* Show mobile menu button in header */
    .header-mobile-menu-btn {
        display: inline-flex !important;
    }

    /* Force mobile menu system to be active */
    .mobile-menu-btn {
        display: inline-flex !important;
    }

    /* Hide desktop navigation list */
    #desktopNav,
    .mf-nav-list {
        display: none !important;
    }

    /* Mobile menu list inside container - column layout for accordion */
    .mobile-menu-container .mobile-nav-list {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        width: 100% !important;
        padding: 0 !important;
    }
}

/* Desktop only - hide mobile elements above 982px */
@media (min-width: 982px) {
    .header-mobile-menu-btn {
        display: none !important;
    }

    .mobile-menu-btn {
        display: none !important;
    }

    /* Show desktop navigation */
    .mf-navigation-bar {
        display: block !important;
    }

    #desktopNav {
        display: block !important;
    }

    /* Desktop navigation list - HORIZONTAL FLEX LAYOUT */
    .mf-nav-list {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: center !important;
        flex-wrap: nowrap !important;
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
        gap: 10px !important;
    }

    /* Desktop nav items should be inline */
    .mf-nav-list > li {
        position: relative !important;
        width: auto !important;
    }
}

/* ========================================
   MEGA FILTER BUTTON POSITIONING
   Move below navigation bar
   ======================================== */

/* Lower the filter button to appear below navigation */
.mfilter-free-button {
    /* Move down below navigation - increase margin-top */
    margin-top: 150px !important; /* Lowered from original 10px */
}

/* Replace filter button icon with Font Awesome */
.mfilter-free-button:before {
    content: "\f0b0" !important; /* Font Awesome filter icon */
    font-family: 'FontAwesome' !important;
    color: white !important;
    font-size: 18px !important;
    line-height: 23px !important;
    display: block !important;
}

/* Hide background sprite image */
.mfilter-free-button[style*="background-image"] {
    background-position: -9999px -9999px !important;
}