/**
 * Адаптив: базовая ширина мобильных макетов — 375px.
 * Без горизонтальной прокрутки страницы (overflow только внутри category-nav).
 */

:root {
  --bp-mobile-max: 767px;
  --bp-mobile-base: 375px;
  --gutter-mobile: 16px;
  --gutter-mobile-xs: 12px;
}

html {
  overflow-x: clip;
  max-width: 100%;
}

body {
  overflow-x: clip;
  max-width: 100%;
  min-width: 320px;
}

.site-sticky-top,
.site-header,
.category-nav,
main,
.site-footer {
  max-width: 100%;
}

.container {
  width: 100%;
  max-width: min(var(--container), 100%);
}

img,
svg,
video,
iframe {
  max-width: 100%;
  height: auto;
}

/* Планшет и уже: горизонтальное меню категорий только внутри полосы */
@media (max-width: 1200px) {
  .category-nav.category-nav--mega {
    overflow: visible;
    max-width: 100%;
  }

  .category-nav--mega .category-nav-inner--mega,
  .category-nav-inner--mega {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: visible;
    max-width: 100%;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  /* Панель подменю ниже полосы — даём место, иначе overflow-x:auto обрезает выпадение */
  .category-nav--mega .category-nav-inner--mega:has(.category-nav-dropdown:hover),
  .category-nav--mega .category-nav-inner--mega:has(.category-nav-dropdown:focus-within),
  .category-nav--mega .category-nav-inner--mega:has(.category-nav-dropdown.is-open) {
    overflow: visible;
    padding-bottom: 260px;
    margin-bottom: -260px;
  }

  .category-nav-inner--mega::-webkit-scrollbar {
    display: none;
  }
}

/* Планшет: сетка без переполнения */
@media (min-width: 768px) and (max-width: 1024px) {
  .header-inner {
    display: grid;
    grid-template-columns: auto auto 1fr auto auto auto;
    grid-template-areas:
      "logo menu . lang fav cart"
      "search search search search search search";
    align-items: center;
    gap: 10px 12px;
    row-gap: 10px;
    height: auto;
    padding: 10px 0;
    max-width: 100%;
  }

  .header-logo {
    grid-area: logo;
  }

  .header-logo img {
    height: 56px;
  }

  .header-catalog-btn {
    grid-area: menu;
    padding: 10px 16px;
    font-size: 15px;
  }

  .header-search {
    grid-area: search;
    max-width: none;
    width: 100%;
    min-width: 0;
  }

  .header-cta,
  .header-phones,
  .mobile-menu-toggle {
    display: none !important;
  }

  .header-lang {
    grid-area: lang;
    justify-self: end;
  }

  .header-fav {
    grid-area: fav;
    justify-self: end;
  }

  .header-cart {
    grid-area: cart;
    justify-self: end;
  }

  .header-fav-btn,
  .header-cart-btn {
    width: 44px;
    height: 44px;
  }
}

/* Мобильный макет (от 375px и шире в portrait) — max 767px */
@media (max-width: 767px) {
  .container {
    padding-left: var(--gutter-mobile);
    padding-right: var(--gutter-mobile);
  }

  .site-sticky-top .container {
    padding-left: var(--gutter-mobile);
    padding-right: var(--gutter-mobile);
    max-width: 100%;
  }

  .site-header {
    border-bottom: none;
    background: var(--bg);
    overflow: visible;
  }

  .header-inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto auto;
    grid-template-rows: auto auto auto;
    grid-template-areas:
      "menu logo fav cart"
      "phones phones phones lang"
      "search search search search";
    align-items: center;
    gap: 8px 10px;
    row-gap: 10px;
    width: 100%;
    max-width: 100%;
    height: auto;
    min-height: 0;
    padding: 10px 0 12px;
  }

  .header-cta,
  .mobile-menu-toggle {
    display: none !important;
  }

  .header-catalog-btn {
    grid-area: menu;
    justify-self: start;
    padding: 10px 12px;
    border-radius: 12px;
    font-size: 0;
    gap: 0;
    min-width: 44px;
    justify-content: center;
  }

  .header-catalog-btn span {
    display: none;
  }

  .header-catalog-btn svg {
    width: 22px;
    height: 22px;
  }

  .header-logo {
    grid-area: logo;
    min-width: 0;
    max-width: 100%;
    justify-self: start;
    overflow: hidden;
  }

  .header-logo img {
    display: block;
    height: 44px;
    width: auto;
    max-width: min(168px, 46vw);
    object-fit: contain;
    object-position: left center;
  }

  .header-phones {
    grid-area: phones;
    display: flex !important;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 2px 12px;
    min-width: 0;
    max-width: 100%;
    justify-self: stretch;
  }

  .header-phones a {
    font-size: 13px;
    line-height: 1.25;
    white-space: nowrap;
  }

  .header-lang {
    grid-area: lang;
    display: block !important;
    justify-self: end;
    align-self: center;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
  }

  .header-lang.is-open {
    z-index: 50;
  }

  /* Вниз; поверх сетки шапки — координаты дополняет header-lang.js (fixed) */
  .header-lang-menu {
    top: calc(100% + 6px);
    bottom: auto;
    right: 0;
    left: auto;
    z-index: 1300;
    max-height: min(240px, 50dvh);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .header-lang-menu.is-fixed {
    position: fixed;
    right: auto;
    left: auto;
    margin: 0;
  }

  .header-lang-menu[hidden] {
    display: none !important;
    pointer-events: none;
  }

  .header-lang-btn {
    padding: 6px 8px;
    font-size: 13px;
  }

  .header-fav {
    grid-area: fav;
    justify-self: end;
    flex-shrink: 0;
  }

  .header-cart {
    grid-area: cart;
    justify-self: end;
    flex-shrink: 0;
  }

  .header-fav-btn,
  .header-cart-btn {
    width: 42px;
    height: 42px;
    border-radius: 12px;
  }

  .header-search {
    grid-area: search;
    align-self: stretch;
    position: relative;
    z-index: 1;
    min-width: 0;
    width: 100%;
    max-width: none;
    flex: none;
    margin: 0;
    padding-top: 10px;
    border-top: 1px solid var(--border);
    background: var(--bg);
  }

  .header-search input {
    width: 100%;
    min-width: 0;
    padding-top: 11px;
    padding-bottom: 11px;
    font-size: 16px;
    border-radius: 12px;
    background: var(--bg-alt);
    border: 1.5px solid var(--border);
    box-shadow: none;
  }

  .header-search input:focus {
    background: #fff;
    box-shadow: 0 0 0 3px rgba(76, 184, 214, 0.15);
  }

  .site-sticky-top {
    box-shadow: none;
  }

  .hero-section {
    padding-top: 16px;
  }

  /* На мобильных пункты каталога — в шторе «Меню», полосу скрываем */
  .category-nav.category-nav--mega {
    display: none;
  }

  .category-nav .container {
    padding-left: 0;
    padding-right: 0;
    max-width: 100%;
  }

  .category-nav--mega .category-nav-inner--mega,
  .category-nav-inner--mega {
    padding-left: var(--gutter-mobile);
    padding-right: var(--gutter-mobile);
    scroll-padding-inline: var(--gutter-mobile);
    mask-image: none;
  }

  .category-nav-dropdown__panel {
    min-width: min(280px, calc(100% - var(--gutter-mobile) * 2));
    max-width: calc(100% - var(--gutter-mobile) * 2);
  }

  .hero-section,
  .hero-grid,
  .section,
  .product-page,
  .catalog-layout {
    max-width: 100%;
  }

  .brands-row {
    flex-wrap: wrap;
    justify-content: center;
    max-width: 100%;
    overflow-x: clip;
  }

  .proposal-modal.is-open {
    align-items: flex-end;
    padding-bottom: max(8px, env(safe-area-inset-bottom, 0px));
  }

  .proposal-modal__dialog {
    width: 100%;
    max-width: 100%;
    max-height: min(92dvh, calc(100dvh - 12px));
    border-radius: 16px 16px 0 0;
    padding: 18px 16px 16px;
  }

  .proposal-modal__title {
    font-size: 22px;
    padding-right: 40px;
  }

  .proposal-modal__subtitle {
    font-size: 14px;
    margin-bottom: 14px;
  }

  .proposal-form__field textarea {
    min-height: 72px;
    max-height: 120px;
    resize: vertical;
  }
}

/* Узкие экраны: 320–389px (целевой минимум — 375px) */
@media (max-width: 389px) {
  .container,
  .site-sticky-top .container {
    padding-left: var(--gutter-mobile-xs);
    padding-right: var(--gutter-mobile-xs);
  }

  .header-inner {
    gap: 6px 6px;
    row-gap: 8px;
    padding: 8px 0 10px;
    grid-template-columns: auto minmax(0, 1fr) auto auto;
  }

  .header-logo img {
    height: 36px;
    max-width: min(140px, 44vw);
  }

  .header-fav-btn,
  .header-cart-btn {
    width: 38px;
    height: 38px;
  }

  .header-catalog-btn {
    padding: 9px;
  }

  .header-phones {
    gap: 2px 10px;
  }

  .header-phones a {
    font-size: 12px;
  }

  .header-lang-btn {
    padding: 5px 8px;
    font-size: 12px;
  }

  .category-nav--mega .category-nav-inner--mega,
  .category-nav-inner--mega {
    padding-left: var(--gutter-mobile-xs);
    padding-right: var(--gutter-mobile-xs);
    scroll-padding-inline: var(--gutter-mobile-xs);
  }

  .category-nav-item--top,
  .category-nav-dropdown__trigger,
  .category-nav-dropdown__title {
    padding: 10px 11px;
    font-size: 13px;
  }
}

/* Ровно от 375px: можно показать текст «Меню», если помещается */
@media (min-width: 375px) and (max-width: 767px) {
  .header-catalog-btn span {
    display: inline;
    font-size: 13px;
  }

  .header-catalog-btn {
    padding: 9px 12px;
  }
}
