:root{
  --nav-height: 12rem;
}

.wpb-navigation { --nav-bg-clr: #fff; position: absolute; top: 0; left: 0; right: 0; z-index: 1040;

  .logo { display: inline-flex; margin-right: auto;
    img { width: 7rem; height: auto; }
  }

  .wpb-navigation__main .container-fluid{ height: var(--nav-height); display: flex; align-items: start; justify-content: space-between; column-gap: 1rem; padding-top: var(--inline-spacing); }
  .btn--demo span > span{ display: none; }

  & + .wpb-main-content > *:first-child:is(section):not(.wpb-header, .wpb-demo){ padding-top: calc(var(--nav-height) + var(--pt, 0px)); }
  & + .wpb-main-content > *:first-child:is(.wpb-header) .wpb-header__inner{ padding-top: calc(var(--nav-height) + var(--pt, 0px)); }
}

.btn--nav-toggle { --clr: var(--clr-primary);
  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 rect { fill: var(--active-clr); transition: y var(--ts-25) ease, transform var(--ts-25) ease var(--ts-25), opacity 0ms var(--ts-25); }
    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-text); font-weight: 600; width: 100%; text-decoration: underline; text-decoration-color: transparent; display: inline-flex; align-items: center; column-gap: 2rem; line-height: 1; transition: text-decoration-color var(--ts-duration) var(--ts-function); 
      &:hover { text-decoration-color: var(--clr-text); }
    }

    &.menu-item-has-children { position: relative; }  
  }
}

/*** Navigation mobile ***/
@media (max-width: 991.98px) {
    .wpb-navigation__collapse { --collapse-padding: 2rem; --collapse-offset: clamp(1rem, 1.5vw, 2rem); --collapse-br: clamp(.8rem, 1.2vw, 1.6rem); max-width: min(45rem, calc(100% - (var(--collapse-offset) * 2))); transform: translate3d(100%, 0, 0) scaleX(0.5); opacity: 0; width: calc(100% - var(--collapse-offset)); display: none; flex-direction: column; position: fixed; top: var(--collapse-offset); right: var(--collapse-offset); bottom: var(--collapse-offset); left: auto; border-radius: var(--collapse-br); background-color: var(--nav-bg-clr); z-index: 1030; overflow: hidden; transition: transform var(--ts-35) ease, opacity var(--ts-25) ease; 
      &.active { pointer-events: all; transform: translate3d(0%, 0, 0) scaleX(1); opacity: 1; }
    
      .wpb-collapse__header { font-size: 1.6rem; font-weight: bold; margin: calc(var(--collapse-padding) / 2); margin-bottom: 0; padding: var(--collapse-padding); display: flex; justify-content: end; align-items: center; background-color: var(--clr-light); border-radius: var(--collapse-br); 
        > span{ font-size: 2.4rem; }
      }
      .wpb-collapse__body { padding: var(--collapse-padding); flex-grow: 1; overflow-y: auto; overscroll-behavior: contain; }
      .wpb-collapse__footer { padding: var(--collapse-padding); border-top: 1px solid var(--clr-border); display: flex; align-items: center; gap: 1rem; 
        .btn{ width: 100%; }
      }
      
      .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: var(--collapse-padding); display: flex; align-items: center; justify-content: space-between; }
      .wpb-sub-menu__body { padding: var(--collapse-padding); }
    }
}

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

    .logo { 
      img { width: 9.5rem; height: auto; }
    }
  }

  .wpb-navigation__collapse { width: 100%; display: flex!important; justify-content: end; 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-collapse__body{ --p: 0; --bg-clr: #FFFF; padding: var(--p); border-radius: .4rem; background-color: var(--bg-clr); position: absolute; margin-left: auto; margin-right: auto; left: 0; right: 0; width: fit-content; }
    .wpb-collapse__footer{ display: flex; align-items: center; gap: .5rem; }

    .wpb-menu { display: flex; align-items: center;
      > .menu-item > .menu-link { padding: 1.7rem 1.4rem; 
        > .btn { transform: rotate(90deg); --border: none; }
      } /* 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; }
      }
    }
  }
}

@media (min-width: 1200px) {
  .wpb-navigation{
    .btn--demo span > span{ display: inline; }
  }
  .wpb-navigation__collapse{
    .wpb-collapse__body{ --p: 0 2rem; }
  }
}