
.site-header {
  position: sticky;
  top: 0;
  z-index: 999;
  background: #fff;
  border-bottom: 1px solid var(--color-border);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 5px 20px;
  background-color: var(--color-light-bg);
}

.header-logo {
  flex: 0 0 30%;
  display: flex;                /* включаем flex для точного выравнивания */
  align-items: center;          /* центрируем логотип по вертикали */
  justify-content: center;
}

.header-logo img {
  max-width: 100%;              /* не вылезает за ширину родителя */
  max-height: var(--menu-item-height); /* высота равна высоте пункта меню */
  width: auto;                  /* ширина подстраивается пропорционально */
  height: auto;                 /* сохраняем пропорции */
}

.header-menu { flex: 0 0 60%; }
.header-contact { text-align: right; white-space: nowrap;}

.header-contact .phone {
  color: var(--color-primary);
  font-weight: bold;
  margin-bottom: 0.2rem;
}

.header-contact .contact-link a {
  display: inline-block;
  background: var(--color-primary);
  color: #fff;
  padding: 8px 15px;
  border-radius: 4px;
  text-decoration: none;
  transition: background var(--transition-speed) ease;
}

.header-contact .contact-link a:hover {
  background: var(--color-primary-dark);
}

.nav-menu {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-menu li { margin: 0; }

/* Общие стили для подменю */
.nav-menu .sub-menu {
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  background: #fff;
  box-shadow: var(--box-shadow);
  min-width: 200px;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity var(--transition-speed), visibility var(--transition-speed);
}

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

.nav-menu .menu-item-has-children:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Подменю второго уровня и глубже – справа */
.nav-menu .sub-menu .menu-item-has-children {
  position: relative;
}

.nav-menu .sub-menu .menu-item-has-children > .sub-menu {
  top: 0;
  left: 100%;
  margin-left: 0;
}

/* Стили ссылок */
.nav-menu li a {
  position: relative;
  display: block;
  padding: 10px 15px;
  color: var(--color-text);
  text-decoration: none;
  transition: color var(--transition-speed) ease;
}

/* --- Подчеркивание (зеленая линия) через ::before --- */
.nav-menu li a::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 3px;
  width: 100%;
  background: var(--color-primary);
  transform: scaleY(0);
  transform-origin: bottom;
  transition: transform var(--transition-speed) ease;
}

/* Активный пункт – линия видна */
.nav-menu li.current-menu-item > a::before,
.nav-menu li.current_page_item > a::before {
  transform: scaleY(1);
}

/* --- Подчеркивание для родительских пунктов, когда активен вложенный --- */
.nav-menu li.current-menu-ancestor > a::before,
.nav-menu li.current-menu-parent > a::before,
.nav-menu li.current-page-ancestor > a::before,
.nav-menu li.current_page_ancestor > a::before,
.nav-menu li.current_page_parent > a::before {
  transform: scaleY(1);
}

/* При наведении на любой пункт – линия появляется */
.nav-menu li a:hover::before {
  transform: scaleY(1);
  background: var(--color-primary-dark);
}

/* --- Шевроны для пунктов с подпунктами через ::after (юникод) --- */
.nav-menu .menu-item-has-children > a::after {
  content: "\25BC"; /* ▼ */
  font-size: 1em;
  margin-left: 5px; /* слева от текста */
  display: inline-block;
  transition: transform var(--transition-speed);
  color: currentColor;
  position: relative;
  top: -1px;
}

/* Для глубоких уровней (подменю) – другая стрелка */
.nav-menu .sub-menu .menu-item-has-children > a::after {
  content: "\203A"; /* › */
  margin-left: 5px;
}

/* При наведении на пункт с подменю можно вращать стрелку (опционально) */
.nav-menu .menu-item-has-children:hover > a::after {
  transform: rotate(180deg);
}

/* Для глубоких уровней вращение отключаем, чтобы не мешало */
.nav-menu .sub-menu .menu-item-has-children:hover > a::after {
  transform: rotate(0deg);
}

/* --- Мегаменю для пункта «Техника» (класс .tehnika) --- */
.nav-menu .menu-item-has-children.tehnika {
  position: static;
}

/* Само мегаменю: ограниченная ширина + центрирование */
.nav-menu .menu-item-has-children.tehnika > .sub-menu {
  position: absolute;
  display: flex;
  flex-wrap: wrap;
  left: 0;
  right: 0;
  max-width: var(--megamenu-max-width);
  margin-left: auto;
  margin-right: auto;
  background: #fff;
  box-shadow: var(--box-shadow);
  padding: 20px;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-speed), visibility var(--transition-speed);
  box-sizing: border-box;
  top: unset;
}

.nav-menu .menu-item-has-children.tehnika:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
}

/* Колонки второго уровня */
.nav-menu .menu-item-has-children.tehnika > .sub-menu > li {
  flex: 1 1 auto;
  margin: 0 15px 15px 0;
  list-style: none;
}

.nav-menu .menu-item-has-children.tehnika > .sub-menu > li > a {
  font-weight: bold;
  display: block;
  margin-bottom: 10px;
}

/* Третий уровень всегда виден внутри колонки */
.nav-menu .menu-item-has-children.tehnika > .sub-menu > li > .sub-menu {
  display: block;
  position: static;
  box-shadow: none;
  background: transparent;
  opacity: 1;
  visibility: visible;
  padding: 0;
  min-width: 0;
}

/* 4 уровень всегда виден внутри колонки */
.nav-menu .menu-item-has-children.tehnika > .sub-menu > li > .sub-menu > li > .sub-menu {
  display: block;
  position: static;
  box-shadow: none;
  background: transparent;
  opacity: 1;
  visibility: visible;
  padding: 0 0 0 1em;
  min-width: 0;
}

.nav-menu .menu-item-has-children.tehnika > .sub-menu > li > .sub-menu a {
  padding: 5px 0;
  display: block;
  color: #555;
}

/* Скрываем стрелку у второго уровня в мегаменю (подменю всегда открыто) */
.nav-menu .menu-item-has-children.tehnika > .sub-menu > .menu-item-has-children > a::after {
  content: "";
  display: none;
}

/* burger */
button.menu-toggle:hover {
  background: transparent;
}
.menu-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 24px;
}
.menu-toggle {
  width: 30px;
  height: 20px;
  position: relative;
  cursor: pointer;
  border: none;
  background: none;
}
.menu-toggle span {
  position: absolute;
  height: 3px;
  width: 100%;
  background: var(--color-primary);
  left: 0;
  transition: var(--transition-speed);
}
.menu-toggle span:nth-child(1) { top: 0; }
.menu-toggle span:nth-child(2) { top: 8px; }
.menu-toggle span:nth-child(3) { top: 16px; }
.menu-toggle.open span:nth-child(1) {
  transform: rotate(45deg);
  top: 8px;
}
.menu-toggle.open span:nth-child(2) {
  opacity: 0;
}
.menu-toggle.open span:nth-child(3) {
  transform: rotate(-45deg);
  top: 8px;
}
/* burger end*/

/* --- Адаптация для планшетов (от 769px до 1024px) --- */
@media (min-width: 769px) and (max-width: 1024px) {
  .nav-menu {
    justify-content: center;
  }

  .nav-menu li a {
    padding: 10px 12px;
    font-size: 0.95rem;
  }

  /* Мегаменю техники на планшетах: почти на всю ширину, но с отступами */
  .tehnika > .sub-menu {
    max-width: 95%;
    left: 2.5%;
    transform: none;
  }

  .tehnika > .sub-menu > li {
    flex: 1 1 180px;
    margin: 0 10px 10px 0;
  }
}

/* Мобильная версия */
@media (max-width: 768px) {
  .menu-toggle { display: block; }
  .header-inner { justify-content: space-between; }
  .header-logo { flex: 0 0 auto; }
  .header-contact { flex: 0 0 auto; }

  .header-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border-top: 1px solid var(--color-border);
    z-index: 998;
    transform: scaleY(0);
    transform-origin: top;
    transition: transform var(--transition-speed) ease;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
  }
  .header-menu.active {
    transform: scaleY(1);
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }

  .nav-menu {
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
    list-style: none;
    width: 100%;
  }

  .nav-menu li {
    margin: 0;
  }
  .nav-menu li a {
    border-bottom: 1px solid #eee;
  }

  .nav-menu li a {
    display: block;
    text-align: center;
    text-decoration: none;
    color: #000;
  }

  .nav-menu li a:hover {
    background: var(--color-light-bg);
  }

  .nav-menu .menu-item-has-children > a::after {
    display: none;
  }

  /* Скрываем все подменю по умолчанию */
  .nav-menu .sub-menu {
    flex-basis: 100%;
    width: 100%;
    display: none;
    position: static;
    opacity: 1;
    visibility: visible;
    box-shadow: none;
    transition: none;
  }

  /* Показываем подменю только у пункта с классом open */
  .nav-menu .menu-item-has-children.open > .sub-menu {
    display: block;
  }

  /* Флекс-раскладка для пункта с подменю (ссылку и кнопку) */
  .nav-menu .menu-item-has-children.tehnika,
  .nav-menu .menu-item-has-children {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
  }

  .nav-menu .menu-item-has-children.tehnika > .sub-menu > li > a {
    font-weight: normal;
    display: block;
    margin-bottom: 0;
  }
  .nav-menu .menu-item-has-children.tehnika > .sub-menu > li > .sub-menu a {
    padding: 10px 15px;
  }

  .nav-menu .menu-item-has-children > a {
    flex: 1;
    padding: var(--menu-item-padding);
    box-sizing: border-box;
    height: var(--menu-item-height);
    line-height: calc(var(--menu-item-height) - 2 * var(--menu-item-padding));
  }

  /* Кнопка-шеврон */
  .submenu-toggle {
    flex: 0 0 auto;
    width: var(--menu-item-height);
    height: var(--menu-item-height);
    background: transparent;
    border: none;
    font-size: 2rem;
    cursor: pointer;
    transition: transform var(--transition-speed);
    color: var(--color-text);
    display: flex;
    align-items: initial;
    justify-content: center;
    padding: 0;
    line-height: 1;
    top: 0;
    right: 0;
    position: absolute;
    z-index: 2;
  }

  .submenu-toggle.open {
    transform: rotate(90deg);
  }
  button.submenu-toggle:hover {
    background: transparent;
  }

  /* Убираем стандартные CSS-стрелки на мобильных */
  .nav-menu .menu-item-has-children > a::after {
    display: none;
  }

  .nav-menu .sub-menu {
    padding-left: var(--submenu-padding-left);
  }

  /* Мегаменю Техники на мобильных ведёт себя как обычное вертикальное */
  .nav-menu .menu-item-has-children.tehnika > .sub-menu {
    display: none;
    position: static;
    box-shadow: none;
    padding: 0 0 0 var(--submenu-padding-left);
    opacity: 1;
    visibility: visible;
    flex-direction: column;
  }
  .nav-menu .menu-item-has-children.tehnika.open > .sub-menu {
    display: block;
  }

  .nav-menu .menu-item-has-children.tehnika.open > .sub-menu > li {
    margin: 0;
  }

  .nav-menu .menu-item-has-children.tehnika.open > .sub-menu > li > .sub-menu,
  .nav-menu .menu-item-has-children.tehnika.open > .sub-menu > li > .sub-menu > li > .sub-menu {
    display: none;
  }

  .nav-menu .menu-item-has-children.tehnika.open > .sub-menu > .menu-item-has-children.open > .sub-menu,
  .nav-menu .menu-item-has-children.tehnika.open > .sub-menu > .menu-item-has-children > .sub-menu > .menu-item-has-children.open > .sub-menu {
    display: block;
  }

  .nav-menu .menu-item-has-children.tehnika > .sub-menu > li > .sub-menu {
    padding-left: var(--submenu-padding-left);
  }
}