/**
 * Nxtlogic - Shared Navbar & Mega Menu Styles
 * Option A: Scroll-based (transparent → white on scroll) for pages with hero banners
 * Works with main.css navbar base + main.js (.navbar-colored on scroll)
 */

/* ============================================
   MEGA MENU LAYOUT
   ============================================ */
.megamenu-item {
    position: static !important;
}

.megamenu-item .dropdown-menu {
    width: 100%;
    left: 0 !important;
    right: 0 !important;
    padding: 30px 0;
    border-radius: 0 0 15px 15px;
    border: none;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
    background-color: #ffffff;
}


.megamenu-flex-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 10px 30px;
}

.megamenu-column {
    flex: 1;
    padding: 0 20px;
    min-width: 170px;
    text-align: left;
}

/* ============================================
   MEGA MENU HEADINGS & LINKS
   ============================================ */
.megamenu-heading {
    display: inline-block;
    font-size: 16px;
    font-weight: 700;
    color: var(--color-brand-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 15px;
    border-bottom: none;
    padding-bottom: 0;
}

/* Accordion trigger as button - reset button styles on desktop */
button.megamenu-heading.megamenu-acc-trigger {
    background: none;
    border: none;
    cursor: default;
    font: inherit;
    text-align: left;
    padding: 0;
    width: auto;
}

.megamenu-heading::after {
    content: "";
    display: block;
    width: 40px;
    height: 4px;
    background: #919c23;
    margin: 8px auto 0 auto;
    border-radius: 2px;
}

/* Ensure button elements also get the underline */
button.megamenu-heading::after {
    content: "";
    display: block;
    width: 40px;
    height: 4px;
    background: #919c23;
    margin: 8px auto 0 auto;
    border-radius: 2px;
}

.megamenu-link {
    display: block;
    color: #000000;
    font-size: 15px;
    font-weight: 400;
    padding: 6px 0;
    text-decoration: none;
    transition: all 0.3s ease;
}

.megamenu-link:hover {
    color: var(--color-brand-primary);
    padding-left: 5px;
    text-decoration: none;
}

/* ============================================
   DESKTOP MEGA MENU (min-width: 992px)
   ============================================ */
@media (min-width: 992px) {
    .navbar .container {
        position: relative;
    }

    .navbar-collapse,
    .navbar-nav,
    .navbar-nav .nav-item.megamenu-item {
        position: static;
    }

    .navbar-nav .nav-item.megamenu-item .dropdown-menu {
        width: 100%;
        left: 0;
        right: 0;
        top: 100%;
        margin-top: 0px;
        padding: 30px;
        border-radius: 0 0 30px 30px;
        box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15);
        border: none;
        border-top: 3px solid #919c23;
        display: none;
        background: #fff;
        z-index: 9999;
        overflow: visible !important;
    }

    /* Desktop: Ensure megamenu heading underline is centered */
    .navbar-nav .nav-item.megamenu-item .megamenu-heading::after,
    .navbar-nav .nav-item.megamenu-item button.megamenu-heading::after {
        margin: 8px auto 0 auto !important;
        width: 40px !important;
        height: 4px !important;
        background: #919c23 !important;
    }

    /* Show dropdown when hovering over nav-item */
    .navbar-nav .nav-item.megamenu-item:hover .dropdown-menu,
    .navbar-nav .nav-item.megamenu-item.megamenu-active .dropdown-menu {
        display: block;
        animation: fadeIn 0.3s ease;
    }
    
    /* Keep dropdown open when hovering over the dropdown itself */
    .navbar-nav .nav-item.megamenu-item .dropdown-menu:hover {
        display: block !important;
    }
    
    /* Hide dropdowns for nav items that are not hovered and not active */
    .navbar-nav .nav-item.megamenu-item:not(:hover):not(.megamenu-active) .dropdown-menu:not(:hover) {
        display: none !important;
    }

    /* Desktop: accordion panels always visible (no collapse) */
    .navbar-nav .nav-item.megamenu-item .megamenu-acc-panel {
        display: block !important;
    }

    /* Hover bridge - prevents menu from closing when moving from nav link to dropdown */
    /* Smaller height to avoid interfering when moving between nav items */
    .navbar-nav .nav-item.megamenu-item .dropdown-menu::before {
        content: "";
        display: block;
        position: absolute;
        bottom: 100%;
        left: 0;
        width: 100%;
        height: 15px;
        background: transparent;
        z-index: 1;
    }
    
    /* Ensure dropdowns don't overlap horizontally - each dropdown only shows for its nav item */
    .navbar-nav .nav-item.megamenu-item:not(:hover) .dropdown-menu:not(:hover) {
        display: none !important;
    }
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ============================================
   MOBILE MEGA MENU (max-width: 991px)
   ============================================ */
@media (max-width: 991px) {
    .megamenu-flex-row {
        flex-direction: column;
    }

    .navbar-nav .nav-item.megamenu-item {
        position: relative;
    }

    .navbar-nav .nav-item.megamenu-item .dropdown-menu {
        width: 100% !important;
        margin-top: 0 !important;
        box-shadow: none !important;
        border-left: 3px solid #919c23;
        border-top: none;
        border-radius: 0;
        padding: 20px 15px;
        background: #ffffff;
        position: static !important;
        transform: none !important;
    }
    
    /* Mobile: Better navbar collapse container (Skechers-style) */
    .navbar-collapse {
        background: #ffffff;
        margin-top: 10px;
        padding: 10px 0;
        border-top: 1px solid #e0e0e0;
    }
    
    /* Mobile: Nav links styling */
    .navbar-nav .nav-link {
        padding: 12px 20px;
        font-size: 15px;
        font-weight: 500;
        color: var(--color-text-primary);
        border-bottom: 1px solid #f0f0f0;
    }
    
    .navbar-nav .nav-link:hover,
    .navbar-nav .nav-link:focus {
        color: var(--color-brand-primary);
        background: rgba(145, 156, 35, 0.05);
    }

    .navbar-nav .nav-item.megamenu-item.show .dropdown-menu {
        display: block !important;
    }

    .megamenu-heading {
        margin-top: 15px;
        display: block;
        text-align: left;
    }

    .megamenu-heading::after {
        margin: 8px 0 0 0;
    }

    .megamenu-link {
        padding-left: 10px;
    }

    /* Mobile: Accordion for all megamenus - show only section headers until tapped */
    .navbar-nav .nav-item.megamenu-item .megamenu-acc-panel {
        display: none;
        overflow: hidden;
        max-height: 0;
        transition: max-height 0.3s ease-out, padding 0.3s ease-out;
        padding: 0;
    }
    .navbar-nav .nav-item.megamenu-item .megamenu-column.mobile-acc-open .megamenu-acc-panel {
        display: block;
        max-height: 2000px;
        padding: 8px 0;
        transition: max-height 0.4s ease-in, padding 0.3s ease-in;
    }

    /* Mobile: Convert all megamenu headings to clickable buttons (like Skechers) */
    .navbar-nav .nav-item.megamenu-item .megamenu-heading {
        cursor: pointer;
        width: 100%;
        padding: 14px 16px;
        margin: 8px 0 4px 0;
        text-align: left;
        border-radius: 8px;
        background: #f0f0f0;
        border-left: 4px solid #919c23;
        transition: all 0.2s ease;
        position: relative;
        padding-right: 45px;
        font-size: 15px;
        font-weight: 600;
        color: var(--color-text-primary);
        display: flex;
        align-items: center;
        min-height: 48px; /* Skechers-style: minimum 44-48px tap target */
    }
    .navbar-nav .nav-item.megamenu-item .megamenu-heading:hover,
    .navbar-nav .nav-item.megamenu-item .megamenu-heading:focus,
    .navbar-nav .nav-item.megamenu-item .megamenu-heading:active {
        background: #e8e8e8;
        outline: none;
        border-left-color: var(--color-brand-primary-dark);
    }
    /* Chevron arrow for all headings (Skechers-style) */
    .navbar-nav .nav-item.megamenu-item .megamenu-heading::after {
        content: "";
        position: absolute;
        right: 16px;
        top: 50%;
        margin-top: -4px;
        width: 0;
        height: 0;
        border-left: 5px solid transparent;
        border-right: 5px solid transparent;
        border-top: 6px solid #919c23;
        transition: transform 0.3s ease;
        margin: 0;
        width: auto;
        height: auto;
        background: none;
        border-radius: 0;
    }
    .navbar-nav .nav-item.megamenu-item .megamenu-column.mobile-acc-open .megamenu-heading::after {
        transform: rotate(180deg);
    }
    /* Remove the underline bar on mobile */
    .navbar-nav .nav-item.megamenu-item .megamenu-heading::before {
        display: none;
    }

    /* Mobile: tap-friendly section headers with chevron and highlight (for button triggers) */
    .navbar-nav .nav-item.megamenu-item button.megamenu-acc-trigger {
        cursor: pointer;
        width: 100%;
        padding: 14px 16px;
        margin: 8px 0 4px 0;
        text-align: left;
        border-radius: 8px;
        background: #f0f0f0;
        border-left: 4px solid #919c23;
        transition: all 0.2s ease;
        position: relative;
        padding-right: 45px;
        font-size: 15px;
        font-weight: 600;
        color: var(--color-text-primary);
        min-height: 48px;
        display: flex;
        align-items: center;
    }
    .navbar-nav .nav-item.megamenu-item button.megamenu-acc-trigger:hover,
    .navbar-nav .nav-item.megamenu-item button.megamenu-acc-trigger:focus,
    .navbar-nav .nav-item.megamenu-item button.megamenu-acc-trigger:active {
        background: #e8e8e8;
        outline: none;
        border-left-color: var(--color-brand-primary-dark);
    }
    .navbar-nav .nav-item.megamenu-item button.megamenu-acc-trigger::after {
        content: "";
        position: absolute;
        right: 16px;
        top: 50%;
        margin-top: -4px;
        width: 0;
        height: 0;
        border-left: 5px solid transparent;
        border-right: 5px solid transparent;
        border-top: 6px solid #919c23;
        transition: transform 0.3s ease;
    }
    .navbar-nav .nav-item.megamenu-item .megamenu-column.mobile-acc-open button.megamenu-acc-trigger::after {
        transform: rotate(180deg);
    }
    
    /* Mobile: Links inside accordion panels (Skechers-style spacing) */
    .navbar-nav .nav-item.megamenu-item .megamenu-acc-panel .megamenu-link {
        padding: 12px 16px 12px 28px;
        display: block;
        border-radius: 6px;
        font-size: 14px;
        color: var(--color-text-secondary);
        transition: all 0.2s ease;
        min-height: 44px;
        display: flex;
        align-items: center;
    }
    .navbar-nav .nav-item.megamenu-item .megamenu-acc-panel .megamenu-link:hover,
    .navbar-nav .nav-item.megamenu-item .megamenu-acc-panel .megamenu-link:focus {
        background: rgba(145, 156, 35, 0.12);
        color: var(--color-brand-primary);
        padding-left: 32px;
    }
    
    /* Mobile: Better spacing between sections (Skechers-style) */
    .navbar-nav .nav-item.megamenu-item .megamenu-column {
        margin-bottom: 12px;
        padding: 0;
    }
    .navbar-nav .nav-item.megamenu-item .megamenu-column:first-child .megamenu-heading,
    .navbar-nav .nav-item.megamenu-item .megamenu-column:first-child button.megamenu-acc-trigger {
        margin-top: 0;
    }

    /* Mobile: All dropdown toggles - clear "tap to expand" cue (chevron rotates when open) */
    .navbar-nav .nav-item.megamenu-item .dropdown-toggle {
        padding-right: 35px;
        position: relative;
    }
    .navbar-nav .nav-item.megamenu-item.show .dropdown-toggle::after {
        transform: rotate(180deg);
    }
    
    /* Mobile: Better visual separation between main nav items */
    .navbar-nav .nav-item {
        border-bottom: 1px solid #f0f0f0;
    }
    .navbar-nav .nav-item:last-child {
        border-bottom: none;
    }
}

/* ============================================
   DROPDOWN ARROW FIX (removes broken square)
   ============================================ */
.navbar-nav .dropdown-toggle::after {
    display: inline-block !important;
    content: "" !important;
    width: 0 !important;
    height: 0 !important;
    margin-left: 0.4em !important;
    vertical-align: middle !important;
    border-top: 0.35em solid currentColor !important;
    border-right: 0.35em solid transparent !important;
    border-bottom: 0 !important;
    border-left: 0.35em solid transparent !important;
    font-family: inherit !important;
    border-radius: 0 !important;
}

.navbar-nav .dropdown-toggle::before {
    display: none !important;
}

/* ============================================
   PAGES WITHOUT HERO - Always white navbar
   Add body class "navbar-static-white" for pages
   that don't have a hero banner (e.g. blog, contact)
   ============================================ */
/* Base navbar - ensure it starts white for static-white pages */
body.navbar-static-white .navbar {
    background-color: #ffffff !important;
    box-shadow: 0 2px 15px rgba(0, 0, 0, 0.08) !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    transition: none !important;
}

/* Also apply when navbar-colored class is present */
body.navbar-static-white .navbar.navbar-colored {
    background-color: #ffffff !important;
    box-shadow: 0 2px 15px rgba(0, 0, 0, 0.08) !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    transition: none !important;
}

body.navbar-static-white .navbar .nav-link,
body.navbar-static-white .navbar.navbar-colored .nav-link {
    color: var(--color-text-primary)333 !important;
    font-weight: 500 !important;
    padding: 15px 20px !important;
}

body.navbar-static-white .navbar .nav-link:hover,
body.navbar-static-white .navbar .nav-link:focus,
body.navbar-static-white .navbar.navbar-colored .nav-link:hover,
body.navbar-static-white .navbar.navbar-colored .nav-link:focus {
    color: var(--color-brand-primary) !important;
    background: transparent !important;
}

body.navbar-static-white .navbar-brand .w-logo,
body.navbar-static-white .navbar.navbar-colored .navbar-brand .w-logo {
    display: none !important;
}

body.navbar-static-white .navbar-brand .b-logo,
body.navbar-static-white .navbar.navbar-colored .navbar-brand .b-logo {
    display: block !important;
    max-width: 260px !important;
    width: auto !important;
    max-height: 66px !important;
    height: auto !important;
    object-fit: contain !important;
}

body.navbar-static-white .navbar-toggler {
    border-color: var(--color-brand-primary) !important;
}

body.navbar-static-white .navbar-toggler .fa-bars,
body.navbar-static-white .navbar.navbar-colored .navbar-toggler .fa-bars {
    color: var(--color-text-primary) !important;
}

/* Ensure dropdown toggles have dark text on white navbar */
body.navbar-static-white .navbar .dropdown-toggle,
body.navbar-static-white .navbar.navbar-colored .dropdown-toggle {
    color: var(--color-text-primary) !important;
}

body.navbar-static-white .navbar .dropdown-toggle:hover,
body.navbar-static-white .navbar .dropdown-toggle:focus,
body.navbar-static-white .navbar.navbar-colored .dropdown-toggle:hover,
body.navbar-static-white .navbar.navbar-colored .dropdown-toggle:focus {
    color: var(--color-brand-primary) !important;
}

/* Ensure dropdown arrows are visible on white navbar */
body.navbar-static-white .navbar .dropdown-toggle::after,
body.navbar-static-white .navbar.navbar-colored .dropdown-toggle::after {
    border-top-color: var(--color-text-primary) !important;
}

body.navbar-static-white .navbar .dropdown-toggle:hover::after,
body.navbar-static-white .navbar .dropdown-toggle:focus::after,
body.navbar-static-white .navbar.navbar-colored .dropdown-toggle:hover::after,
body.navbar-static-white .navbar.navbar-colored .dropdown-toggle:focus::after {
    border-top-color: var(--color-brand-primary) !important;
}

/* ============================================
   LOGO SIZING – Web & Mobile (all views)
   ============================================ */
/* Desktop (992px and up): max-width 300px, max-height 72px in main.css */

/* Tablet / small desktop (max-width 991px) */
@media (max-width: 991px) {
    .navbar .navbar-brand .w-logo,
    .navbar .navbar-brand .b-logo,
    .navbar-colored .navbar-brand .w-logo,
    .navbar-colored .navbar-brand .b-logo {
        max-width: 270px !important;
        max-height: 66px !important;
        width: auto !important;
        height: auto !important;
        object-fit: contain !important;
    }
}

/* Mobile (max-width 767px) */
@media (max-width: 767px) {
    .navbar .navbar-brand .w-logo,
    .navbar .navbar-brand .b-logo,
    .navbar-colored .navbar-brand .w-logo,
    .navbar-colored .navbar-brand .b-logo {
        max-width: 250px !important;
        max-height: 60px !important;
        width: auto !important;
        height: auto !important;
        object-fit: contain !important;
    }
}

/* Small mobile (max-width 576px) */
@media (max-width: 576px) {
    .navbar .navbar-brand .w-logo,
    .navbar .navbar-brand .b-logo,
    .navbar-colored .navbar-brand .w-logo,
    .navbar-colored .navbar-brand .b-logo {
        max-width: 240px !important;
        max-height: 57px !important;
        width: auto !important;
        height: auto !important;
        object-fit: contain !important;
    }
}
