/* =========================================================
   05-menu.css
   Mašin Elektro - Main Navigation + Category Mega Menu
   ========================================================= */

/* ---------------------------------------------------------
   Main blue navigation
--------------------------------------------------------- */

.me-main-nav,
.main-navigation,
.site-navigation {
    background: #0b63b6;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 12px 26px rgba(15, 36, 64, 0.12);
    position: relative;
    z-index: 100;
}

.me-main-nav ul,
.main-navigation ul,
.site-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.me-main-nav > ul,
.main-navigation > ul,
.site-navigation > ul {
    display: flex;
    align-items: center;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 24px;
}

.me-main-nav li,
.main-navigation li,
.site-navigation li {
    position: relative;
}

.me-main-nav a,
.main-navigation a,
.site-navigation a {
    display: flex;
    align-items: center;
    min-height: 56px;
    padding: 0 22px;
    color: #ffffff;
    font-size: 14px;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-left: 1px solid rgba(255, 255, 255, 0.13);
    transition: background 0.2s ease, color 0.2s ease;
}

.me-main-nav li:last-child > a,
.main-navigation li:last-child > a,
.site-navigation li:last-child > a {
    border-right: 1px solid rgba(255, 255, 255, 0.13);
}

.me-main-nav a:hover,
.main-navigation a:hover,
.site-navigation a:hover,
.me-main-nav .current-menu-item > a,
.main-navigation .current-menu-item > a,
.site-navigation .current-menu-item > a {
    background: #084f94;
    color: #ffffff;
}


/* ---------------------------------------------------------
   Homepage category menu wrapper
--------------------------------------------------------- */

.me-home-categories {
    width: 100%;
    max-width: 320px;
    background: #ffffff;
    border: 1px solid #dfe7f0;
    border-radius: 14px;
    box-shadow: 0 18px 45px rgba(15, 36, 64, 0.15);
    overflow: visible;
    position: relative;
    z-index: 999;
    font-family: inherit;
}

.me-category-head {

    display: flex;

    align-items: center;

    gap: 12px;

    min-height: 58px;

    padding: 0 18px;

    background: linear-gradient(135deg, #0b63b6, #084f94);

    color: #ffffff;

    border-radius: 14px 14px 0 0;

    font-size: 14px;

    font-weight: 900;

    text-transform: uppercase;

    letter-spacing: 0.035em;

    box-shadow: 0 4px 15px rgba(11, 99, 182, 0.25);

}

.me-category-head i {
    color: #ffffff;
    font-size: 18px;
}

.me-category-menu,
.me-category-menu ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.me-category-menu {
    position: relative;
    background: #ffffff;
    border-radius: 0 0 14px 14px;
}

.me-category-menu > li {
    position: static;
    border-bottom: 1px solid #e4ebf3;
}

.me-category-menu > li:last-child {
    border-bottom: none;
}

.me-category-menu a {
    text-decoration: none;
}


/* ---------------------------------------------------------
   Main category items
--------------------------------------------------------- */

.me-category-menu > li > a {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 52px;
    padding: 0 42px 0 18px;
    background: #ffffff;
    color: #1c2a3a;
    font-size: 14px;
    font-weight: 900;
    line-height: 1.25;
    text-transform: uppercase;
    transition:
        background 0.2s ease,
        color 0.2s ease,
        padding-left 0.2s ease;
}

.me-category-menu > li > a::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 4px;
    height: 100%;
    background: #d62828;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.me-category-menu > li.menu-item-has-children > a::after {
    content: "›";
    position: absolute;
    right: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: #7d91a8;
    font-size: 24px;
    font-weight: 800;
    line-height: 1;
}

.me-category-menu > li:hover > a,
.me-category-menu > li.current-menu-item > a,
.me-category-menu > li.current-menu-ancestor > a,
.me-category-menu > li.current-product_cat-ancestor > a {
    background: #f2f7fc;
    color: #0b63b6;
    padding-left: 24px;
}

.me-category-menu > li:hover > a::before,
.me-category-menu > li.current-menu-item > a::before,
.me-category-menu > li.current-menu-ancestor > a::before,
.me-category-menu > li.current-product_cat-ancestor > a::before {
    opacity: 1;
}

.me-category-menu > li:hover > a::after {
    color: #0b63b6;
}


/* ---------------------------------------------------------
   Mega submenu - desktop
--------------------------------------------------------- */

.me-category-menu > li > .sub-menu {
    position: absolute;
    top: 58px;
    left: 100%;
    width: min(920px, calc(100vw - 380px));
    min-height: 360px;
    padding: 26px;
    background:
        linear-gradient(135deg, rgba(11, 99, 182, 0.045), rgba(255, 255, 255, 0) 42%),
        #ffffff;
    border: 1px solid #dfe7f0;
    border-left: 4px solid #0b63b6;
    border-radius: 0 18px 18px 0;
    box-shadow: 24px 28px 60px rgba(15, 36, 64, 0.18);
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-content: start;
    gap: 12px 16px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateX(12px);
    transition:
        opacity 0.18s ease,
        visibility 0.18s ease,
        transform 0.18s ease;
    z-index: 9999;
}

.me-category-menu > li:hover > .sub-menu,
.me-category-menu > li:focus-within > .sub-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(0);
}

.me-category-menu .sub-menu > li {
    position: relative;
    border: 0;
}

.me-category-menu .sub-menu > li > a {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 44px;
    padding: 11px 12px 11px 32px;
    background: #f7f9fc;
    border: 1px solid #edf2f7;
    border-radius: 11px;
    color: #26384d;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.25;
    text-transform: none;
    transition:
        background 0.2s ease,
        border-color 0.2s ease,
        color 0.2s ease,
        transform 0.2s ease;
}

.me-category-menu .sub-menu > li > a::before {
    content: "";
    position: absolute;
    left: 14px;
    top: 50%;
    width: 6px;
    height: 6px;
    background: #d62828;
    border-radius: 50%;
    transform: translateY(-50%);
}

.me-category-menu .sub-menu > li > a:hover {
    background: #eef6ff;
    border-color: #cfe2f7;
    color: #0b63b6;
    transform: translateX(3px);
}


/* ---------------------------------------------------------
   Prevent slider/content from cutting the menu
--------------------------------------------------------- */

.me-home-hero,
.me-home-hero-inner,
.me-slider-wrap,
.me-slider-section,
.home-slider,
.bx-wrapper {
    overflow: visible;
}

.me-home-hero,
.me-home-hero-inner {
    position: relative;
    z-index: 20;
}

.me-slider-wrap,
.me-slider-section,
.home-slider {
    position: relative;
    z-index: 1;
}


/* ---------------------------------------------------------
   Mobile / tablet
--------------------------------------------------------- */

@media (max-width: 1024px) {
    .me-main-nav > ul,
    .main-navigation > ul,
    .site-navigation > ul {
        padding: 0 16px;
        overflow-x: auto;
    }

    .me-main-nav a,
    .main-navigation a,
    .site-navigation a {
        min-height: 50px;
        padding: 0 16px;
        font-size: 13px;
        white-space: nowrap;
    }

    .me-home-categories {
        max-width: 100%;
    }

    .me-category-menu > li > .sub-menu {
        width: min(680px, calc(100vw - 340px));
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .me-home-categories {
        border-radius: 12px;
    }

    .me-category-head {
        min-height: 52px;
        border-radius: 12px 12px 0 0;
        font-size: 13px;
    }

    .me-category-menu > li {
        position: relative;
    }

    .me-category-menu > li > a {
        min-height: 48px;
        font-size: 13px;
    }

    .me-category-menu > li > .sub-menu {
        position: static;
        width: auto;
        min-height: 0;
        padding: 12px;
        background: #f8fafc;
        border: 0;
        border-top: 1px solid #e4ebf3;
        border-radius: 0;
        box-shadow: none;
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: none;
    }

    .me-category-menu .sub-menu > li > a {
        min-height: 40px;
        font-size: 13px;
    }
}