/*
 * Header shell fixes.
 *
 * The legacy stylesheet defines the open-state menu rule before the hidden base
 * rule, so the cascade can leave the mobile/desktop dropdown hidden after JS
 * correctly toggles `.menu-opened`. Keep the state fix in CSS so the script only
 * owns behavior and the stylesheet owns presentation.
 */
html {
  height: auto;
  min-height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
}

body {
  height: auto;
  min-height: 100%;
  overflow-x: hidden;
  overflow-y: visible;
}

.header.fixed {
  background: #fff;
  box-shadow: 0 20px 64px -20px rgba(83, 104, 115, 0.2);
}

.header.menu-opened {
  background-color: #fff;
}

.header.menu-opened .header__menu,
.header.menu-opened .header__langs {
  display: none;
}

.header.menu-opened .header__langs2 {
  position: static;
  visibility: visible;
  opacity: 1;
  z-index: 5;
}

.header.menu-opened > .header__drop-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: none;
}

.overlay-bg.active {
  opacity: 1;
  visibility: visible;
  transition: none;
  transition-delay: 50ms;
  z-index: 5;
}

.header.menu-opened .header__hamb {
  position: relative;
  z-index: 6;
}

.header__hamb {
  cursor: pointer;
}

.header__langs .header__langs-drop {
  pointer-events: none;
}

.header__langs.is-open .header__langs-drop {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

@media (hover: hover) and (pointer: fine) {
  .header__langs:hover .header__langs-drop {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  body.header-lang-suppressed .header__langs:not(.is-open):hover .header__langs-drop {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }
}

@media (hover: none), (pointer: coarse) {
  .header__langs:not(.is-open):hover .header__langs-drop {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }
}

@media (max-width: 767px) {
  .header.menu-opened > .wrapper {
    position: relative;
  }

  .header.menu-opened > .wrapper .header__logo {
    position: absolute;
    left: 50%;
    margin: 0;
    transform: translateX(-50%);
  }

  .header.menu-opened > .wrapper .header__langs--mobile,
  .header .header__drop-menu .header__langs--mobile {
    display: none;
  }
}
