.header {
  /* display: none; */
  border-bottom: 2px solid #2B2E4126;
  padding: 22px 0;
  height: 98px;
  width: 100%;
  transition: all 0.3s ease-in-out;
}
.header.scrolled {
  top: -98px;
  transition: all 0.3s ease-in-out;
}
.header + main {
  padding-top: 98px;
}
@media (max-width: 1023.98px) {
  .header {
    height: 222px;
  }
  .header.scrolled {
    top: -222px;
  }
  .header + main {
    padding-top: 222px;
  }
}

.header-row {
  position: relative;
}
.header-row, .header-contacts-outer {
  gap: 20px;
}
.header-logo {
  max-width: 188.55px;
  max-height: 52px;
}
.header-nav, .header-nav > ul {
  gap: 16px;
}
.header-nav ul li a {
  font-weight: 500;
}
.header-search {
  position: relative;
  max-width: 400px;
  min-width: 400px;
}
.header-search input {
  background: #F4F4F4;
    padding: 14px;
    padding-left: 40px !important;
    border-radius: 10px;
    width: 100%;
    max-height: 52px;
}
.header-search svg {
  position: absolute;
      top: 50%;
    transform: translateY(-50%);
    left: 10px;
}
.header-contacts {
  gap: 4px;
}
.header-contacts .phone {
  font-size: 21px;
  font-weight: 600;
}
.header-contacts .phone, .header-contacts .email, .header-btn {
  line-height: 1;
}
.header-btn {
  min-width: 220px;
  max-width: 220px;
  padding: 18px;
  border-radius: 10px;
  font-weight: 500;
  max-height: 52px;
}
.cat-button {
  cursor: pointer;
  background: #2A2D40;
    border-radius: 5px;
    color: white;
    padding: 9px 11px;
}
.cat-button, .menu-cat-button {
    display: flex;
    align-items: center;
    gap: 5px;
}
.catalog-mobile-header .cat-button {
  padding: 0;
  background: none;
  cursor: unset;
}
.main-mobile-content .cat-button {
  padding: 0;
  cursor: unset;
  border-radius: 0;
  border-bottom: unset;
}
.main-mobile-content .cat-button .main-mobile-link {
  border-bottom: unset;
  width: 100%;
  background: #2A2D40;
  color: white;
}
.main-mobile-content .cat-button .main-mobile-link .menu-cat-button + svg path {
  fill-opacity: 1;
  fill: white;
}
.cat-button:not(.active) .close-icon {
  display: none;
}
.cat-button.active .open-icon {
  display: none;
}
@media (min-width: 1600px) {
  .header-wrapper {
    max-width: 1574px;
    margin: 0 auto;
  }
}
@media (max-width: 1599.98px) {
  .header-wrapper {
    padding: 0 10px;
  }
  .header-search {
    min-width: 350px;
    max-width: 350px;
  }
  .header-btn {
    min-width: 200px;
    max-width: 200px;
  }
  .catalog-dropdown:before {
    display: none;
  }
  .catalog-dropdown {
    left: -10px;
    padding-left: 10px;
  }
}
@media (max-width: 1439.98px) {
  .header-btn, .header-search {
      min-width: unset;
      max-width: unset;
  }
  .header-btn {
    padding: 18px 10px;
  }
}
@media (max-width: 1279.98px) {
  .header-logo {
    max-width: 152.3px;
  }
  .header-row, .header-contacts-outer {
    gap: 15px;
  }
  .header-nav, .header-nav > ul {
      gap: 12px;
  }
}
@media (max-width: 1199.98px) and (min-width: 1024px) {
  .header {
    font-size: 14px;
  }
  .header-contacts .phone {
    font-size: 18.5px;
  }
  .header-logo {
    max-width: 120px;
  }
}
@media (max-width: 1199.98px) {
  .header-row, .header-contacts-outer {
    gap: 10px;
  }
  .header-nav, .header-nav > ul {
      gap: 8px;
  }
  .header-btn {
        padding: 18px 8px;
    }
}
@media (max-width: 1023.98px) {
  .header-row {
    flex-wrap: wrap;
    /* row-gap: 20px; */
  }
  .header-row, .header-contacts-outer {
    gap: 20px;
  }
  .header-search, .header-contacts-outer {
    width: 100%;
  }
  .header-search input {
    padding: 9px;
    max-height: 42px;
  }
  .header-btn {
    min-width: 175px;
    max-width: 175px;
  }
}
@media (min-width: 700px) {
 .menu-button {
  display: none;
 }
 .main-mobile-menu {
    display: none;
  }
}
@media (max-width: 699.98px) {
  .header-nav > ul {
    display: none;
  }
  .menu-button {
    cursor: pointer;
    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #2A2D40;
    border-radius: 5px;
  }
}
@media (max-width: 389.98px) {
  .header-btn {
      min-width: unset;
      max-width: unset;
  }
}
@media (max-width: 359.98px) {
  .header-logo {
      max-width: 120px;
  }
  .header-row, .header-contacts-outer {
      gap: 10px;
  }
  .header-btn {
    font-size: 14px;
  }
}

.catalog-dropdown {
  position: absolute;
  top: calc(100% + 24px);
  left: 0;
  width: 294px;
  background-color: #ffffff;
  /* border-radius: 12px; */
  /* box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.02); */
  /* border: 1px solid #e5e7eb; */
  /* border-right: 1px solid #2A2D4040; */
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  border-bottom: 2px solid #2B2E4126;
  /* border-right: 2px solid #2B2E4126; */
}

.catalog-dropdown.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.catalog-dropdown:before {
    content: '';
    background: white;
    position: absolute;
    width: 173px;
    height: calc(100% + 1.75px);
    left: -173px;
    border-bottom: 2px solid #2B2E4126;
}

.catalog-menu {
  /* margin: 20px 0; */
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 20px 0;
  border-right: 2px solid #2B2E4126;
}

.catalog-menu:has(.catalog-item.has-submenu:hover) {
  /* border-right: 2px solid #2B2E4126; */
}

.catalog-item {
  /* position: relative; */
  padding-right: 20px;
}

.catalog-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 11px;
  line-height: 1;
  color: #2A2D40;
  /* text-decoration: none; */
  /* font-size: 14px; */
  font-weight: 500;
  transition: all 0.2s ease;
  cursor: pointer;
  border-radius: 5px;
}

.catalog-link:hover {
  background-color: #2A2D40;
  color: white;
}
.submenu-link:hover {
    color: rgb(238 35 59);
}
.catalog-link:hover svg path {
  fill: white !important;
}

.catalog-arrow {
  width: 16px;
  height: 16px;
  transition: transform 0.2s ease;
  color: #999;
}

.submenu {
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: absolute;
  top: 0;
  /* left: calc(100% + 1.75px); */
  left: 100%;
  min-width: 355px;
  background-color: #ffffff;
  /* border-radius: 12px; */
  /* box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.02); */
  /* border: 1px solid #e5e7eb; */
  /* list-style: none; */
  /* margin: 0; */
  /* border-left: 2px solid #2A2D4026; */
  height: calc(100% + 1.75px);
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transform: translateX(-10px);
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  border-radius: 0 0 10px 0;
  border-right: 2px solid #2B2E4126;
  border-bottom: 2px solid #2B2E4126;
}

.catalog-item.has-submenu:hover > .submenu {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
}

.submenu-link {
  display: block;
  color: #2A2D40;
  text-decoration: none;
  line-height: 1.5;
  /* font-size: 13px; */
  font-weight: 500;
  transition: all 0.2s ease;
  /* white-space: nowrap; */
}

@media (max-width: 1023.98px) {
  .catalog-dropdown {
    display: none;
  }

  .catalog-mobile-menu {
    position: fixed;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background-color: #2A2D40;
    z-index: 1001;
    display: flex;
    flex-direction: column;
    transition: left 0.3s ease;
    font-weight: 500;
  }

  .catalog-mobile-menu.open {
    left: 0;
  }

  .catalog-mobile-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 9px 11px;
    background-color: #2A2D40;

  }

  .catalog-mobile-back {
    display: flex;
    align-items: center;
    gap: 5px;
    background: none;
    border: none;
    color: white;
    font-size: 16px;
    cursor: pointer;
    transition: background 0.2s ease;
  }

  .catalog-mobile-back.hidden {
    visibility: hidden;
    pointer-events: none;
    display: none;
  }

  .catalog-mobile-back + .cat-button {
    display: none;
  }

  .catalog-mobile-back.hidden + .cat-button {
    display: flex;
  }

  .catalog-mobile-outer {
    display: flex;
    align-items: center;
    gap: 12px;
  }

  .catalog-mobile-back:hover {
    /* background-color: rgba(255, 255, 255, 0.1); */
  }

  .catalog-mobile-close {
    /* background: none;
    border: none;
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease; */
  }

  .catalog-mobile-close:hover {
    /* background-color: rgba(255, 255, 255, 0.1); */
  }

  .catalog-mobile-content {
    flex: 1;
    overflow: hidden;
    position: relative;
  }

  .catalog-mobile-screen {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #F4F4F4;
    transition: transform 0.3s ease;
    overflow-y: auto;
  }

  .catalog-mobile-screen.screen-main {
    transform: translateX(0);
  }

  .catalog-mobile-screen.screen-sub {
    transform: translateX(100%);
  }

  .catalog-mobile-menu.submenu-active .catalog-mobile-screen.screen-main {
    transform: translateX(-100%);
  }

  .catalog-mobile-menu.submenu-active .catalog-mobile-screen.screen-sub {
    transform: translateX(0);
  }

  .catalog-mobile-list {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .catalog-mobile-item {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }

  .catalog-mobile-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    color: #2A2D40;
    border-bottom: 1px solid #2A2D4026;
    background: #FFFFFF;
    text-decoration: none;
    transition: background 0.2s ease;
    cursor: pointer;
    position: relative;
  }

  /* Для пунктов с подменю — чтобы стрелка была кликабельной отдельно */
  .catalog-mobile-link-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex: 1;
  }

  .catalog-mobile-link-text {
    flex: 1;
    color: #2A2D40;
    text-decoration: none;
  }

  .catalog-mobile-arrow-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 12px;
    /* margin: -4px; */
    display: flex;
    align-items: center;
    justify-content: center;
    /* border-radius: 4px; */
    transition: background 0.2s ease;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }

  /* Для обычных ссылок (без подменю) */
  .catalog-mobile-link > span {
    flex: 1;
  }

  .catalog-mobile-sublist {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .catalog-mobile-sublink, .catalog-mobile-title {
    display: block;
    padding: 14.5px 12px;
    line-height: 19px;
    color: #2A2D40;
    background: #FFFFFF;
    text-decoration: none;
    /* font-size: 13px; */
    transition: background 0.2s ease;
  }

  .catalog-mobile-sublink:hover {
    /* background-color: #4a4e6b; */
  }

  .catalog-mobile-title {
    background: #2A2D4026;
    border-bottom: 1px solid #2A2D4026;
  }

  .catalog-mobile-submenu {
    display: none;
  }

  .catalog-mobile-submenu.active {
    display: block;
  }
}

@media (min-width: 1024px) {
  .catalog-mobile-menu {
    display: none;
  }
}

/* ============================================
   СТИЛИ ДЛЯ ОСНОВНОГО МОБИЛЬНОГО МЕНЮ
   ============================================ */

@media (max-width: 1023.98px) {
  .main-mobile-menu {
    position: fixed;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background-color: #2A2D40;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    transition: left 0.3s ease;
    font-weight: 500;
  }

  .main-mobile-menu.open {
    left: 0;
  }

  .main-mobile-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 9px 11px;
    background-color: white;
  }

  .main-mobile-back {
    display: flex;
    align-items: center;
    gap: 5px;
    background: none;
    border: none;
    color: white;
    font-size: 16px;
    cursor: pointer;
    transition: background 0.2s ease;
  }

  .main-mobile-back.hidden {
    visibility: hidden;
    pointer-events: none;
    display: none;
  }

  .main-mobile-menu .main-mobile-back:not(.hidden) {
    color: #2A2D40;
  }
  .main-mobile-menu .main-mobile-back:not(.hidden) svg path {
    fill: #2A2D40;
  }

  .main-mobile-close {
    background: none;
    border: none;
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
  }

  .main-mobile-content {
    flex: 1;
    overflow: hidden;
    position: relative;
  }

  .main-mobile-screen {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #F4F4F4;
    transition: transform 0.3s ease;
    overflow-y: auto;
  }

  .main-mobile-screen.screen-main {
    transform: translateX(0);
  }

  .main-mobile-screen.screen-sub {
    transform: translateX(100%);
  }

  .main-mobile-menu.submenu-active .main-mobile-screen.screen-main {
    transform: translateX(-100%);
  }

  .main-mobile-menu.submenu-active .main-mobile-screen.screen-sub {
    transform: translateX(0);
  }

  .main-mobile-list {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .main-mobile-item {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }

  .main-mobile-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    color: #2A2D40;
    border-bottom: 1px solid #2A2D4026;
    background: #FFFFFF;
    text-decoration: none;
    transition: background 0.2s ease;
    cursor: pointer;
    position: relative;
  }

  .main-mobile-link-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex: 1;
  }

  .main-mobile-link-wrapper span + .main-mobile-arrow-btn {
    width: 100%;
    justify-content: end;
  }

  .main-mobile-link-text {
    flex: 1;
    color: #2A2D40;
    text-decoration: none;
  }

  .main-mobile-arrow-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }

  .main-mobile-link > span {
    flex: 1;
  }

  .main-mobile-sublist {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .main-mobile-sublink, .main-mobile-title {
    display: block;
    padding: 14.5px 12px;
    line-height: 19px;
    color: #2A2D40;
    background: #FFFFFF;
    text-decoration: none;
    transition: background 0.2s ease;
  }

  .main-mobile-title {
    background: #2A2D4026;
    border-bottom: 1px solid #2A2D4026;
  }

  .main-mobile-submenu {
    display: none;
  }

  .main-mobile-submenu.active {
    display: block;
  }
}