.wpb-navigation { --nav-clr: var(--clr-contrast, var(--clr-text)); position: fixed; left: 0; top: 0; right: 0; z-index: 1050; transition: all 200ms ease;
  &.is-scrolled { background: var(--clr-light); --nav-clr: var(--clr-text);}
  .wpb-navigation__main {
    > .container { position: static; display: flex; align-items: center; justify-content: space-between; column-gap: 3.2rem; }
  }
  .logo { display: inline-flex; margin: auto;
    img { width: 6.8rem; height: auto; }
  }

  & + *:is(section){ --spacing-top: 10rem; padding-top: calc(var(--spacing-top) + var(--pt, 0px)); }
}

.btn--nav-toggle { --border: none; min-height: 0; justify-content: center;
  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(3px) translateX(-4.5px) rotate(45deg); }
    svg .middle { opacity: 0; }
    svg .bottom { transform: translateY(-5px) translateX(-4.5px) rotate(-45deg); }
  }
}

.wpb-navigation__collapse {
  ul { list-style: none; }
  .menu-item {  --padding-y: 1.5rem;
    
    .menu-link {  color: var(--nav-clr); width: 100%; text-decoration: none; display: inline-flex; align-items: center; column-gap: .6rem; line-height: 1; transition: color var(--ts-duration) var(--ts-function); position: relative; 
      &:has(.menu-item__text) { padding: 0; }      
    }
    &.menu-item-has-children { position: relative; } 
    
    .menu-item__text { height: 100%; display: flex; flex-direction: column; align-items: start; gap: 2rem; padding: 2rem; background: var(--clr-light); border-radius: 2rem; 
      strong { font-weight: 500; font-size: clamp(2rem, 2.5vw, 3.8rem); }
      .menu-item__description { font-size: 1.6rem; font-weight: 400; line-height: 1.7; }
      .btn { margin-top: auto; }
    }
    &.menu-item--highlight .menu-link::after { content: attr(data-vacancy-count); display: inline-flex; align-items: center; justify-content: center; min-width: 1.8rem; height: 1.8rem; padding: 0 .4rem; border-radius: 50%; background-color: var(--clr-primary); color: #fff; font-size: 1rem; font-weight: 600; line-height: 1; position: absolute; top: -.8rem; right: -2.2rem; }
    &.menu-item--highlight .menu-link { width: fit-content; }
  }
  .wpb-sub-menu__body > ul { display: grid; grid-template-columns: minmax(0, 1fr); gap: 2rem; padding-bottom: 3.2rem; 
    .menu-link { height: 100%; }
  }
}

/*** Navigation mobile ***/
@media (max-width: 1199.98px) {
  .wpb-navigation {
    .wpb-navigation__main { padding: 3rem 0; }
    .wpb-navigation__actions .btn { --icon-bg-clr: var(--clr-primary); --p: 0; --border: none; min-height: auto; width: 4rem; height: 4rem; padding: 0;
      .wpb-icon { --icon-clr: #fff; margin: 0 !important; }
      .icon-before{ transform: scale(1) !important; opacity: 1 !important; width: var(--size) !important; }
      .btn__text, .icon-after { display: none; }
    }
  }

  .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: #fff; 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); }
    }

    .btn.btn--link { --icon-bg-clr: var(--clr-light); }
  
    .wpb-collapse__header { color: var(--clr-text); font-size: 1.6rem; font-weight: bold; padding: 3rem 1.8rem; display: flex; column-gap: 2rem; align-items: center; }
    .wpb-collapse__body { padding: 0 1.8rem; flex-grow: 1; overflow-y: auto; overscroll-behavior: contain; }
    .wpb-collapse__footer { padding: 1.8rem; }
    
    .menu-item {
      .menu-link { font-size: 2rem; padding: var(--padding-y) 0; }
      &.menu-item--highlight .menu-link::after { top: .8rem; right: -2.2rem; }
      &.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: #fff; z-index: 1; overflow-y: auto; transform: translate3d(100%, 0, 0); transition: transform var(--ts-35) ease; 
    &.active { transform: translate3d(0, 0, 0); }
    .container { height: 100%; display: flex; flex-direction: column; }
    .wpb-sub-menu__header { font-size: 1.6rem; font-weight: bold; padding: 3rem 0; display: flex; align-items: center; justify-content: space-between; }
    .wpb-sub-menu__body { padding: 0; flex-grow: 1; overflow-y: auto; overscroll-behavior: contain; }
  }
}

/*** Navigation desktop ***/
@media (min-width: 1200px) {
  .wpb-pagewrapper:has(.wpb-navigation .menu-item-has-children)::after { content: ''; position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 2; background-color: var(--clr-dark); opacity: 0; pointer-events: none; transition: opacity var(--ts-25) ease; z-index: 5; }
  .wpb-pagewrapper:has(.wpb-navigation .menu-item-has-children > .menu-link:hover)::after, .wpb-pagewrapper:has(.wpb-navigation .menu-item-has-children .wpb-sub-menu:hover)::after { opacity: .9; }

  .wpb-navigation {
    .btn.btn--nav-toggle, .wpb-collapse__header, .wpb-sub-menu__header { display: none; }
    
    .logo img { width: 8.7rem; }

    &:has(.menu-item-has-children > .menu-link:hover), &:has(.menu-item-has-children .wpb-sub-menu:hover) {
      .wpb-navigation__collapse .menu-item .menu-link { color: var(--clr-text); }
    }

    & + *:is(section){ --spacing-top: 12rem; }
    &:has(+ .wpb-bg-clr--dark, + .wpb-bg-clr--gradient){ --clr-contrast: #FFFF; }
  }


  .wpb-navigation__collapse { width: 100%; display: flex !important; justify-content: space-between; align-items: center;
    .menu-item { --padding-y: 1rem; padding: var(--padding-y) 1.6rem; 
      .menu-link {  color: var(--nav-clr); font-size: 1.6rem; position: relative; }
      &.menu-item-has-children { position: static;
        > .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; padding: 0 !important; }
        }
        > .menu-link:hover + .wpb-sub-menu, > .wpb-sub-menu:hover { pointer-events: all; opacity: 1; }
      }
    }

    .wpb-sub-menu__body > ul { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 2rem; padding-bottom: 0; }

    .wpb-menu { display: flex; align-items: center;
      > .menu-item { --padding-y: 3.2rem; --padding-x: 1.4rem; min-height: 12rem; display: inline-grid; place-items: center; padding: var(--padding-y) var(--padding-x);
        &.menu-item-has-children .menu-link:hover::after { content: ''; height: 10rem; position: absolute; top: 0; left: 0; right: 0; bottom: 0;  }
        > .menu-link { position: relative; transition: opacity var(--ts-duration) var(--ts-function);
          > .btn { --icon-clr: var(--clr-primary); --icon-bg-clr: transparent; transform: rotate(90deg);
            i { display: block; width: auto; height: auto; font-size: 1.3rem; }
          }
          &::before{ --line-width: 100%; content: ''; position: absolute; bottom: 0; left: 0; right: 0; width: 0px; height: 2px; opacity: 0; background-color: var(--clr-primary); transform: translateY(.8rem); transition: width var(--ts-duration) var(--ts-function), background-color var(--ts-duration) var(--ts-function), opacity var(--ts-duration) var(--ts-function); }
          &:hover { opacity: .7; 
            &::before { opacity: 1; width: var(--line-width); }
          }
        }
      } 

      .wpb-sub-menu { padding: 13.7rem 0 7rem 0; z-index: -1; position: absolute; top: 0; right: 0; bottom: auto; left: 0; width: 100%; height: auto!important; background-color: #fff; 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: 1400px) {
  .wpb-navigation__collapse .menu-item .menu-item__text { padding: 3.2rem; }
}

@media (min-width: 1600px) {
  .wpb-navigation__collapse .menu-item .menu-item__text { padding: 4.8rem; }
}