
.wpb-navigation {position: absolute; top: 0; left: 0; right: 0; bottom: 0; height: fit-content; min-height: 8rem; background: linear-gradient(90deg, rgba(58, 52, 58, 0.7), rgba(58, 52, 58, 0.7)), linear-gradient(90deg, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2)); z-index: 1040; 
    .container { display: flex; align-items: center; justify-content: space-between; column-gap: 1rem; }
        
    .logo { display: inline-flex; margin-right: auto; position: absolute; top: 1.6rem; left: 50%; transform: translateX(-50%);
        img { width: 10rem; height: auto; }
    }
}

.btn--nav-toggle {
    svg { fill: var(--clr); 
        rect { transition: y var(--ts-25) ease var(--ts-25), transform var(--ts-25) ease, opacity var(--ts-25); transform-origin: center; }
    }
    &:hover svg rect { fill: var(--hover-clr); }
    &:focus svg rect { fill: var(--focus-clr); }
    &:active svg rect { fill: var(--active-clr); }
    
    &[aria-expanded="true"] {
        svg .top { transform: translateY(5px) translateX(-4px) rotate(45deg); }
        svg .middle { opacity: 0; }
        svg .bottom { transform: translateY(-5px) translateX(-4px) rotate(-45deg); }
    }
}

.wpb-navigation__collapse {
    ul { list-style: none; }
    .menu-item {
        .menu-link { color: var(--clr-light); width: 100%; text-decoration: none; text-transform: uppercase; font-size: 1.4rem; font-weight: 600; display: inline-flex; align-items: center; column-gap: 2rem; line-height: 1; transition: color var(--ts-duration) var(--ts-function); 
        &:hover { color: var(--clr-primary); }
        }

        &.menu-item--current > .menu-link { color: var(--clr-primary); }
        &.menu-item-has-children { position: relative; }  
    }
    .wpb-collapse__body {display: flex; align-items: center; justify-content: space-between; width: 100%;}
}

/*** Navigation mobile ***/
@media (max-width: 991.98px) {
    .wpb-navigation__collapse { max-width: 45rem; transform: translate3d(100%, 0, 0); width: 100%; display: none; flex-direction: column; position: fixed; top: 0; right: 0; bottom: 0; left: auto; background-color: var(--nav-bg-clr); z-index: 1030; overflow: hidden; transition: transform var(--ts-35) ease; 
      &.active { pointer-events: all; transform: translate3d(0%, 0, 0); }
      &.wpb-navigation__collapse--left { transform: translate3d(-100%, 0, 0); left: 0; right: auto;
        &.active { transform: translate3d(0%, 0, 0); }
      }
    
      .wpb-collapse__header { font-size: 1.6rem; font-weight: bold; padding: 2rem; display: flex; justify-content: space-between; align-items: center; }
      .wpb-collapse__body {flex-direction: column; align-items: start; justify-content: flex-start; padding: 2rem; flex-grow: 1; overflow-y: auto; overscroll-behavior: contain; }
      .wpb-collapse__footer { padding: 2rem; }
      
      .menu-item {
        .menu-link { font-size: 2rem; padding: 1.5rem 0; }
        &.menu-item-has-children > .menu-link > .btn { position: absolute; right: 0; top: 50%; transform: translateY(-50%); }
      }
    }
    
    .wpb-sub-menu { display: flex; flex-direction: column; height: 100%; overflow: hidden; list-style: none; position: fixed; top: 0; right: 0; bottom: 0; left: 0; background-color: var(--nav-bg-clr); z-index: 1; overflow-y: auto; transform: translate3d(100%, 0, 0); transition: transform var(--ts-35) ease; 
      &.active { transform: translate3d(0, 0, 0); }
      .wpb-sub-menu__header { font-size: 1.6rem; font-weight: bold; padding: 2rem; display: flex; align-items: center; justify-content: space-between; }
      .wpb-sub-menu__body { padding: 2rem; }
    }
}

/*** Navigation desktop ***/
@media (min-width: 992px) {
    .wpb-navigation { 
        .btn.btn--nav-toggle, .wpb-collapse__header, .wpb-sub-menu__header { display: none; }
    }

    .wpb-navigation__collapse { width: 100%; display: flex!important; justify-content: space-between; align-items: center;
        .menu-item {
            .menu-link { font-size: 1.4rem; position: relative; padding: 1rem 1.6rem; }
            &.menu-item-has-children {
                > .menu-link { display: flex; justify-content: space-between;
                    > .btn { --bg-clr: transparent; --border: none; --clr: var(--clr-text); width: auto; height: auto; min-height: 0; }
                }
                &:hover > .wpb-sub-menu { pointer-events: all; opacity: 1; }
            }
        }

        .wpb-menu { display: flex; align-items: center;
            /* > .menu-item > .menu-link { padding: 3.2rem 1.4rem;  */
            > .menu-item { padding: 3.2rem 0;
                > .btn { transform: rotate(90deg); --border: none; }
                &.menu-item--current > .menu-link { background-color: var(--clr-primary); color: var(--clr-light);}
            } /* Hoogste niveau links */

            .wpb-sub-menu { position: absolute; top: 100%; right: auto; bottom: auto; left: 50%; transform: translateX(-50%); box-shadow: 0 .5rem .5rem rgba(21, 47, 51, .1); width: 100%; padding: 0; min-width: 20rem; height: auto!important; background-color: var(--nav-bg-clr); opacity: 0; overflow: visible; pointer-events: none; transition: opacity var(--ts-25) ease; 
                .wpb-sub-menu { top: 0; left: 100%; transform: none; } 
                .wpb-sub-menu__header { display: none; }
            }
        }
    }

}