/* ===== ГЛОБАЛЬНЫЕ НАСТРОЙКИ ===== */
:root {
  --color-main: #3e2828; /* Основной тёмно-коричневый цвет текста и кнопок. */
  --color-bg: #e9e4de; /* Основной бежевый фон для шапки, подвала и карточек. */
  --color-dropdown: #e9e4de; /* Основной бежевый фон для шапки, подвала и карточек. */
  --color-light: #f7f3ef; /* Светлый фон для внутренних блоков и полей. */
  --color-soft: #fffaf4; /* Очень светлый фон для блока ответа администратора. */
  --color-accent: #73523b; /* Акцентный коричневый цвет для фокуса и слайдера. */
  --color-danger: #8b2f2f; /* Красный цвет для удаления и бейджей. */
  --color-success-text: #27442a; /* Цвет текста успешного сообщения. */
  --color-success-bg: #e5f1e1; /* Фон успешного сообщения. */
  --color-error-text: #762626; /* Цвет текста ошибки. */
  --color-error-bg: #f3dddd; /* Фон сообщения об ошибке. */
  --font-light: "fl", sans-serif; /* Лёгкое начертание Montserrat Alternates. */
  --font-regular: "fr", sans-serif; /* Обычное начертание Montserrat Alternates. */
  --font-medium: "fm", sans-serif; /* Среднее начертание Montserrat Alternates. */
  --header-height: 80px; /* Высота фиксированной шапки на компьютере. */
  --footer-min-height: 210px; /* Минимальная высота подвала для расчёта страницы. */
  --container-wide: 84%; /* Ширина широких блоков сайта. */
  --container-page: min(84%, 1180px); /* Ширина внутренних страниц. */
  --radius-small: 16px; /* Малое скругление. */
  --radius-medium: 20px; /* Среднее скругление. */
  --radius-large: 28px; /* Большое скругление карточек. */
  --radius-pill: 999px; /* Полностью круглые кнопки и бейджи. */
  --shadow-soft: 0 8px 24px rgba(62, 40, 40, 0.12); /* Мягкая тень карточек. */
  --shadow-card: 0 8px 24px rgba(62, 40, 40, 0.18); /* Более заметная тень карточек. */
  --transition-base: 0.2s ease; /* Единая плавность анимаций. */
}

@font-face {
  font-family: "fl"; /* Название лёгкого шрифта. */
  src: url("/fonts/MontserratAlternates-Light.ttf"); /* Путь к файлу лёгкого шрифта. */
}

@font-face {
  font-family: "fr"; /* Название обычного шрифта. */
  src: url("/fonts/MontserratAlternates-Regular.ttf"); /* Путь к файлу обычного шрифта. */
}

@font-face {
  font-family: "fm"; /* Название среднего шрифта. */
  src: url("/fonts/MontserratAlternates-Medium.ttf"); /* Путь к файлу среднего шрифта. */
}

* {
  box-sizing: border-box; /* Учитывает padding и border внутри ширины элемента. */
}

html {
  min-height: 100%; /* Даёт странице минимальную высоту на весь экран. */
}

body {
  width: 100%; /* Растягивает body на всю ширину окна. */
  min-height: 100vh; /* Растягивает body минимум на высоту экрана. */
  display: flex; /* Включает flex-раскладку для прижатия подвала вниз. */
  flex-direction: column; /* Располагает шапку, main и подвал вертикально. */
  overflow-x: hidden; /* Убирает горизонтальную прокрутку от широких блоков. */
}

main {
  flex: 1 0 auto; /* Заставляет основной контент занимать свободное место. */
  width: 100%; /* Растягивает main на всю ширину. */
  margin-top: var(--header-height); /* Отступает от фиксированной шапки, чтобы контент не уходил под неё. */
  position: relative; /* Создаёт слой для контента над фоном страницы. */
  z-index: 1; /* Держит контент выше фоновых элементов, но ниже фиксированной шапки. */
}

a {
  color: var(--color-main); /* Делает ссылки основного коричневого цвета. */
  text-decoration: none; /* Убирает подчёркивание ссылок. */
}

img {
  max-width: 100%; /* Запрещает изображениям вылезать за контейнер. */
}

h2 {
  color: var(--color-main); /* Задаёт цвет заголовков второго уровня. */
  font-family: var(--font-medium); /* Подключает среднее начертание для h2. */
  font-size: 30px; /* Задаёт размер h2. */
  margin-left: 40px; /* Сохраняет старый отступ h2 слева. */
  padding-top: 40px; /* Сохраняет старний верхний отступ h2. */
}

h3 {
  font-family: var(--font-medium); /* Делает h3 средним начертанием. */
  font-size: 18px; /* Задаёт размер h3. */
  padding-bottom: 15px; /* Добавляет нижний отступ h3. */
}

h4 {
  color: var(--color-main); /* Делает h4 основного цвета. */
  font-family: var(--font-medium); /* Делает h4 средним начертанием. */
  font-size: 20px; /* Задаёт размер h4. */
  padding-bottom: 5px; /* Добавляет нижний отступ h4. */
  text-align: center; /* Центрирует h4. */
}

hr {
  width: 90%; /* Делает линию почти на всю ширину страницы. */
  margin: 0 auto 40px; /* Центрирует линию и добавляет нижний отступ. */
}

/* ===== ШАПКА ===== */
header {
  width: 100%; /* Растягивает шапку на всю ширину. */
  height: var(--header-height); /* Использует единую высоту шапки. */
  position: fixed; /* Закрепляет шапку сверху экрана. */
  top: 0; /* Прижимает шапку к верхней границе. */
  left: 0; /* Прижимает шапку к левой границе. */
  z-index: 1000; /* Показывает шапку поверх остального контента. */
  background-color: var(--color-bg); /* Задаёт бежевый фон шапки. */
  color: var(--color-main); /* Задаёт цвет текста в шапке. */
  font-family: var(--font-medium); /* Задаёт шрифт шапки. */
}

.header-nav {
  width: 80%; /* Ограничивает ширину навигации. */
  min-height: var(--header-height); /* Сохраняет высоту шапки внутри. */
  margin: 0 auto; /* Центрирует навигацию. */
  display: flex; /* Расставляет логотип, меню и действия в строку. */
  align-items: center; /* Центрирует элементы по вертикали. */
  justify-content: space-between; /* Разводит элементы по краям. */
  gap: 18px; /* Добавляет расстояние между группами. */
}

nav ul {
  display: flex; /* Показывает пункты меню в строку. */
  align-items: center; /* Центрирует пункты меню по вертикали. */
  justify-content: space-between; /* Равномерно распределяет пункты. */
  gap: 40px; /* Добавляет расстояние между пунктами. */
  list-style-type: none; /* Убирает маркеры списка. */
}

.header-actions {
  display: flex; /* Расставляет корзину и аккаунт в строку. */
  align-items: center; /* Центрирует действия по вертикали. */
  gap: 18px; /* Добавляет расстояние между действиями. */
}

.lk {
  position: relative; /* Позволяет выпадающему меню позиционироваться от иконки. */
  display: flex; /* Центрирует иконку личного кабинета. */
  align-items: center; /* Выравнивает иконку по вертикали. */
  opacity: 50%; /* Сохраняет полупрозрачность иконки. */
}

.account {
  position: relative; /* Создаёт привязку для dropdown. */
  cursor: pointer; /* Показывает, что элемент кликабельный. */
}

.dropdown {
  display: none; /* Скрывает меню по умолчанию. */
  position: absolute; /* Позволяет меню выпадать поверх страницы. */
  right: 0; /* Прижимает меню к правому краю иконки. */
  top: 55px; /* Опускает меню под иконку. */
  min-width: 160px; /* Задаёт минимальную ширину меню. */
  z-index: 1000; /* Показывает меню поверх контента. */
  background: var(--color-dropdown); /* Задаёт бежевый фон меню. */
  border-radius: 6px; /* Скругляет углы меню. */
  box-shadow: 0 4px 10px var(--color-main); /* Добавляет тень меню. */
}

.dropdown.show {
  display: block; /* Показывает меню при добавлении класса show. */
}

.dropdown a {
  display: block; /* Растягивает ссылку на всю ширину пункта. */
  padding: 10px 15px; /* Добавляет внутренние отступы пункта. */
  color: var(--color-main); /* Делает текст пункта основного цвета. */
  text-decoration: none; /* Убирает подчёркивание пункта. */
  font-family: var(--font-regular); /* Подключает обычный шрифт пункта. */
}

.dropdown a:hover {
  background: #eae8e5; /* Подсвечивает пункт меню при наведении. */
}

.cart-link {
  position: relative; /* Нужен для позиционирования бейджа количества. */
  display: inline-flex; /* Делает ссылку-корзину гибким элементом. */
  align-items: center; /* Центрирует содержимое корзины по вертикали. */
  justify-content: center; /* Центрирует содержимое корзины по горизонтали. */
  gap: 8px; /* Добавляет расстояние между иконкой и текстом. */
  min-height: 44px; /* Задаёт удобную высоту клика. */
  padding: 0 16px; /* Добавляет боковые отступы. */
  border: 1px solid rgba(62, 40, 40, 0.25); /* Добавляет тонкую рамку. */
  border-radius: var(--radius-pill); /* Делает кнопку округлой. */
  background: rgba(255, 250, 244, 0.45); /* Добавляет светлый полупрозрачный фон. */
  color: var(--color-main); /* Делает текст основного цвета. */
  font-family: var(--font-medium); /* Делает текст корзины средним. */
}

.cart-badge {
  position: absolute; /* Размещает бейдж поверх кнопки корзины. */
  top: -8px; /* Поднимает бейдж вверх. */
  right: -8px; /* Сдвигает бейдж вправо. */
  display: inline-flex; /* Центрирует число внутри бейджа. */
  align-items: center; /* Центрирует число по вертикали. */
  justify-content: center; /* Центрирует число по горизонтали. */
  min-width: 22px; /* Задаёт минимальную ширину бейджа. */
  height: 22px; /* Задаёт высоту бейджа. */
  padding: 0 6px; /* Добавляет боковой отступ для двухзначных чисел. */
  border-radius: var(--radius-pill); /* Делает бейдж круглым. */
  background: var(--color-danger); /* Делает бейдж красным. */
  color: #ffffff; /* Делает цифру белой. */
  font-size: 12px; /* Задаёт размер цифры. */
  line-height: 1; /* Убирает лишнюю высоту строки. */
}

/* ===== СЛАЙДЕР ===== */
.slaider {
  max-width: 1275px; /* Ограничивает ширину слайдера. */
  height: 520px; /* Задаёт высоту слайдера. */
  margin: 80px auto 0; /* Центрирует слайдер и сохраняет верхний отступ. */
  display: flex; /* Включает flex для внутреннего содержимого. */
}

.slaidshow {
  max-width: 1440px; /* Ограничивает ширину области показа. */
  margin: 0 auto; /* Центрирует область показа. */
  overflow: hidden; /* Скрывает лишние слайды за пределами блока. */
}

.slaides {
  width: 1440px; /* Задаёт ширину ленты слайдов. */
  display: flex; /* Располагает слайды в строку. */
  transition: 1s; /* Добавляет плавное движение слайдов. */
}

.slaid {
  width: 1350px; /* Задаёт ширину одного слайда. */
  height: 520px; /* Задаёт высоту одного слайда. */
  display: flex; /* Включает flex для содержимого слайда. */
  justify-content: space-between; /* Разводит элементы слайда по краям. */
  align-content: center; /* Центрирует строки внутри слайда. */
  position: relative; /* Нужен для абсолютного заголовка. */
}

.slaid h1 {
  position: absolute; /* Размещает заголовок поверх слайда. */
  top: 150px; /* Задаёт отступ сверху. */
  left: 500px; /* Задаёт отступ слева. */
  width: 40%; /* Ограничивает ширину заголовка. */
  font-family: var(--font-medium); /* Подключает средний шрифт. */
  font-size: 70px; /* Задаёт крупный размер заголовка. */
  cursor: pointer; /* Показывает кликабельность заголовка. */
  text-shadow: 0 0 3px var(--color-main); /* Добавляет лёгкую тень текста. */
}

.button-slaider {
  position: absolute; /* Размещает кнопки поверх слайдера. */
  z-index: 1; /* Поднимает кнопки над изображением. */
  width: 100%; /* Растягивает блок кнопок на ширину контейнера. */
  max-width: 1275px; /* Ограничивает ширину кнопок шириной слайдера. */
  height: 570px; /* Задаёт высоту области кнопок. */
  margin: 0 auto; /* Центрирует область кнопок. */
  display: flex; /* Включает flex для кнопок. */
  align-items: flex-end; /* Прижимает кнопки к низу. */
  justify-content: center; /* Центрирует кнопки по горизонтали. */
}

.block-button {
  width: 325px; /* Задаёт ширину блока переключателей. */
  margin-bottom: 20px; /* Добавляет отступ снизу. */
  display: flex; /* Расставляет переключатели в строку. */
  justify-content: space-between; /* Равномерно распределяет переключатели. */
}

.block-button div {
  width: 90px; /* Задаёт ширину одного переключателя. */
  height: 5px; /* Задаёт высоту одного переключателя. */
  border: 1px solid var(--color-accent); /* Добавляет рамку переключателя. */
  border-radius: 20px; /* Скругляет переключатель. */
}

.click-but {
  background-color: var(--color-accent); /* Закрашивает активный переключатель. */
}

/* ===== ГЛАВНАЯ: ПРОМО И КОЛЛЕКЦИЯ ===== */
.block2 {
  width: var(--container-wide); /* Задаёт ширину промо-блока. */
  height: auto; /* Позволяет блоку растягиваться по содержимому. */
  margin: 60px auto 0; /* Центрирует блок и добавляет верхний отступ. */
  background-image: url("/img/bgimg1.png"); /* Подключает фон промо-блока. */
  background-size: cover; /* Растягивает фон на весь блок. */
}

.headercardsin2blok {
  position: relative; /* Нужен для абсолютной кнопки внутри. */
  width: 80%; /* Ограничивает ширину шапки карточек. */
  margin: 0 auto; /* Центрирует шапку карточек. */
  padding-top: 100px; /* Добавляет верхний отступ. */
  display: flex; /* Расставляет элементы в строку. */
  align-items: center; /* Центрирует элементы по вертикали. */
  justify-content: space-between; /* Разводит элементы по краям. */
}

.headercardsin2blok button {
  position: absolute; /* Размещает кнопку поверх блока. */
  top: 110px; /* Задаёт отступ кнопки сверху. */
  z-index: 100; /* Поднимает кнопку над карточками. */
  width: 260px; /* Задаёт ширину кнопки. */
  height: 60px; /* Задаёт высоту кнопки. */
  border: none; /* Убирает рамку кнопки. */
  border-radius: 30px; /* Скругляет кнопку. */
  background-color: var(--color-main); /* Делает кнопку тёмной. */
}

.headercardsin2blok button a {
  color: var(--color-bg); /* Делает ссылку внутри кнопки бежевой. */
  font-family: var(--font-medium); /* Делает текст кнопки средним. */
  font-size: 18px; /* Задаёт размер текста кнопки. */
}

.card {
  margin-bottom: 40px; /* Добавляет нижний отступ карточкам. */
  display: flex; /* Расставляет карточки в строку. */
  flex-wrap: wrap; /* Разрешает перенос карточек на новую строку. */
  align-items: center; /* Центрирует карточки по вертикали. */
  justify-content: center; /* Центрирует карточки по горизонтали. */
}

.showmore {
  width: 20%; /* Задаёт ширину блока «показать ещё». */
  margin: 0 auto; /* Центрирует блок. */
  padding-bottom: 40px; /* Добавляет нижний отступ. */
  display: flex; /* Расставляет элементы в строку. */
  flex-wrap: wrap; /* Разрешает перенос элементов. */
  align-items: center; /* Центрирует элементы по вертикали. */
  justify-content: center; /* Центрирует элементы по горизонтали. */
  gap: 20px; /* Добавляет расстояние между элементами. */
}

.showmore button {
  border: none; /* Убирает рамку у кнопки. */
}

.showmore p {
  color: var(--color-main); /* Делает текст основного цвета. */
  font-family: var(--font-regular); /* Подключает обычный шрифт. */
  font-size: 18px; /* Задаёт размер текста. */
}

.block3 {
  width: var(--container-wide); /* Задаёт ширину блока новой коллекции. */
  margin: 0 auto 90px; /* Центрирует блок и задаёт нижний отступ. */
  padding-top: 60px; /* Добавляет верхний отступ. */
}

.collectionSlide {
  position: relative; /* Нужен для текста и кнопки поверх картинки. */
  display: flex; /* Включает flex-раскладку. */
}

.collectionSlide img {
  width: 1275px; /* Сохраняет исходную ширину изображения коллекции. */
}

.collectionSlide a {
  position: absolute; /* Размещает текст поверх изображения. */
  top: 250px; /* Задаёт отступ текста сверху. */
  left: 200px; /* Задаёт отступ текста слева. */
  z-index: 10; /* Поднимает текст над изображением. */
  width: 40%; /* Ограничивает ширину текста. */
  color: var(--color-bg); /* Делает текст бежевым. */
  font-family: var(--font-medium); /* Делает текст средним. */
  font-size: 100px; /* Задаёт крупный размер текста. */
  text-shadow: 10px 2px 3px var(--color-main); /* Добавляет выразительную тень. */
}

.collectionSlide button {
  position: absolute; /* Размещает кнопку поверх изображения. */
  top: 300px; /* Задаёт отступ кнопки сверху. */
  width: 260px; /* Задаёт ширину кнопки. */
  height: 60px; /* Задаёт высоту кнопки. */
  border: none; /* Убирает рамку кнопки. */
  border-radius: 30px; /* Скругляет кнопку. */
  background-color: var(--color-main); /* Делает кнопку тёмной. */
  color: var(--color-bg); /* Делает текст кнопки бежевым. */
  font-family: var(--font-medium); /* Делает текст кнопки средним. */
  font-size: 18px; /* Задаёт размер текста кнопки. */
}

/* ===== ПОДВАЛ ===== */
footer {
  position: relative; /* Держит подвал в обычном потоке страницы. */
  bottom: auto; /* Убирает ручную привязку к низу, чтобы не было наложения. */
  left: auto; /* Не сдвигает подвал слева. */
  right: auto; /* Не сдвигает подвал справа. */
  z-index: 0; /* Оставляет подвал ниже основного контента. */
  width: 100%; /* Растягивает подвал на всю ширину. */
  flex-shrink: 0; /* Запрещает подвалу сжиматься. */
  margin-top: auto; /* Прижимает подвал вниз, если контента мало. */
  clear: both; /* Не даёт float-элементам заходить на подвал. */
  background-color: var(--color-bg); /* Задаёт бежевый фон подвала. */
}

.footerblocks {
  width: min(90%, 860px); /* Ограничивает ширину содержимого подвала. */
  min-height: 150px; /* Сохраняет минимальную высоту подвала. */
  height: auto; /* Позволяет подвалу расти, если текста больше. */
  margin: 0 auto; /* Центрирует содержимое подвала. */
  padding: 30px 0 24px; /* Добавляет отступы сверху и снизу. */
  display: flex; /* Расставляет колонки подвала в строку. */
  align-items: flex-start; /* Выравнивает колонки по верхнему краю. */
  justify-content: space-between; /* Разводит колонки по ширине. */
  gap: 30px; /* Добавляет расстояние между колонками. */
}

.footerblocks ul {
  list-style-type: none; /* Убирает маркеры списка. */
  text-decoration: none; /* Убирает оформление текста. */
  font-family: var(--font-regular); /* Задаёт обычный шрифт спискам. */
  font-size: 18px; /* Задаёт размер пунктов подвала. */
}

.footerblocks li {
  padding-bottom: 10px; /* Добавляет отступ между пунктами. */
}

.textunder {
  text-align: center; /* Центрирует нижнюю подпись. */
  font-family: var(--font-regular); /* Задаёт обычный шрифт подписи. */
}

/* ===== СТРАНИЦА «О НАС» ===== */
.AboutUs-block1 {
  width: 80%; /* Ограничивает ширину первого блока. */
  height: 520px; /* Задаёт высоту первого блока. */
  margin: 0 auto; /* Центрирует первый блок. */
  padding-top: 100px; /* Добавляет верхний отступ. */
  text-align: center; /* Центрирует текст внутри блока. */
  background-image: url("/img/aboutUs.png"); /* Подключает фоновое изображение. */
}

.AboutUs-block1 h1 {
  color: var(--color-main); /* Делает заголовок основного цвета. */
  font-family: var(--font-medium); /* Делает заголовок средним. */
  font-size: 35px; /* Задаёт размер заголовка. */
  padding-bottom: 60px; /* Добавляет нижний отступ заголовка. */
}

.aboutBrand {
  width: 350px; /* Задаёт ширину текстового блока бренда. */
  margin: 0 auto; /* Центрирует блок бренда. */
  padding-top: 100px; /* Добавляет верхний отступ. */
  padding-left: 50%; /* Сдвигает блок вправо по макету. */
  display: flex; /* Включает flex для содержимого. */
  flex-wrap: wrap; /* Разрешает перенос элементов. */
  align-items: center; /* Центрирует элементы по вертикали. */
  justify-content: center; /* Центрирует элементы по горизонтали. */
}

.aboutBrand p {
  color: var(--color-main); /* Делает текст основного цвета. */
  font-family: var(--font-medium); /* Делает текст средним. */
  font-size: 20px; /* Задаёт размер текста. */
  padding-bottom: 20px; /* Добавляет нижний отступ. */
}

.aboutBrand button {
  width: 200px; /* Задаёт ширину кнопки. */
  height: 60px; /* Задаёт высоту кнопки. */
  border: none; /* Убирает рамку кнопки. */
  border-radius: 30px; /* Скругляет кнопку. */
  background-color: var(--color-main); /* Делает кнопку тёмной. */
  color: var(--color-bg); /* Делает текст кнопки бежевым. */
  font-family: var(--font-medium); /* Делает текст кнопки средним. */
  font-size: 20px; /* Задаёт размер текста кнопки. */
}

.aboutUs-promo {
  width: 80%; /* Ограничивает ширину промо-разделителя. */
  margin: 0 auto; /* Центрирует промо-разделитель. */
}

.AboutUs-block2 {
  width: 80%; /* Ограничивает ширину второго блока. */
  margin: 0 auto; /* Центрирует второй блок. */
  background-image: url("/img/bgAboutUs.png"); /* Подключает фон второго блока. */
}

.aboutUS-foundress {
  padding-top: 40px; /* Добавляет верхний отступ. */
  display: flex; /* Расставляет основательниц в строку. */
  align-items: center; /* Центрирует блоки по вертикали. */
  justify-content: center; /* Центрирует блоки по горизонтали. */
  gap: 40px; /* Добавляет расстояние между блоками. */
}

.aboutUS-foundress div {
  text-align: center; /* Центрирует подписи. */
  font-family: var(--font-medium); /* Делает подписи средним шрифтом. */
}

.aboutUS-foundress div p {
  padding-top: 10px; /* Добавляет отступ между картинкой и подписью. */
  font-size: 20px; /* Задаёт размер подписи. */
}

.aboutUs-block2Text {
  color: var(--color-main); /* Делает текст основного цвета. */
  font-family: var(--font-medium); /* Делает текст средним. */
  font-size: 30px; /* Задаёт размер текста. */
  padding: 40px 0 35px 200px; /* Задаёт отступы текста по макету. */
}

/* ===== КАТАЛОГ ===== */
.catalog {
  margin-top: 50px;  /* Добавляет верхний отступ заголовку каталога. */
  margin-bottom: 40px; /* Добавляет нижний отступ заголовку каталога. */
  color: var(--color-main); /* Делает заголовок основного цвета. */
  font-family: var(--font-medium); /* Делает заголовок средним. */
  font-size: 30px; /* Задаёт размер заголовка. */
  text-align: center; /* Центрирует заголовок. */
}

.catalog-cards {
  width: min(90%, 1180px); /* Ограничивает ширину сетки каталога. */
  margin: 0 auto; /* Центрирует сетку каталога. */
  padding-bottom: 60px; /* Добавляет нижний отступ сетки. */
  display: grid; /* Использует адаптивную сетку вместо повторяющегося flex. */
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); /* Создаёт адаптивные колонки карточек. */
  align-items: stretch; /* Растягивает карточки по высоте. */
  justify-content: center; /* Центрирует сетку. */
  gap: 28px; /* Задаёт расстояние между карточками. */
}

.catalog-card {
  width: 100%; /* Растягивает карточку на ширину ячейки сетки. */
  min-height: 100%; /* Выравнивает высоту карточек. */
  padding: 18px; /* Добавляет внутренние отступы карточки. */
  border-radius: var(--radius-large); /* Скругляет углы карточки. */
  background: var(--color-bg); /* Задаёт фон карточки. */
  box-shadow: var(--shadow-soft); /* Добавляет мягкую тень. */
  display: flex; /* Включает flex внутри карточки. */
  flex-wrap: wrap; /* Разрешает перенос содержимого. */
  align-items: center; /* Центрирует содержимое по вертикали. */
  justify-content: center; /* Центрирует содержимое по горизонтали. */
  gap: 10px; /* Добавляет расстояние между элементами. */
  transition: var(--transition-base); /* Делает hover плавным. */
}

.catalog-card:hover {
  transform: translateY(-4px); /* Поднимает карточку при наведении. */
  box-shadow: 0 12px 28px rgba(62, 40, 40, 0.18); /* Усиливает тень при наведении. */
}

.catalog-card img {
  width: 100%; /* Растягивает картинку в пределах карточки. */
  max-width: 220px; /* Ограничивает ширину картинки. */
  aspect-ratio: 1 / 1; /* Делает область изображения квадратной. */
  object-fit: contain; /* Показывает изображение целиком. */
  display: block; /* Убирает лишние зазоры у изображения. */
  margin: 0 auto 10px; /* Центрирует картинку и добавляет нижний отступ. */
}

.catalog-card p {
  color: var(--color-main); /* Делает текст карточки основного цвета. */
  font-family: var(--font-regular); /* Делает текст обычным шрифтом. */
  font-size: 18px; /* Задаёт размер текста карточки. */
  padding-bottom: 5px; /* Добавляет нижний отступ текста. */
  text-align: center; /* Центрирует текст карточки. */
}

.catalog-card button {
  padding: 5px 19px; /* Задаёт внутренние отступы кнопки. */
  border: none; /* Убирает рамку кнопки. */
  border-radius: 20px; /* Скругляет кнопку. */
  background-color: var(--color-main); /* Делает кнопку тёмной. */
  color: var(--color-bg); /* Делает текст кнопки бежевым. */
  font-family: var(--font-regular); /* Делает текст кнопки обычным. */
  font-size: 18px; /* Задаёт размер текста кнопки. */
  text-align: center; /* Центрирует текст кнопки. */
}

.catalog-card__body {
  width: 100%; /* Растягивает текстовую часть на всю карточку. */
  display: grid; /* Располагает элементы текстовой части сеткой. */
  gap: 6px; /* Добавляет расстояние между строками. */
}

.catalog-card__desc {
  min-height: 42px; /* Выравнивает высоту описаний. */
  line-height: 1.35; /* Увеличивает читаемость описания. */
  opacity: 0.75; /* Делает описание визуально второстепенным. */
}

.catalog-card__price {
  margin-top: 4px; /* Добавляет небольшой отступ над ценой. */
  font-family: var(--font-medium) !important; /* Выделяет цену средним шрифтом. */
  font-size: 20px !important; /* Делает цену крупнее описания. */
}

.catalog-card__form {
  width: 100%; /* Растягивает форму на всю ширину карточки. */
  margin-top: auto; /* Прижимает форму к низу карточки. */
  display: flex; /* Центрирует кнопку формы. */
  justify-content: center; /* Центрирует кнопку по горизонтали. */
}

.catalog-card__form button,
.cart-summary .btn-primary,
.cart-summary .btn-secondary {
  width: 100%; /* Делает кнопки в карточках и итогах полной ширины. */
}

/* ===== НОВАЯ КОЛЛЕКЦИЯ ===== */
.newCollection-promo {
  width: 80%; /* Ограничивает ширину промо-блока коллекции. */
  margin: 0 auto; /* Центрирует промо-блок. */
  padding-top: 100px; /* Добавляет верхний отступ. */
  padding-bottom: 40px; /* Добавляет нижний отступ. */
  display: flex; /* Расставляет элементы в строку. */
  align-items: center; /* Центрирует элементы по вертикали. */
  justify-content: center; /* Центрирует элементы по горизонтали. */
  gap: 60px; /* Добавляет расстояние между элементами. */
}

.newCollection-promo p {
  color: var(--color-main); /* Делает текст основного цвета. */
  font-family: var(--font-medium); /* Делает текст средним. */
  font-size: 20px; /* Задаёт размер текста. */
}

.newCollection-block2 h3 {
  text-align: center; /* Центрирует заголовок второго блока коллекции. */
}

.newcollectionBlock2 {
  width: 80%; /* Ограничивает ширину второго блока коллекции. */
  margin: 0 auto; /* Центрирует блок коллекции. */
  padding-bottom: 40px; /* Добавляет нижний отступ. */
  display: flex; /* Расставляет элементы коллекции в строку. */
  align-items: center; /* Центрирует элементы по вертикали. */
  justify-content: space-between; /* Разводит элементы по ширине. */
  gap: 30px; /* Добавляет расстояние между элементами. */
}

.newcollectionBlock2 li {
  list-style-type: none; /* Убирает маркеры списка. */
  text-decoration: none; /* Убирает оформление ссылок/текста. */
}

/* ===== ФОРМЫ, РЕГИСТРАЦИЯ И ТАБЛИЦЫ ===== */
.registration-form {
  width: 100%; /* Растягивает форму на доступную ширину. */
  max-width: 400px; /* Ограничивает максимальную ширину формы. */
  margin: 0 auto 60px; /* Центрирует форму и добавляет нижний отступ. */
  padding: 30px 40px; /* Добавляет внутренние отступы формы. */
  border-radius: 10px; /* Скругляет форму. */
  background-color: var(--color-bg); /* Задаёт фон формы. */
  box-shadow: 0 4px 15px var(--color-main); /* Добавляет тень формы. */
}

.registration-form input {
  width: 100%; /* Растягивает поля на ширину формы. */
  margin: 8px 0; /* Добавляет вертикальные отступы полям. */
  padding: 12px; /* Добавляет внутренний отступ полям. */
  border: none; /* Убирает рамку полей. */
  border-radius: 20px; /* Скругляет поля. */
}

.registration-form button {
  width: 100%; /* Растягивает кнопку на ширину формы. */
  margin-top: 15px; /* Добавляет верхний отступ кнопки. */
  padding: 12px; /* Добавляет внутренний отступ кнопки. */
  border: none; /* Убирает рамку кнопки. */
  border-radius: 20px; /* Скругляет кнопку. */
  background-color: var(--color-main); /* Делает кнопку тёмной. */
  color: var(--color-bg); /* Делает текст кнопки бежевым. */
  font-family: var(--font-regular); /* Делает текст кнопки обычным. */
  font-size: 18px; /* Задаёт размер текста кнопки. */
  cursor: pointer; /* Показывает кликабельность кнопки. */
}

.registration-form button:hover {
  background-color: #45a049; /* Подсвечивает кнопку регистрации при наведении. */
}

.registration-form .link {
  margin-top: 10px; /* Добавляет отступ над ссылкой. */
  text-align: center; /* Центрирует ссылку. */
  font-family: var(--font-regular); /* Делает ссылку обычным шрифтом. */
}

.registration-form .link a {
  color: #4caf50; /* Делает ссылку зелёной. */
  text-decoration: none; /* Убирает подчёркивание ссылки. */
}

.table {
  width: 80%; /* Ограничивает ширину таблицы. */
  margin: 0 auto; /* Центрирует таблицу. */
  color: var(--color-main); /* Делает текст таблицы основного цвета. */
  font-family: var(--font-regular); /* Делает текст таблицы обычным. */
}

tbody {
  text-align: center; /* Центрирует содержимое таблицы. */
}

td {
  border: 1px solid var(--color-main); /* Добавляет рамку ячейкам. */
}

.red {
  width: 100%; /* Растягивает блок редактирования на всю ширину. */
}

.red option,
.red label {
  color: var(--color-main); /* Делает текст option и label основного цвета. */
  font-family: var(--font-regular); /* Делает текст option и label обычным. */
}

.red label {
  width: 100%; /* Растягивает label на всю ширину. */
}

/* ===== СТРАНИЦЫ ЛИЧНОГО КАБИНЕТА, ЗАЯВОК И ЗАКАЗОВ ===== */
.page-panel {
  width: var(--container-page); /* Ограничивает ширину личного кабинета. */
  min-height: calc(100vh - var(--header-height) - var(--footer-min-height)); /* Не даёт подвалу подниматься на контент. */
  margin: 0 auto; /* Центрирует страницу. */
  padding-top: 60px; /* Делает аккуратный отступ сверху внутри страницы. */
  padding-bottom: 80px; /* Добавляет нижний отступ перед подвалом. */
}

.page-panel > .catalog:first-child {
  margin-top: 0; /* Убирает лишний верхний отступ у первого заголовка внутри кабинета. */
}

.statementh1 {
  padding-bottom: 40px; /* Добавляет нижний отступ заголовку заявок. */
  color: var(--color-main); /* Делает заголовок основного цвета. */
  font-family: var(--font-medium); /* Делает заголовок средним. */
  font-size: 35px; /* Задаёт размер заголовка. */
  text-align: center; /* Центрирует заголовок. */
}

.statements-wrap {
  width: 100%; /* Растягивает блок заявок на ширину контейнера. */
  max-width: 980px; /* Ограничивает ширину списка заявок. */
  margin: 0 auto; /* Центрирует список заявок. */
  display: grid; /* Располагает заявки вертикальной сеткой. */
  gap: 24px; /* Добавляет расстояние между заявками. */
}

.statement-card,
.order-card {
  padding: 28px; /* Добавляет внутренние отступы карточки. */
  border-radius: var(--radius-large); /* Скругляет карточку. */
  background: var(--color-bg); /* Задаёт бежевый фон карточки. */
  box-shadow: var(--shadow-card); /* Добавляет тень карточки. */
  color: var(--color-main); /* Делает текст карточки основного цвета. */
  font-family: var(--font-regular); /* Делает текст карточки обычным шрифтом. */
}

.statement-card__head {
  margin-bottom: 18px; /* Добавляет отступ после шапки карточки. */
  display: flex; /* Расставляет заголовок и статус в строку. */
  align-items: flex-start; /* Выравнивает элементы по верху. */
  justify-content: space-between; /* Разводит заголовок и статус по краям. */
  gap: 20px; /* Добавляет расстояние между заголовком и статусом. */
}

.statement-card__head h2,
.cart-item__info h2,
.cart-summary h2,
.shop-section-title,
.shop-block-title {
  margin: 0 0 10px; /* Сбрасывает лишние внешние отступы заголовков карточек. */
  padding: 0; /* Сбрасывает верхний padding от глобального h2. */
  color: var(--color-main); /* Делает заголовки основного цвета. */
  font-family: var(--font-medium); /* Делает заголовки средним шрифтом. */
}

.statement-card__head h2 {
  font-size: 26px; /* Задаёт размер имени/заголовка в заявке. */
}

.statement-card__label {
  margin-bottom: 6px; /* Добавляет отступ под номером заявки/заказа. */
  font-family: var(--font-medium); /* Делает номер заявки/заказа средним. */
  opacity: 0.65; /* Делает номер визуально второстепенным. */
}

.status-pill {
  min-width: 120px; /* Задаёт минимальную ширину статуса. */
  padding: 10px 16px; /* Добавляет внутренние отступы статуса. */
  border-radius: var(--radius-pill); /* Делает статус округлым. */
  background: var(--color-main); /* Делает статус тёмным. */
  color: var(--color-bg); /* Делает текст статуса бежевым. */
  display: inline-flex; /* Центрирует текст внутри статуса. */
  align-items: center; /* Центрирует текст по вертикали. */
  justify-content: center; /* Центрирует текст по горизонтали. */
  font-family: var(--font-medium); /* Делает текст статуса средним. */
  font-size: 14px; /* Задаёт размер текста статуса. */
  white-space: nowrap; /* Запрещает перенос статуса. */
}

.statement-info,
.order-meta {
  margin-bottom: 18px; /* Добавляет отступ после мета-информации. */
  display: flex; /* Расставляет данные в строку. */
  flex-wrap: wrap; /* Разрешает перенос данных. */
  gap: 10px 24px; /* Добавляет расстояние между данными. */
  font-size: 14px; /* Делает мета-информацию компактной. */
}

.statement-info {
  opacity: 0.8; /* Делает информацию заявки чуть мягче. */
}

.message-box,
.answer-box {
  margin-top: 14px; /* Добавляет отступ над текстовым блоком. */
  padding: 18px; /* Добавляет внутренние отступы блока. */
  border: 1px solid rgba(62, 40, 40, 0.12); /* Добавляет мягкую рамку. */
  border-radius: var(--radius-medium); /* Скругляет блок. */
  background: var(--color-light); /* Задаёт светлый фон блока сообщения. */
  line-height: 1.5; /* Делает текст сообщения читабельнее. */
}

.answer-box {
  background: var(--color-soft); /* Делает блок ответа администратора ещё светлее. */
}

.answer-box strong {
  font-family: var(--font-medium); /* Выделяет подпись ответа администратора. */
}

.answer-box p {
  margin-top: 8px; /* Добавляет отступ перед текстом ответа. */
}

.statement-actions,
.form-actions,
.order-card__footer {
  margin-top: 22px; /* Добавляет отступ над кнопками. */
  display: flex; /* Расставляет кнопки в строку. */
  align-items: center; /* Центрирует кнопки по вертикали. */
  gap: 14px; /* Добавляет расстояние между кнопками. */
  flex-wrap: wrap; /* Разрешает перенос кнопок. */
}

.statement-actions,
.form-actions {
  justify-content: flex-end; /* Прижимает действия заявки/формы вправо. */
}

.order-card__footer {
  justify-content: space-between; /* Разводит итог и кнопку редактирования по краям. */
}

.btn-primary,
.btn-secondary,
.btn-danger {
  min-height: 44px; /* Делает кнопки удобными для клика. */
  padding: 0 22px; /* Добавляет боковые отступы кнопок. */
  border: none; /* Убирает рамку по умолчанию. */
  border-radius: var(--radius-pill); /* Делает кнопки округлыми. */
  display: inline-flex; /* Центрирует текст внутри кнопок. */
  align-items: center; /* Центрирует текст по вертикали. */
  justify-content: center; /* Центрирует текст по горизонтали. */
  font-family: var(--font-medium); /* Делает текст кнопок средним. */
  font-size: 15px; /* Задаёт размер текста кнопок. */
  cursor: pointer; /* Показывает кликабельность кнопок. */
  transition: var(--transition-base); /* Делает hover плавным. */
}

.btn-primary {
  background: var(--color-main); /* Делает основную кнопку тёмной. */
  color: var(--color-bg); /* Делает текст основной кнопки бежевым. */
}

.btn-secondary {
  border: 1px solid var(--color-main); /* Добавляет рамку вторичной кнопке. */
  background: transparent; /* Делает фон вторичной кнопки прозрачным. */
  color: var(--color-main); /* Делает текст вторичной кнопки тёмным. */
}

.btn-danger {
  background: var(--color-danger); /* Делает опасную кнопку красной. */
  color: #ffffff; /* Делает текст опасной кнопки белым. */
}

.btn-primary:hover,
.btn-secondary:hover,
.btn-danger:hover {
  transform: translateY(-2px); /* Слегка поднимает кнопку при наведении. */
  box-shadow: 0 6px 14px rgba(62, 40, 40, 0.18); /* Добавляет тень при наведении. */
}

.statement-form {
  max-width: 780px; /* Ограничивает ширину формы заявки. */
  margin: 0 auto; /* Центрирует форму заявки. */
}

.form-group {
  margin-top: 18px; /* Добавляет расстояние между группами формы. */
  display: grid; /* Располагает label и поле вертикально. */
  gap: 8px; /* Добавляет расстояние между label и полем. */
  font-family: var(--font-regular); /* Задаёт обычный шрифт группе. */
}

.form-group label {
  color: var(--color-main); /* Делает label основного цвета. */
  font-family: var(--font-medium); /* Делает label средним. */
}

.form-group select,
.form-group textarea,
.quantity-field input,
.admin-order-item input,
.add-product-row select,
.add-product-row input {
  width: 100%; /* Растягивает поля на всю ширину контейнера. */
  padding: 12px 14px; /* Добавляет внутренние отступы полей. */
  border: 1px solid rgba(62, 40, 40, 0.18); /* Добавляет мягкую рамку полям. */
  border-radius: var(--radius-small); /* Скругляет поля. */
  background: var(--color-light); /* Задаёт светлый фон полей. */
  color: var(--color-main); /* Делает текст полей основного цвета. */
  font-family: var(--font-regular); /* Делает текст полей обычным. */
  box-sizing: border-box; /* Сохраняет корректную ширину полей. */
}

.form-group select,
.form-group textarea {
  padding: 14px 16px; /* Делает поля заявки чуть просторнее. */
  border-radius: 18px; /* Задаёт отдельное скругление для полей заявки. */
  font-size: 16px; /* Задаёт размер текста в полях заявки. */
  outline: none; /* Убирает стандартную обводку браузера. */
}

.form-group textarea {
  min-height: 130px; /* Задаёт минимальную высоту textarea. */
  resize: vertical; /* Разрешает менять высоту textarea. */
}

.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--color-accent); /* Подсвечивает рамку активного поля. */
  box-shadow: 0 0 0 3px rgba(115, 82, 59, 0.15); /* Добавляет мягкую подсветку фокуса. */
}

.empty-text {
  margin-top: 40px; /* Добавляет верхний отступ пустому сообщению. */
  color: var(--color-main); /* Делает сообщение основного цвета. */
  font-family: var(--font-medium); /* Делает сообщение средним. */
  text-align: center; /* Центрирует пустое сообщение. */
}

/* ===== КОРЗИНА И ОФОРМЛЕНИЕ ЗАКАЗА ===== */
.shop-alert {
  width: min(90%, 980px); /* Ограничивает ширину уведомления. */
  margin: -16px auto 28px; /* Центрирует уведомление и задаёт отступы. */
  padding: 14px 18px; /* Добавляет внутренние отступы уведомления. */
  border-radius: 18px; /* Скругляет уведомление. */
  font-family: var(--font-medium); /* Делает текст уведомления средним. */
  text-align: center; /* Центрирует текст уведомления. */
}

.shop-alert--success {
  background: var(--color-success-bg); /* Задаёт зелёный фон успешного уведомления. */
  color: var(--color-success-text); /* Задаёт зелёный текст успешного уведомления. */
}

.shop-alert--error {
  background: var(--color-error-bg); /* Задаёт красноватый фон ошибки. */
  color: var(--color-error-text); /* Задаёт красный текст ошибки. */
}

.shop-page {
  padding-bottom: 120px; /* Добавляет нижний отступ магазинным страницам. */
}

.empty-cart {
  display: grid; /* Располагает элементы пустой корзины вертикально. */
  justify-items: center; /* Центрирует элементы пустой корзины. */
  gap: 18px; /* Добавляет расстояние между элементами. */
}

.cart-layout {
  width: min(100%, 1120px); /* Ограничивает ширину корзины. */
  margin: 0 auto; /* Центрирует корзину. */
  display: grid; /* Делит корзину на список и итог. */
  grid-template-columns: minmax(0, 1fr) 320px; /* Задаёт две колонки корзины. */
  align-items: start; /* Выравнивает колонки по верхнему краю. */
  gap: 28px; /* Добавляет расстояние между колонками. */
}

.cart-list {
  display: grid; /* Располагает товары корзины вертикально. */
  gap: 18px; /* Добавляет расстояние между товарами. */
}

.cart-item {
  padding: 18px; /* Добавляет внутренние отступы товара. */
  border-radius: 26px; /* Скругляет карточку товара. */
  background: var(--color-bg); /* Задаёт фон товара. */
  box-shadow: var(--shadow-soft); /* Добавляет тень товара. */
  color: var(--color-main); /* Делает текст товара основного цвета. */
  display: grid; /* Расставляет части товара сеткой. */
  grid-template-columns: 110px minmax(0, 1fr) 130px 150px; /* Задаёт колонки товара. */
  align-items: center; /* Центрирует содержимое товара по вертикали. */
  gap: 18px; /* Добавляет расстояние между колонками. */
  font-family: var(--font-regular); /* Делает текст товара обычным. */
}

.cart-item img {
  width: 110px; /* Задаёт ширину изображения товара. */
  height: 110px; /* Задаёт высоту изображения товара. */
  border-radius: 18px; /* Скругляет фон изображения товара. */
  background: var(--color-light); /* Задаёт фон изображения товара. */
  object-fit: contain; /* Показывает изображение целиком. */
}

.cart-item__info p,
.order-meta p,
.muted-text {
  color: var(--color-main); /* Делает вторичный текст основного цвета. */
  font-family: var(--font-regular); /* Делает вторичный текст обычным. */
  line-height: 1.45; /* Увеличивает читаемость вторичного текста. */
}

.quantity-field,
.admin-order-item label {
  display: grid; /* Располагает label и input вертикально. */
  gap: 8px; /* Добавляет расстояние между label и input. */
  color: var(--color-main); /* Делает текст основного цвета. */
  font-family: var(--font-medium); /* Делает подписи средним шрифтом. */
}

.cart-item__sum {
  display: grid; /* Располагает сумму и кнопку вертикально. */
  justify-items: end; /* Прижимает сумму вправо. */
  gap: 10px; /* Добавляет расстояние между суммой и кнопкой. */
  font-family: var(--font-medium); /* Делает сумму средним шрифтом. */
}

.btn-link-danger {
  border: none; /* Убирает рамку текстовой кнопки. */
  background: transparent; /* Делает фон текстовой кнопки прозрачным. */
  color: var(--color-danger); /* Делает текст красным. */
  font-family: var(--font-medium); /* Делает текст средним. */
  cursor: pointer; /* Показывает кликабельность. */
  text-decoration: underline; /* Подчёркивает действие удаления. */
}

.cart-summary {
  position: sticky; /* Закрепляет итог корзины при прокрутке. */
  top: calc(var(--header-height) + 30px); /* Отступает от фиксированной шапки. */
  padding: 24px; /* Добавляет внутренние отступы итогового блока. */
  border-radius: var(--radius-large); /* Скругляет итоговый блок. */
  background: var(--color-bg); /* Задаёт фон итогового блока. */
  box-shadow: 0 8px 24px rgba(62, 40, 40, 0.15); /* Добавляет тень итогового блока. */
  color: var(--color-main); /* Делает текст итогового блока основного цвета. */
  display: grid; /* Располагает элементы итогов вертикально. */
  gap: 14px; /* Добавляет расстояние между элементами итогов. */
  font-family: var(--font-regular); /* Делает текст итогов обычным. */
}

.cart-summary__total {
  font-family: var(--font-medium); /* Делает итоговую сумму средним шрифтом. */
  font-size: 30px; /* Делает итоговую сумму крупной. */
}

.checkout-grid {
  width: min(100%, 980px); /* Ограничивает ширину оформления заказа. */
  margin: 0 auto; /* Центрирует оформление заказа. */
  display: grid; /* Делит оформление на две колонки. */
  grid-template-columns: 0.8fr 1.2fr; /* Задаёт ширину колонок оформления. */
  gap: 24px; /* Добавляет расстояние между колонками. */
}

.checkout-items {
  margin-top: 18px; /* Добавляет отступ над списком товаров в checkout. */
  display: grid; /* Располагает товары checkout вертикально. */
  gap: 12px; /* Добавляет расстояние между товарами checkout. */
}

.checkout-item,
.checkout-total {
  color: var(--color-main); /* Делает текст checkout основного цвета. */
  display: flex; /* Расставляет название и цену в строку. */
  align-items: center; /* Центрирует название и цену по вертикали. */
  justify-content: space-between; /* Разводит название и цену по краям. */
  gap: 16px; /* Добавляет расстояние между названием и ценой. */
  font-family: var(--font-regular); /* Делает текст checkout обычным. */
}

.checkout-total {
  margin-top: 22px; /* Добавляет верхний отступ итога checkout. */
  padding-top: 18px; /* Добавляет внутренний верхний отступ итога. */
  border-top: 1px solid rgba(62, 40, 40, 0.16); /* Добавляет разделительную линию. */
  font-family: var(--font-medium); /* Делает итог checkout средним. */
  font-size: 22px; /* Делает итог checkout крупнее. */
}

/* ===== СПИСОК ЗАКАЗОВ И АДМИН-РЕДАКТИРОВАНИЕ ===== */
.orders-section,
.cabinet-section {
  width: min(100%, 1080px); /* Ограничивает ширину секций кабинета. */
  margin: 0 auto 46px; /* Центрирует секции и добавляет нижний отступ. */
}

.cabinet-section {
  margin-top: 46px; /* Добавляет расстояние между заказами и заявками. */
}

.shop-block-title {
  margin-bottom: 24px; /* Добавляет нижний отступ заголовку блока. */
  font-size: 28px; /* Задаёт размер заголовка блока. */
  text-align: center; /* Центрирует заголовок блока. */
}

.orders-wrap {
  display: grid; /* Располагает заказы вертикально. */
  gap: 22px; /* Добавляет расстояние между заказами. */
}

.order-items-mini {
  display: grid; /* Располагает мини-товары вертикально. */
  gap: 12px; /* Добавляет расстояние между мини-товарами. */
}

.order-item-mini {
  padding: 12px; /* Добавляет внутренние отступы мини-товара. */
  border-radius: 18px; /* Скругляет мини-товар. */
  background: var(--color-light); /* Задаёт фон мини-товара. */
  display: grid; /* Расставляет картинку, название и цену сеткой. */
  grid-template-columns: 58px minmax(0, 1fr) auto; /* Задаёт колонки мини-товара. */
  align-items: center; /* Центрирует мини-товар по вертикали. */
  gap: 14px; /* Добавляет расстояние между колонками. */
}

.order-item-mini img {
  width: 58px; /* Задаёт ширину картинки мини-товара. */
  height: 58px; /* Задаёт высоту картинки мини-товара. */
  object-fit: contain; /* Показывает картинку целиком. */
}

.order-edit-form {
  max-width: 980px; /* Ограничивает ширину формы редактирования заказа. */
}

.admin-order-items {
  margin-top: 18px; /* Добавляет верхний отступ списку товаров заказа. */
  display: grid; /* Располагает админ-товары вертикально. */
  gap: 14px; /* Добавляет расстояние между админ-товарами. */
}

.admin-order-item {
  padding: 14px; /* Добавляет внутренние отступы админ-товара. */
  border-radius: var(--radius-medium); /* Скругляет админ-товар. */
  background: var(--color-light); /* Задаёт фон админ-товара. */
  color: var(--color-main); /* Делает текст админ-товара основного цвета. */
  display: grid; /* Раскладывает админ-товар по колонкам. */
  grid-template-columns: 72px minmax(160px, 1fr) 100px 120px 120px auto; /* Задаёт колонки админ-товара. */
  align-items: center; /* Центрирует содержимое по вертикали. */
  gap: 14px; /* Добавляет расстояние между колонками. */
  font-family: var(--font-regular); /* Делает текст админ-товара обычным. */
}

.admin-order-item img {
  width: 72px; /* Задаёт ширину изображения админ-товара. */
  height: 72px; /* Задаёт высоту изображения админ-товара. */
  object-fit: contain; /* Показывает изображение целиком. */
}

.admin-order-item h4 {
  padding: 0 0 4px; /* Убирает лишние отступы и оставляет нижний. */
  text-align: left; /* Выравнивает название товара слева. */
}

.add-product-row__fields {
  display: grid; /* Располагает выбор товара и количество в строку. */
  grid-template-columns: minmax(0, 1fr) 120px; /* Задаёт колонки добавления товара. */
  gap: 12px; /* Добавляет расстояние между полями. */
}

/* ===== АДАПТИВ ===== */
@media (max-width: 1100px) {
  :root {
    --header-height: 104px; /* Увеличивает расчётную высоту шапки на планшетах. */
  }

  header {
    height: auto; /* Позволяет шапке расти по содержимому. */
    min-height: var(--header-height); /* Сохраняет минимальную высоту шапки. */
  }

  .header-nav {
    width: 92%; /* Делает шапку шире на планшетах. */
    min-height: var(--header-height); /* Синхронизирует высоту внутренней навигации. */
    gap: 14px; /* Уменьшает расстояние между группами. */
  }

  nav ul {
    flex-wrap: wrap; /* Разрешает меню переноситься на новую строку. */
    justify-content: center; /* Центрирует меню после переноса. */
    gap: 18px; /* Уменьшает расстояние между пунктами. */
  }

  .textHeader {
    font-size: 14px; /* Уменьшает текст меню на планшетах. */
  }

  .cart-layout,
  .checkout-grid {
    grid-template-columns: 1fr; /* Делает корзину и оформление одноколоночными. */
  }

  .cart-summary {
    position: static; /* Отключает липкий итог на узких экранах. */
  }

  .admin-order-item {
    grid-template-columns: 72px minmax(0, 1fr) 1fr 1fr; /* Упрощает сетку редактирования заказа. */
  }
}

@media (max-width: 760px) {
  :root {
    --header-height: 150px; /* Увеличивает расчётную высоту шапки на телефонах. */
  }

  .header-nav {
    padding: 8px 0 12px; /* Добавляет вертикальные отступы в мобильной шапке. */
    flex-wrap: wrap; /* Разрешает элементам шапки переноситься. */
    justify-content: center; /* Центрирует элементы шапки. */
  }

  .header-logo img {
    width: 72px; /* Уменьшает логотип на телефонах. */
    height: auto; /* Сохраняет пропорции логотипа. */
  }

  .main-nav {
    order: 3; /* Переносит меню ниже логотипа и действий. */
    width: 100%; /* Растягивает меню на всю ширину. */
  }

  nav ul {
    padding: 0; /* Убирает лишний padding у меню. */
    gap: 10px 16px; /* Уменьшает расстояние между пунктами меню. */
  }

  .header-actions {
    gap: 10px; /* Уменьшает расстояние между корзиной и аккаунтом. */
  }

  .cart-link__text {
    display: none; /* Скрывает текст корзины и оставляет иконку. */
  }

  .catalog {
    margin-top: 120px; /* Сохраняет отступ заголовка каталога на мобильных страницах. */
    font-size: 26px; /* Уменьшает заголовок каталога. */
  }

  .page-panel {
    width: 92%; /* Делает кабинет шире на телефонах. */
    padding-top: 42px; /* Уменьшает верхний отступ кабинета. */
    padding-bottom: 70px; /* Оставляет место перед подвалом. */
  }

  .page-panel > .catalog:first-child {
    margin-top: 0; /* Не даёт первому заголовку кабинета получить лишний отступ. */
  }

  .catalog-cards {
    width: 92%; /* Делает сетку каталога шире на телефонах. */
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); /* Уменьшает минимальную ширину карточки. */
    gap: 18px; /* Уменьшает расстояние между карточками. */
  }

  .catalog-card {
    padding: 14px; /* Уменьшает внутренние отступы карточек. */
    border-radius: 22px; /* Уменьшает скругление карточек. */
  }

  .cart-item {
    grid-template-columns: 82px minmax(0, 1fr); /* Перестраивает товар корзины в две колонки. */
    align-items: start; /* Выравнивает содержимое товара по верху. */
  }

  .cart-item img {
    width: 82px; /* Уменьшает картинку товара в корзине. */
    height: 82px; /* Уменьшает высоту картинки товара. */
  }

  .quantity-field,
  .cart-item__sum {
    grid-column: 1 / -1; /* Растягивает количество и сумму на всю ширину. */
    justify-items: stretch; /* Растягивает содержимое этих блоков. */
  }

  .cart-item__sum {
    display: flex; /* Расставляет сумму и удаление в строку. */
    align-items: center; /* Центрирует сумму и удаление по вертикали. */
    justify-content: space-between; /* Разводит сумму и удаление по краям. */
  }

  .order-card,
  .statement-card {
    padding: 20px; /* Уменьшает отступы карточек на телефонах. */
    border-radius: 22px; /* Уменьшает скругление карточек на телефонах. */
  }

  .statement-card__head {
    flex-direction: column; /* Ставит заголовок и статус друг под другом. */
  }

  .statement-actions,
  .form-actions {
    justify-content: stretch; /* Растягивает действия на всю ширину. */
  }

  .order-item-mini {
    grid-template-columns: 48px minmax(0, 1fr); /* Упрощает сетку мини-товара заказа. */
  }

  .order-item-mini strong {
    grid-column: 2; /* Переносит цену под название на телефоне. */
  }

  .admin-order-item {
    grid-template-columns: 64px minmax(0, 1fr); /* Упрощает админ-строку товара на телефоне. */
  }

  .admin-order-item label,
  .admin-order-item strong,
  .admin-order-item button {
    grid-column: 1 / -1; /* Растягивает поля админ-товара на всю ширину. */
  }

  .add-product-row__fields {
    grid-template-columns: 1fr; /* Ставит добавление товара в одну колонку. */
  }

  .footerblocks {
    width: 90%; /* Делает подвал шире на телефонах. */
    flex-wrap: wrap; /* Разрешает колонкам подвала переноситься. */
    justify-content: center; /* Центрирует колонки подвала. */
    gap: 22px; /* Уменьшает расстояние между колонками. */
    text-align: center; /* Центрирует текст подвала. */
  }
}

@media (max-width: 430px) {
  .catalog-cards {
    grid-template-columns: 1fr; /* Делает каталог одной колонкой на маленьких телефонах. */
  }

  .btn-primary,
  .btn-secondary,
  .btn-danger,
  .order-card__footer .btn-primary {
    width: 100%; /* Растягивает кнопки на маленьких экранах. */
  }
}

/* ===== ГЛАВНАЯ СТРАНИЦА: ОБНОВЛЁННЫЙ ДИЗАЙН И РАБОЧИЙ СЛАЙДЕР ===== */

html,
body {
  margin: 0;
  padding: 0;
}

body {
  background: #fbfaf8;
  color: var(--color-main);
  font-family: var(--font-regular);
}

.home-page {
  width: 100%;
  padding: 34px 0 90px;
  background:
    radial-gradient(circle at 8% 8%, rgba(233, 228, 222, 0.95) 0, rgba(233, 228, 222, 0) 30%),
    linear-gradient(180deg, #fffdfb 0%, #f7f3ef 100%);
}

.home-page h1,
.home-page h2,
.home-page h3,
.home-page p {
  margin: 0;
  padding: 0;
}

.home-eyebrow {
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 14px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.home-slider {
  position: relative;
  width: min(92%, 1180px);
  min-height: 520px;
  margin: 0 auto 72px;
  overflow: hidden;
  border-radius: 42px;
  background:
    linear-gradient(135deg, rgba(233, 228, 222, 0.95), rgba(255, 250, 244, 0.92)),
    url("/img/bgimg1.png") center / cover no-repeat;
  box-shadow: 0 24px 55px rgba(62, 40, 40, 0.18);
}

.home-slider__track {
  position: relative;
  min-height: 520px;
}

.home-slide {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  align-items: center;
  gap: 32px;
  padding: 58px 86px 74px;
  opacity: 0;
  visibility: hidden;
  transform: translateX(28px);
  transition: opacity 0.45s ease, transform 0.45s ease, visibility 0.45s ease;
}

.home-slide.is-active {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
  z-index: 2;
}

.home-slide__content {
  max-width: 560px;
  display: grid;
  gap: 22px;
}

.home-slide__content h1,
.home-slide__content h2 {
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(20px, 4.8vw, 40px);
  line-height: 1.06;
  letter-spacing: -0.04em;
}

.home-slide__content p:not(.home-eyebrow) {
  max-width: 520px;
  color: rgba(62, 40, 40, 0.78);
  font-size: 18px;
  line-height: 1.65;
}

.home-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}

.home-btn {
  min-height: 50px;
  padding: 0 25px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 15px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.home-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 22px rgba(62, 40, 40, 0.16);
}

.home-btn--dark {
  background: var(--color-main);
  color: var(--color-bg);
}

.home-btn--light {
  border: 1px solid rgba(62, 40, 40, 0.18);
  background: rgba(255, 255, 255, 0.55);
  color: var(--color-main);
}

.home-slide__image {
  position: relative;
  min-height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.home-slide__image::before {
  content: "";
  position: absolute;
  width: min(82%, 360px);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: rgba(115, 82, 59, 0.13);
  filter: blur(2px);
}

.home-slide__image img {
  position: relative;
  z-index: 2;
  width: min(100%, 430px);
  max-height: 390px;
  object-fit: contain;
  filter: drop-shadow(0 24px 24px rgba(62, 40, 40, 0.24));
}

.home-slider__arrow {
  position: absolute;
  top: 50%;
  z-index: 5;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(62, 40, 40, 0.16);
  border-radius: 50%;
  background: rgba(255, 250, 244, 0.88);
  color: var(--color-main);
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
  transform: translateY(-50%);
  transition: 0.2s ease;
}

.home-slider__arrow:hover {
  background: var(--color-main);
  color: var(--color-bg);
}

.home-slider__arrow--prev {
  left: 24px;
}

.home-slider__arrow--next {
  right: 24px;
}

.home-slider__dots {
  position: absolute;
  left: 86px;
  bottom: 36px;
  z-index: 6;
  display: flex;
  gap: 12px;
}

.home-slider__dots button {
  width: 42px;
  height: 5px;
  border: none;
  border-radius: 20px;
  background: rgba(62, 40, 40, 0.22);
  cursor: pointer;
  transition: 0.2s ease;
}

.home-slider__dots button.is-active {
  width: 70px;
  background: var(--color-accent);
}

.home-section,
.home-collection,
.home-benefits {
  width: min(92%, 1180px);
  margin: 0 auto;
}

.home-section {
  margin-bottom: 72px;
}

.home-section__head {
  margin-bottom: 28px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
}

.home-section__head h2,
.home-collection__content h2 {
  margin-top: 8px;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(28px, 3.2vw, 42px);
  line-height: 1.12;
  letter-spacing: -0.03em;
}

.home-section__link {
  min-height: 42px;
  padding: 0 18px;
  border: 1px solid rgba(62, 40, 40, 0.2);
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  font-family: var(--font-medium);
}

.home-categories {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.home-category-card {
  min-height: 310px;
  padding: 24px;
  border-radius: 34px;
  background: rgba(233, 228, 222, 0.82);
  box-shadow: var(--shadow-soft);
  display: grid;
  align-content: space-between;
  gap: 20px;
  transition: 0.2s ease;
}

.home-category-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 32px rgba(62, 40, 40, 0.16);
}

.home-category-card img {
  width: 100%;
  height: 170px;
  object-fit: contain;
  border-radius: 24px;
  background: rgba(255, 250, 244, 0.6);
}

.home-category-card h3,
.home-benefit h3 {
  margin-bottom: 8px;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 22px;
}

.home-category-card p,
.home-benefit p,
.home-collection__content p {
  color: rgba(62, 40, 40, 0.74);
  font-size: 16px;
  line-height: 1.55;
}

.home-category-card a {
  margin-top: 14px;
  display: inline-flex;
  color: var(--color-accent);
  font-family: var(--font-medium);
}

.home-collection {
  margin-bottom: 72px;
  padding: 34px;
  border-radius: 42px;
  background: var(--color-bg);
  box-shadow: var(--shadow-card);
  display: grid;
  grid-template-columns: 1fr 0.92fr;
  gap: 38px;
  align-items: center;
}

.home-collection__image {
  min-height: 360px;
  border-radius: 32px;
  overflow: hidden;
  background: var(--color-light);
}

.home-collection__image img {
  width: 100%;
  height: 100%;
  min-height: 360px;
  display: block;
  object-fit: cover;
}

.home-collection__content {
  display: grid;
  gap: 18px;
  align-content: center;
}

.home-collection__content .home-btn {
  justify-self: start;
}

.home-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.home-benefit {
  padding: 26px;
  border-radius: 30px;
  background: #fffaf4;
  border: 1px solid rgba(62, 40, 40, 0.08);
}

.home-benefit span {
  width: 42px;
  height: 42px;
  margin-bottom: 18px;
  border-radius: 50%;
  background: var(--color-main);
  color: var(--color-bg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 14px;
}

@media (max-width: 980px) {
  .home-page {
    padding-top: 26px;
  }

  .home-slider,
  .home-slider__track {
    min-height: 680px;
  }

  .home-slide {
    grid-template-columns: 1fr;
    padding: 44px 54px 74px;
  }

  .home-slide__image {
    min-height: 280px;
  }

  .home-categories,
  .home-collection,
  .home-benefits {
    grid-template-columns: 1fr;
  }

  .home-collection {
    padding: 24px;
  }
}

@media (max-width: 680px) {
  .home-page {
    padding: 20px 0 64px;
  }

  .home-slider {
    width: 92%;
    min-height: 650px;
    margin-bottom: 54px;
    border-radius: 30px;
  }

  .home-slider__track {
    min-height: 650px;
  }

  .home-slide {
    padding: 34px 24px 82px;
    gap: 18px;
  }

  .home-slide__content p:not(.home-eyebrow) {
    font-size: 15px;
  }

  .home-actions,
  .home-btn {
    width: 100%;
  }

  .home-slider__arrow {
    top: auto;
    bottom: 26px;
    width: 40px;
    height: 40px;
    font-size: 28px;
    transform: none;
  }

  .home-slider__arrow--prev {
    left: 24px;
  }

  .home-slider__arrow--next {
    right: 24px;
  }

  .home-slider__dots {
    left: 50%;
    bottom: 42px;
    transform: translateX(-50%);
  }

  .home-slider__dots button {
    width: 24px;
  }

  .home-slider__dots button.is-active {
    width: 42px;
  }

  .home-section__head {
    align-items: flex-start;
    flex-direction: column;
  }

  .home-category-card {
    min-height: auto;
  }

  .home-collection {
    border-radius: 30px;
  }

  .home-collection__image,
  .home-collection__image img {
    min-height: 250px;
  }
}

/* ===== ДОПОЛНЕНИЯ ДЛЯ КАТАЛОГА ПО КАТЕГОРИЯМ И ОСТАТКОВ ===== */
.catalog-page {
  width: 100%;
  padding-bottom: 90px;
}

.catalog-category {
  width: min(90%, 1180px);
  margin: 0 auto 58px;
}

.catalog-category__head {
  margin-bottom: 22px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
}

.catalog-category__head h2 {
  margin: 0;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 28px;
}

.catalog-category__count {
  margin: 0;
  padding: 8px 16px;
  border-radius: var(--radius-pill);
  background: var(--color-bg);
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 14px;
}

.catalog-cards--category {
  width: 100%;
  padding-bottom: 0;
}

.catalog-card__image-wrap {
  position: relative;
  width: 100%;
}

.stock-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  padding: 7px 12px;
  border-radius: var(--radius-pill);
  color: #ffffff;
  font-family: var(--font-medium);
  font-size: 12px;
  line-height: 1;
}

.stock-badge--in {
  background: #466643;
}

.stock-badge--out {
  background: var(--color-danger);
}

.catalog-card__stock,
.cart-stock {
  width: 100%;
  margin: 0;
  color: #466643;
  font-family: var(--font-medium);
  font-size: 14px;
  text-align: center;
}

.catalog-card__stock--out,
.cart-stock--warning {
  color: var(--color-danger);
}

.catalog-card--out {
  opacity: 0.65;
}

.catalog-card--out img {
  filter: grayscale(0.7);
}

.catalog-card__form button:disabled {
  opacity: 0.65;
  cursor: not-allowed;
  background: #8c8377;
}

.checkout-item small {
  display: block;
  margin-top: 4px;
  opacity: 0.7;
  font-family: var(--font-regular);
}

@media (max-width: 760px) {
  .catalog-category__head {
    align-items: flex-start;
    flex-direction: column;
  }
}



/* ===== СООБЩЕНИЯ О ПРАВКАХ ЗАКАЗА АДМИНИСТРАТОРОМ ===== */
.order-changes {
  width: 100%;
  margin-top: 22px;
  padding: 18px;
  border: 1px solid rgba(62, 40, 40, 0.12);
  border-radius: var(--radius-medium);
  background: var(--color-soft);
  color: var(--color-main);
  font-family: var(--font-regular);
}

.order-changes h3 {
  margin: 0 0 14px;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 18px;
}

.order-change-item {
  padding: 12px 0;
  border-top: 1px solid rgba(62, 40, 40, 0.12);
}

.order-change-item:first-of-type {
  border-top: none;
  padding-top: 0;
}

.order-change-item p {
  margin: 0;
  line-height: 1.45;
}

.order-stock-note {
  display: block;
  margin-top: 6px;
  color: rgba(62, 40, 40, 0.68);
  font-family: var(--font-regular);
  font-size: 13px;
  line-height: 1.35;
}

/* ===== ОБНОВЛЁННЫЙ ПОДВАЛ С КАРТОЙ САЙТА ===== */
footer {
  position: relative;
  width: 100%;
  flex-shrink: 0;
  margin-top: auto;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 250, 244, 0.9) 0, rgba(255, 250, 244, 0) 28%),
    linear-gradient(135deg, #e9e4de 0%, #f7f3ef 55%, #fffaf4 100%);
  color: var(--color-main);
  font-family: var(--font-regular);
}

.site-footer {
  position: relative;
  padding: 56px 0 26px;
}

.site-footer__decor {
  position: absolute;
  width: 270px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: rgba(115, 82, 59, 0.1);
  filter: blur(4px);
  pointer-events: none;
}

.site-footer__decor--left {
  left: -90px;
  bottom: 40px;
}

.site-footer__decor--right {
  right: -80px;
  top: 20px;
}

.site-footer__inner {
  position: relative;
  z-index: 1;
  width: min(92%, 1180px);
  margin: 0 auto;
}

.site-footer__top {
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) minmax(160px, 0.65fr) minmax(190px, 0.75fr);
  gap: 34px;
  align-items: start;
}

.site-footer__brand,
.site-footer__column,
.footer-map {
  border: 1px solid rgba(62, 40, 40, 0.1);
  border-radius: 32px;
  background: rgba(255, 250, 244, 0.58);
  box-shadow: 0 14px 34px rgba(62, 40, 40, 0.1);
  backdrop-filter: blur(6px);
}

.site-footer__brand {
  min-height: 100%;
  padding: 30px;
  display: grid;
  gap: 18px;
}

.site-footer__logo {
  width: fit-content;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.site-footer__brand p {
  max-width: 520px;
  margin: 0;
  color: rgba(62, 40, 40, 0.72);
  font-size: 16px;
  line-height: 1.65;
}

.site-footer__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.site-footer__tags span {
  padding: 9px 14px;
  border-radius: var(--radius-pill);
  background: rgba(62, 40, 40, 0.08);
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 13px;
}

.site-footer__column {
  padding: 28px;
}

.site-footer__column h3,
.footer-map__head h3 {
  margin: 0 0 18px;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 22px;
}

.site-footer__column ul {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
  list-style: none;
}

.site-footer__column li,
.site-footer__column a,
.site-footer__column span {
  color: rgba(62, 40, 40, 0.76);
  font-family: var(--font-regular);
  font-size: 15px;
  line-height: 1.35;
}

.site-footer__column a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: var(--transition-base);
}

.site-footer__column a::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-accent);
  opacity: 0.55;
  transition: var(--transition-base);
}

.site-footer__column a:hover {
  color: var(--color-main);
  transform: translateX(4px);
}

.site-footer__column a:hover::before {
  opacity: 1;
}

.footer-map {
  margin-top: 28px;
  padding: 26px;
}

.footer-map__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.footer-map__eyebrow {
  margin: 0 0 6px;
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.footer-map__toggle {
  min-height: 42px;
  padding: 0 18px;
  border: 1px solid rgba(62, 40, 40, 0.16);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.45);
  color: var(--color-main);
  font-family: var(--font-medium);
  cursor: pointer;
  transition: var(--transition-base);
}

.footer-map__toggle:hover {
  background: var(--color-main);
  color: var(--color-bg);
  transform: translateY(-2px);
}

.footer-map__scheme {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 18px;
  max-height: 520px;
  overflow: hidden;
  opacity: 1;
  transition: max-height 0.35s ease, opacity 0.25s ease, margin 0.35s ease;
}

.footer-map__scheme.is-collapsed {
  max-height: 0;
  margin-top: -12px;
  opacity: 0;
}

.footer-map__node,
.footer-map__small {
  position: relative;
  z-index: 2;
  min-height: 42px;
  border: 1px solid rgba(62, 40, 40, 0.16);
  border-radius: 18px;
  background: rgba(255, 250, 244, 0.9);
  color: var(--color-main);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-family: var(--font-medium);
  box-shadow: 0 8px 18px rgba(62, 40, 40, 0.08);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.footer-map__node {
  width: min(100%, 185px);
  padding: 0 18px;
}

.footer-map__node--main {
  min-height: 50px;
  margin-top: 10px;
  border-radius: 22px;
  background: var(--color-main);
  color: var(--color-bg);
  font-size: 18px;
}

.footer-map__line--vertical {
  width: 1px;
  height: 22px;
  background: rgba(62, 40, 40, 0.28);
}

.footer-map__branches,
.footer-map__subbranches {
  width: 100%;
  display: grid;
  gap: 14px;
}

.footer-map__branches {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.footer-map__subbranches {
  width: min(100%, 760px);
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding-top: 4px;
}

.footer-map__small {
  min-height: 38px;
  padding: 0 12px;
  border-radius: 15px;
  background: rgba(233, 228, 222, 0.72);
  font-size: 13px;
}

.footer-map__node:hover,
.footer-map__small:hover,
.footer-map__node:focus,
.footer-map__small:focus {
  background: var(--color-main);
  color: var(--color-bg);
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(62, 40, 40, 0.16);
  outline: none;
}

.footer-map[data-active-node="main"] .footer-map__node--main,
.footer-map[data-active-node="catalog"] [data-map-node="catalog"],
.footer-map[data-active-node="cart"] [data-map-node="cart"],
.footer-map[data-active-node="auth"] [data-map-node="auth"],
.footer-map[data-active-node="questions"] [data-map-node="questions"],
.footer-map[data-active-node="cabinet"] [data-map-node="cabinet"] {
  background: var(--color-accent);
  color: #ffffff;
}

.site-footer__bottom {
  margin-top: 26px;
  padding-top: 18px;
  border-top: 1px solid rgba(62, 40, 40, 0.12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  color: rgba(62, 40, 40, 0.65);
  font-size: 14px;
}

.site-footer__bottom p {
  margin: 0;
}

.site-footer__bottom a {
  color: var(--color-main);
  font-family: var(--font-medium);
}

@media (max-width: 1100px) {
  .site-footer__top {
    grid-template-columns: 1fr 1fr;
  }

  .site-footer__brand {
    grid-column: 1 / -1;
  }

  .footer-map__branches {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .site-footer {
    padding: 42px 0 22px;
  }

  .site-footer__top,
  .footer-map__branches,
  .footer-map__subbranches {
    grid-template-columns: 1fr;
  }

  .site-footer__brand,
  .site-footer__column,
  .footer-map {
    border-radius: 24px;
  }

  .footer-map__head,
  .site-footer__bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .footer-map__toggle,
  .footer-map__node,
  .footer-map__small {
    width: 100%;
  }

  .footer-map__line--vertical {
    height: 14px;
  }
}

/* ===== КАРТА МАГАЗИНА В ПОДВАЛЕ ===== */
.footer-location {
  margin-top: 28px;
  padding: 26px;
  border: 1px solid rgba(62, 40, 40, 0.1);
  border-radius: 32px;
  background: rgba(255, 250, 244, 0.58);
  box-shadow: 0 14px 34px rgba(62, 40, 40, 0.1);
  backdrop-filter: blur(6px);
  display: grid;
  grid-template-columns: minmax(230px, 0.55fr) minmax(320px, 1fr);
  gap: 24px;
  align-items: stretch;
}

.footer-location__info {
  padding: 8px 0;
  display: grid;
  align-content: center;
  gap: 14px;
}

.footer-location__eyebrow {
  margin: 0;
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.footer-location__info h3 {
  margin: 0;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 28px;
}

.footer-location__info p:not(.footer-location__eyebrow) {
  margin: 0;
  max-width: 360px;
  color: rgba(62, 40, 40, 0.72);
  font-family: var(--font-regular);
  font-size: 16px;
  line-height: 1.55;
}

.footer-location__actions {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.footer-location__actions button,
.footer-location__actions a {
  min-height: 40px;
  padding: 0 16px;
  border: 1px solid rgba(62, 40, 40, 0.16);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.48);
  color: var(--color-main);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 14px;
  cursor: pointer;
  transition: var(--transition-base);
}

.footer-location__actions button:first-child {
  border-color: transparent;
  background: var(--color-main);
  color: var(--color-bg);
}

.footer-location__actions button:hover,
.footer-location__actions a:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(62, 40, 40, 0.14);
}

.footer-location__map {
  width: 100%;
  min-height: 330px;
  border: 1px solid rgba(62, 40, 40, 0.14);
  border-radius: 26px;
  overflow: hidden;
  background: var(--color-light);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

.footer-location__map .leaflet-popup-content-wrapper,
.footer-location__map .leaflet-popup-tip {
  background: #fffaf4;
  color: var(--color-main);
  font-family: var(--font-regular);
}

.footer-location__map .leaflet-popup-content b {
  font-family: var(--font-medium);
}

@media (max-width: 980px) {
  .footer-location {
    grid-template-columns: 1fr;
  }

  .footer-location__info p:not(.footer-location__eyebrow) {
    max-width: 100%;
  }
}

@media (max-width: 760px) {
  .footer-location {
    padding: 18px;
    border-radius: 24px;
  }

  .footer-location__map {
    min-height: 280px;
    border-radius: 20px;
  }

  .footer-location__actions,
  .footer-location__actions button,
  .footer-location__actions a {
    width: 100%;
  }
}

/* ===== АДМИНСКОЕ ДОБАВЛЕНИЕ ТОВАРОВ ===== */
.admin-product-section {
  width: min(100%, 1080px);
  margin: 0 auto 46px;
  padding: 28px;
  border-radius: var(--radius-large);
  background: var(--color-bg);
  box-shadow: var(--shadow-card);
  color: var(--color-main);
}

.admin-product-section__head {
  margin-bottom: 22px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}

.admin-product-section__head .shop-block-title {
  margin: 4px 0 0;
  padding: 0;
  text-align: left;
}

.admin-product-section__eyebrow {
  margin: 0;
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.admin-product-form {
  display: grid;
  gap: 22px;
}

.admin-product-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.admin-product-form .form-group {
  margin-top: 0;
}

.admin-product-form .form-group span {
  color: var(--color-main);
  font-family: var(--font-medium);
}

.admin-product-form input[type="text"],
.admin-product-form input[type="number"],
.admin-product-form input[type="file"],
.admin-product-form select,
.admin-product-form textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid rgba(62, 40, 40, 0.18);
  border-radius: 18px;
  background: var(--color-light);
  color: var(--color-main);
  font-family: var(--font-regular);
  font-size: 15px;
  outline: none;
}

.admin-product-form input[type="file"] {
  padding: 12px;
}

.admin-product-form input:focus,
.admin-product-form select:focus,
.admin-product-form textarea:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(115, 82, 59, 0.15);
}

.admin-product-form__textarea {
  grid-column: 1 / -1;
}

.admin-product-form textarea {
  min-height: 130px;
  resize: vertical;
}

.admin-product-form__bottom {
  padding-top: 18px;
  border-top: 1px solid rgba(62, 40, 40, 0.12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.admin-product-form__bottom p {
  margin: 0;
  color: rgba(62, 40, 40, 0.68);
  font-family: var(--font-regular);
  font-size: 14px;
  line-height: 1.45;
}

.admin-product-form__bottom .btn-primary {
  flex-shrink: 0;
}

.admin-product-section .shop-alert {
  width: 100%;
  margin: 0 0 22px;
}

.admin-product-section .shop-alert p {
  margin: 0;
}

.admin-product-section .shop-alert p + p {
  margin-top: 6px;
}

@media (max-width: 760px) {
  .admin-product-section {
    padding: 22px;
    border-radius: 22px;
  }

  .admin-product-section__head,
  .admin-product-form__bottom {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-product-form__grid {
    grid-template-columns: 1fr;
  }

  .admin-product-form__textarea {
    grid-column: auto;
  }

  .admin-product-form__bottom .btn-primary,
  .admin-product-section__head .btn-secondary {
    width: 100%;
  }
}

/* ===== НАВИГАЦИЯ ЛИЧНОГО КАБИНЕТА И ОТСТУП ОТ ШАПКИ ===== */
html {
  scroll-behavior: smooth;
}

.page-panel {
  padding-top: 96px !important;
}

.page-panel .cabinet-title,
.cabinet-title {
  margin: 0 0 30px !important;
  padding: 0 !important;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(36px, 4.4vw, 56px);
  line-height: 1.08;
  text-align: center;
}

.cabinet-nav {
  width: min(100%, 1080px);
  margin: 0 auto 34px;
  padding: 24px 28px;
  border: 1px solid rgba(62, 40, 40, 0.1);
  border-radius: var(--radius-large);
  background:
    radial-gradient(circle at 8% 10%, rgba(255, 250, 244, 0.92) 0, rgba(255, 250, 244, 0) 34%),
    var(--color-bg);
  box-shadow: var(--shadow-soft);
  color: var(--color-main);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.cabinet-nav__head {
  display: grid;
  gap: 6px;
}

.cabinet-nav__eyebrow {
  margin: 0;
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.cabinet-nav h2 {
  margin: 0;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 24px;
  line-height: 1.2;
}

.cabinet-nav__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.cabinet-nav__links a {
  min-height: 42px;
  padding: 0 18px;
  border: 1px solid rgba(62, 40, 40, 0.18);
  border-radius: var(--radius-pill);
  background: rgba(255, 250, 244, 0.58);
  color: var(--color-main);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 14px;
  text-align: center;
  transition: var(--transition-base);
}

.cabinet-nav__links a:hover,
.cabinet-nav__links a:focus {
  border-color: var(--color-main);
  background: var(--color-main);
  color: var(--color-bg);
  box-shadow: 0 8px 18px rgba(62, 40, 40, 0.15);
  transform: translateY(-2px);
  outline: none;
}

#admin-products,
#admin-orders,
#admin-statements,
#user-orders,
#user-statements {
  scroll-margin-top: calc(var(--header-height) + 36px);
}

@media (max-width: 1100px) {
  .page-panel {
    padding-top: 118px !important;
  }

  .cabinet-nav {
    align-items: flex-start;
    flex-direction: column;
  }

  .cabinet-nav__links {
    width: 100%;
    justify-content: flex-start;
  }
}

@media (max-width: 760px) {
  .page-panel {
    padding-top: 54px !important;
  }

  .page-panel .cabinet-title,
  .cabinet-title {
    font-size: 34px;
  }
}

@media (max-width: 520px) {
  .cabinet-nav {
    padding: 20px;
    border-radius: 22px;
  }

  .cabinet-nav__links {
    display: grid;
    grid-template-columns: 1fr;
  }

  .cabinet-nav__links a {
    width: 100%;
  }
}

/* ===== BAGINS: ОТЗЫВЫ БЕЗ КОНФЛИКТОВ ===== */
.bagins-review-section {
  width: min(92%, 1180px);
  margin: 70px auto 72px;
  padding: 34px;
  border-radius: 42px;
  background:
    radial-gradient(circle at 8% 10%, rgba(255, 250, 244, 0.92) 0, rgba(255, 250, 244, 0) 34%),
    var(--color-bg);
  box-shadow: var(--shadow-card);
  color: var(--color-main);
}

.bagins-review-section__head {
  max-width: 720px;
  margin: 0 auto 28px;
  text-align: center;
}

.bagins-review-section__head h2 {
  margin: 8px 0 12px;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.1;
  text-align: center;
}

.bagins-review-section__head span {
  color: rgba(62, 40, 40, 0.72);
  font-family: var(--font-regular);
  line-height: 1.55;
}

.bagins-review-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.bagins-review-card {
  padding: 22px;
  border: 1px solid rgba(62, 40, 40, 0.1);
  border-radius: var(--radius-large);
  background: var(--color-soft);
  box-shadow: var(--shadow-soft);
  color: var(--color-main);
  font-family: var(--font-regular);
}

.bagins-review-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.bagins-review-card__head h3 {
  margin: 0;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 20px;
}

.bagins-review-card__head span {
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 20px;
  white-space: nowrap;
}

.bagins-review-card__order {
  margin: 0 0 6px;
  color: rgba(62, 40, 40, 0.62);
  font-family: var(--font-medium);
  font-size: 13px;
}

.bagins-review-card__products {
  margin: 16px 0;
  padding: 14px;
  border-radius: 18px;
  background: var(--color-light);
}

.bagins-review-card__products strong {
  display: block;
  margin-bottom: 6px;
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 14px;
}

.bagins-review-card__products p,
.bagins-review-card__text {
  margin: 0;
  color: rgba(62, 40, 40, 0.76);
  line-height: 1.55;
}

.bagins-review-card small {
  margin-top: 14px;
  color: rgba(62, 40, 40, 0.58);
  display: block;
}

.bagins-review-empty {
  margin: 0;
  color: rgba(62, 40, 40, 0.72);
  font-family: var(--font-medium);
  text-align: center;
}

.bagins-review-open {
  min-height: 48px;
  margin: 26px auto 0;
  padding: 0 26px;
  border: none;
  border-radius: var(--radius-pill);
  background: var(--color-main);
  color: var(--color-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 15px;
  cursor: pointer;
  transition: var(--transition-base);
}

.bagins-review-open:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(62, 40, 40, 0.18);
}

body.bagins-review-modal-open {
  overflow: hidden;
}

.bagins-review-modal[hidden] {
  display: none;
}

.bagins-review-modal {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.bagins-review-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(62, 40, 40, 0.42);
  backdrop-filter: blur(3px);
}

.bagins-review-modal__content {
  position: relative;
  z-index: 2;
  width: min(94vw, 980px);
  max-height: 86vh;
  overflow-y: auto;
  padding: 30px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 8% 10%, rgba(255, 250, 244, 0.95) 0, rgba(255, 250, 244, 0) 34%),
    var(--color-bg);
  box-shadow: 0 24px 60px rgba(62, 40, 40, 0.28);
}

.bagins-review-modal__head {
  margin-bottom: 22px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.bagins-review-modal__head h2 {
  margin: 8px 0 12px;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.1;
  text-align: left;
}

.bagins-review-modal__close {
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 50%;
  background: var(--color-main);
  color: var(--color-bg);
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
}

.bagins-review-modal__list {
  display: grid;
  gap: 16px;
}

#reviews {
  scroll-margin-top: calc(var(--header-height) + 36px);
}

@media (max-width: 980px) {
  .bagins-review-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .bagins-review-section,
  .bagins-review-modal__content {
    padding: 20px;
    border-radius: 24px;
  }

  .bagins-review-card {
    padding: 18px;
    border-radius: 20px;
  }

  .bagins-review-card__head,
  .bagins-review-modal__head {
    flex-direction: column;
  }

  .bagins-review-open {
    width: 100%;
  }

  .bagins-review-modal {
    padding: 14px;
  }

  .bagins-review-modal__close {
    position: absolute;
    top: 16px;
    right: 16px;
  }
}

/* ===== BAGINS ABOUT: УНИКАЛЬНЫЙ ДИЗАЙН СТРАНИЦЫ О НАС ===== */
.bagins-about-page {
  padding: 54px 0 90px;
  background:
    radial-gradient(circle at 6% 5%, rgba(233, 228, 222, 0.95) 0, rgba(233, 228, 222, 0) 32%),
    linear-gradient(180deg, #fffdfb 0%, #f7f3ef 100%);
}

.bagins-about-page h1,
.bagins-about-page h2,
.bagins-about-page h3,
.bagins-about-page p {
  margin: 0;
  padding: 0;
}

.bagins-about-label {
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.bagins-about-hero,
.bagins-about-story,
.bagins-about-founder,
.bagins-about-values,
.bagins-about-reviews,
.bagins-about-cta {
  width: min(92%, 1180px);
  margin-left: auto;
  margin-right: auto;
}

.bagins-about-hero {
  min-height: 560px;
  margin-bottom: 54px;
  padding: 56px;
  border-radius: 46px;
  background:
    linear-gradient(115deg, rgba(233, 228, 222, 0.98) 0%, rgba(247, 243, 239, 0.92) 52%, rgba(255, 250, 244, 0.7) 100%);
  box-shadow: 0 24px 55px rgba(62, 40, 40, 0.16);
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(340px, 1.05fr);
  gap: 40px;
  align-items: center;
  overflow: hidden;
  position: relative;
}

.bagins-about-hero::before {
  content: "";
  position: absolute;
  width: 360px;
  height: 360px;
  left: -130px;
  top: -120px;
  border-radius: 50%;
  background: rgba(115, 82, 59, 0.12);
  filter: blur(4px);
}

.bagins-about-hero__content {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 20px;
}

.bagins-about-hero__content h1 {
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(44px, 6vw, 82px);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.bagins-about-hero__text {
  max-width: 560px;
  color: rgba(62, 40, 40, 0.76);
  font-family: var(--font-regular);
  font-size: 19px;
  line-height: 1.65;
}

.bagins-about-hero__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.bagins-about-button {
  width: fit-content;
  min-height: 52px;
  padding: 0 26px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 15px;
  transition: var(--transition-base);
}

.bagins-about-button--dark,
.bagins-about-button--cream:hover {
  background: var(--color-main);
  color: var(--color-bg);
}

.bagins-about-button--light {
  border: 1px solid rgba(62, 40, 40, 0.18);
  background: rgba(255, 250, 244, 0.6);
  color: var(--color-main);
}

.bagins-about-button--cream {
  background: var(--color-bg);
  color: var(--color-main);
}

.bagins-about-button:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px rgba(62, 40, 40, 0.2);
}

.bagins-about-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.bagins-about-hero__stats div {
  padding: 14px;
  border-radius: 22px;
  background: rgba(255, 250, 244, 0.68);
  display: grid;
  gap: 4px;
}

.bagins-about-hero__stats strong {
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 26px;
}

.bagins-about-hero__stats span {
  color: rgba(62, 40, 40, 0.7);
  font-family: var(--font-regular);
  font-size: 13px;
}

.bagins-about-hero__image {
  position: relative;
  z-index: 2;
  min-height: 430px;
  border-radius: 36px;
  overflow: hidden;
  background: var(--color-light);
  box-shadow: inset 0 0 0 1px rgba(62, 40, 40, 0.08);
}

.bagins-about-hero__image img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  display: block;
  object-fit: cover;
  object-position: center;
}

.bagins-about-hero__note {
  position: absolute;
  right: 22px;
  bottom: 22px;
  max-width: 270px;
  padding: 18px;
  border-radius: 24px;
  background: rgba(255, 250, 244, 0.88);
  box-shadow: 0 14px 28px rgba(62, 40, 40, 0.14);
  display: grid;
  gap: 6px;
}

.bagins-about-hero__note strong {
  color: var(--color-main);
  font-family: var(--font-medium);
}

.bagins-about-hero__note span {
  color: rgba(62, 40, 40, 0.72);
  font-family: var(--font-regular);
  font-size: 14px;
  line-height: 1.35;
}

.bagins-about-story {
  margin-bottom: 58px;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 34px;
  align-items: center;
}

.bagins-about-story__image {
  min-height: 380px;
  border-radius: 40px;
  overflow: hidden;
  background: var(--color-bg);
  box-shadow: var(--shadow-card);
}

.bagins-about-story__image img {
  width: 100%;
  height: 100%;
  min-height: 380px;
  display: block;
  object-fit: cover;
}

.bagins-about-story__content,
.bagins-about-founder,
.bagins-about-values,
.bagins-about-reviews {
  border: 1px solid rgba(62, 40, 40, 0.1);
  background:
    radial-gradient(circle at 8% 10%, rgba(255, 250, 244, 0.9) 0, rgba(255, 250, 244, 0) 34%),
    var(--color-bg);
  box-shadow: var(--shadow-soft);
}

.bagins-about-story__content {
  padding: 36px;
  border-radius: 40px;
  display: grid;
  gap: 16px;
}

.bagins-about-story__content h2,
.bagins-about-founder__content h2,
.bagins-about-values__head h2,
.bagins-about-reviews__head h2,
.bagins-about-cta h2 {
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.bagins-about-story__content p:not(.bagins-about-label),
.bagins-about-founder__content p,
.bagins-about-value p,
.bagins-about-reviews__head p,
.bagins-about-review__text,
.bagins-about-review__products p,
.bagins-about-reviews__empty,
.bagins-about-cta p {
  color: rgba(62, 40, 40, 0.74);
  font-family: var(--font-regular);
  line-height: 1.55;
}

.bagins-about-founder {
  margin-bottom: 70px;
  padding: 34px;
  border-radius: 42px;
  display: grid;
  grid-template-columns: minmax(260px, 0.75fr) minmax(0, 1.25fr);
  gap: 34px;
  align-items: center;
}

.bagins-about-founder__photo {
  display: grid;
  justify-items: center;
}

.bagins-about-founder__photo img {
  width: min(100%, 330px);
  height: 360px;
  border-radius: 32px;
  background: var(--color-light);
  object-fit: cover;
  box-shadow: 0 16px 30px rgba(62, 40, 40, 0.14);
}

.bagins-about-founder__content {
  display: grid;
  gap: 16px;
}

.bagins-about-founder__content blockquote {
  margin: 8px 0 0;
  padding: 24px;
  border-left: 4px solid var(--color-accent);
  border-radius: 22px;
  background: rgba(255, 250, 244, 0.7);
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(20px, 2.5vw, 30px);
  line-height: 1.35;
}

.bagins-about-values,
.bagins-about-reviews {
  margin-bottom: 70px;
  padding: 36px;
  border-radius: 42px;
}

.bagins-about-values__head,
.bagins-about-reviews__head {
  max-width: 760px;
  margin: 0 auto 30px;
  display: grid;
  gap: 10px;
  text-align: center;
}

.bagins-about-values__grid,
.bagins-about-reviews__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.bagins-about-value,
.bagins-about-review {
  padding: 22px;
  border: 1px solid rgba(62, 40, 40, 0.1);
  border-radius: 28px;
  background: var(--color-soft);
  box-shadow: var(--shadow-soft);
}

.bagins-about-value {
  display: grid;
  gap: 12px;
}

.bagins-about-value span {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-main);
  color: var(--color-bg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 14px;
}

.bagins-about-value h3,
.bagins-about-review h3 {
  margin: 0;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 22px;
}

.bagins-about-review__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.bagins-about-review__top span {
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 20px;
  white-space: nowrap;
}

.bagins-about-review__order {
  margin-bottom: 6px !important;
  color: rgba(62, 40, 40, 0.62);
  font-family: var(--font-medium);
  font-size: 13px;
}

.bagins-about-review__products {
  margin: 16px 0;
  padding: 14px;
  border-radius: 18px;
  background: var(--color-light);
}

.bagins-about-review__products strong {
  display: block;
  margin-bottom: 6px;
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 14px;
}

.bagins-about-review small {
  margin-top: 14px;
  color: rgba(62, 40, 40, 0.58);
  display: block;
  font-family: var(--font-regular);
}

.bagins-about-review-open {
  min-height: 48px;
  margin: 28px auto 0;
  padding: 0 26px;
  border: none;
  border-radius: var(--radius-pill);
  background: var(--color-main);
  color: var(--color-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 15px;
  cursor: pointer;
  transition: var(--transition-base);
}

.bagins-about-review-open:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(62, 40, 40, 0.18);
}

.bagins-about-reviews__empty {
  text-align: center;
}

.bagins-about-cta {
  width: min(92%, 1180px);
  margin: 0 auto;
  padding: 34px;
  border-radius: 42px;
  background:
    linear-gradient(135deg, rgba(62, 40, 40, 0.96), rgba(115, 82, 59, 0.9));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.bagins-about-cta .bagins-about-label,
.bagins-about-cta h2,
.bagins-about-cta p {
  color: var(--color-bg);
}

body.bagins-about-modal-open {
  overflow: hidden;
}

.bagins-about-modal[hidden] {
  display: none;
}

.bagins-about-modal {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.bagins-about-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(62, 40, 40, 0.42);
  backdrop-filter: blur(3px);
}

.bagins-about-modal__content {
  position: relative;
  z-index: 2;
  width: min(94vw, 980px);
  max-height: 86vh;
  overflow-y: auto;
  padding: 30px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 8% 10%, rgba(255, 250, 244, 0.95) 0, rgba(255, 250, 244, 0) 34%),
    var(--color-bg);
  box-shadow: 0 24px 60px rgba(62, 40, 40, 0.28);
}

.bagins-about-modal__head {
  margin-bottom: 22px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.bagins-about-modal__head h2 {
  margin: 8px 0 0;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(28px, 3.4vw, 42px);
  line-height: 1.1;
}

.bagins-about-modal__close {
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 50%;
  background: var(--color-main);
  color: var(--color-bg);
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
}

.bagins-about-modal__list {
  display: grid;
  gap: 16px;
}

#reviews {
  scroll-margin-top: calc(var(--header-height) + 36px);
}

@media (max-width: 980px) {
  .bagins-about-page {
    padding-top: 36px;
  }

  .bagins-about-hero,
  .bagins-about-story,
  .bagins-about-founder,
  .bagins-about-values__grid,
  .bagins-about-reviews__grid,
  .bagins-about-cta {
    grid-template-columns: 1fr;
  }

  .bagins-about-hero {
    padding: 38px;
  }

  .bagins-about-hero__image,
  .bagins-about-hero__image img,
  .bagins-about-story__image,
  .bagins-about-story__image img {
    min-height: 320px;
  }
}

@media (max-width: 760px) {
  .bagins-about-page {
    padding: 28px 0 64px;
  }

  .bagins-about-hero,
  .bagins-about-story__content,
  .bagins-about-founder,
  .bagins-about-values,
  .bagins-about-reviews,
  .bagins-about-cta,
  .bagins-about-modal__content {
    padding: 22px;
    border-radius: 26px;
  }

  .bagins-about-story__image,
  .bagins-about-value,
  .bagins-about-review {
    border-radius: 24px;
  }

  .bagins-about-hero__buttons,
  .bagins-about-button,
  .bagins-about-review-open {
    width: 100%;
  }

  .bagins-about-hero__stats {
    grid-template-columns: 1fr;
  }

  .bagins-about-founder__photo img {
    height: 280px;
  }

  .bagins-about-review__top,
  .bagins-about-modal__head,
  .bagins-about-cta {
    align-items: flex-start;
    flex-direction: column;
  }

  .bagins-about-modal {
    padding: 14px;
  }

  .bagins-about-modal__close {
    position: absolute;
    top: 16px;
    right: 16px;
  }
}

/* ===== BAGINS LK: УНИКАЛЬНЫЙ ДИЗАЙН ЛИЧНОГО КАБИНЕТА ===== */
.bagins-lk-page {
  width: min(92%, 1180px);
  min-height: calc(100vh - var(--header-height) - var(--footer-min-height));
  margin: var(--header-height) auto 0;
  padding: 70px 0 90px;
  background:
    radial-gradient(circle at 8% 4%, rgba(233, 228, 222, 0.85) 0, rgba(233, 228, 222, 0) 34%),
    linear-gradient(180deg, #fffdfb 0%, #f7f3ef 100%);
}

.bagins-lk-page h1,
.bagins-lk-page h2,
.bagins-lk-page h3,
.bagins-lk-page h4,
.bagins-lk-page p {
  margin: 0;
  padding: 0;
}

.bagins-lk-title {
  margin-bottom: 30px !important;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: clamp(38px, 5vw, 62px);
  line-height: 1.08;
  text-align: center;
  letter-spacing: -0.04em;
}

.bagins-lk-alert {
  width: min(100%, 980px);
  margin: 0 auto 22px;
  padding: 14px 18px;
  border-radius: 18px;
  font-family: var(--font-medium);
  text-align: center;
}

.bagins-lk-alert--success {
  background: var(--color-success-bg);
  color: var(--color-success-text);
}

.bagins-lk-alert--error {
  background: var(--color-error-bg);
  color: var(--color-error-text);
}

.bagins-lk-nav,
.bagins-lk-product,
.bagins-lk-section,
.bagins-lk-statements-list {
  width: min(100%, 1080px);
  margin: 0 auto 46px;
}

.bagins-lk-nav {
  padding: 24px 28px;
  border: 1px solid rgba(62, 40, 40, 0.1);
  border-radius: 30px;
  background:
    radial-gradient(circle at 8% 10%, rgba(255, 250, 244, 0.92) 0, rgba(255, 250, 244, 0) 34%),
    var(--color-bg);
  box-shadow: var(--shadow-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.bagins-lk-nav__head {
  display: grid;
  gap: 6px;
}

.bagins-lk-label {
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.bagins-lk-nav h2,
.bagins-lk-section-title {
  color: var(--color-main);
  font-family: var(--font-medium);
}

.bagins-lk-nav h2 {
  font-size: 24px;
}

.bagins-lk-nav__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.bagins-lk-nav__links a {
  min-height: 42px;
  padding: 0 18px;
  border: 1px solid rgba(62, 40, 40, 0.18);
  border-radius: var(--radius-pill);
  background: rgba(255, 250, 244, 0.58);
  color: var(--color-main);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 14px;
  text-align: center;
  transition: var(--transition-base);
}

.bagins-lk-nav__links a:hover,
.bagins-lk-nav__links a:focus {
  border-color: var(--color-main);
  background: var(--color-main);
  color: var(--color-bg);
  box-shadow: 0 8px 18px rgba(62, 40, 40, 0.15);
  transform: translateY(-2px);
  outline: none;
}

.bagins-lk-product,
.bagins-lk-order,
.bagins-lk-statement {
  border-radius: 30px;
  background: var(--color-bg);
  box-shadow: var(--shadow-card);
  color: var(--color-main);
}

.bagins-lk-product {
  padding: 30px;
}

.bagins-lk-product__head {
  margin-bottom: 24px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.bagins-lk-section-title {
  margin: 0 0 24px;
  padding: 0;
  font-size: clamp(26px, 3vw, 36px);
  line-height: 1.14;
  text-align: center;
}

.bagins-lk-product__head .bagins-lk-section-title {
  margin: 6px 0 0;
  text-align: left;
}

.bagins-lk-product-form {
  display: grid;
  gap: 22px;
}

.bagins-lk-product-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.bagins-lk-field {
  margin: 0;
  display: grid;
  gap: 8px;
  color: var(--color-main);
  font-family: var(--font-medium);
}

.bagins-lk-field input,
.bagins-lk-field select,
.bagins-lk-field textarea,
.bagins-lk-review-form select,
.bagins-lk-review-form textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid rgba(62, 40, 40, 0.18);
  border-radius: 18px;
  background: var(--color-light);
  color: var(--color-main);
  font-family: var(--font-regular);
  font-size: 15px;
  outline: none;
}

.bagins-lk-field input:focus,
.bagins-lk-field select:focus,
.bagins-lk-field textarea:focus,
.bagins-lk-review-form select:focus,
.bagins-lk-review-form textarea:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(115, 82, 59, 0.15);
}

.bagins-lk-field input[type="file"] {
  padding: 12px;
}

.bagins-lk-product-form__textarea {
  grid-column: 1 / -1;
}

.bagins-lk-product-form textarea {
  min-height: 130px;
  resize: vertical;
}

.bagins-lk-product-form__bottom {
  padding-top: 18px;
  border-top: 1px solid rgba(62, 40, 40, 0.12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.bagins-lk-product-form__bottom p {
  color: rgba(62, 40, 40, 0.68);
  font-family: var(--font-regular);
  font-size: 14px;
  line-height: 1.45;
}

.bagins-lk-btn {
  min-height: 44px;
  padding: 0 22px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 15px;
  cursor: pointer;
  transition: var(--transition-base);
}

.bagins-lk-btn--primary {
  border: none;
  background: var(--color-main);
  color: var(--color-bg);
}

.bagins-lk-btn--secondary {
  border: 1px solid var(--color-main);
  background: transparent;
  color: var(--color-main);
}

.bagins-lk-btn--danger {
  border: none;
  background: var(--color-danger);
  color: #ffffff;
}

.bagins-lk-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(62, 40, 40, 0.18);
}

.bagins-lk-orders-list,
.bagins-lk-statements-list {
  display: grid;
  gap: 22px;
}

.bagins-lk-order,
.bagins-lk-statement {
  padding: 28px;
  font-family: var(--font-regular);
}

.bagins-lk-card-head {
  margin-bottom: 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.bagins-lk-card-head h2 {
  margin: 0;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 26px;
}

.bagins-lk-card-label {
  margin-bottom: 6px !important;
  color: rgba(62, 40, 40, 0.65);
  font-family: var(--font-medium);
}

.bagins-lk-status {
  min-width: 120px;
  padding: 10px 16px;
  border-radius: var(--radius-pill);
  background: var(--color-main);
  color: var(--color-bg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 14px;
  white-space: nowrap;
}

.bagins-lk-meta {
  margin-bottom: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 24px;
  color: rgba(62, 40, 40, 0.78);
  font-size: 14px;
}

.bagins-lk-items {
  display: grid;
  gap: 12px;
}

.bagins-lk-item {
  padding: 12px;
  border-radius: 18px;
  background: var(--color-light);
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
}

.bagins-lk-item img {
  width: 58px;
  height: 58px;
  object-fit: contain;
}

.bagins-lk-item span {
  color: var(--color-main);
  font-family: var(--font-regular);
}

.bagins-lk-item strong {
  font-family: var(--font-medium);
  white-space: nowrap;
}

.bagins-lk-changes,
.bagins-lk-message,
.bagins-lk-answer,
.bagins-lk-review-box,
.bagins-lk-review-form {
  margin-top: 18px;
  padding: 18px;
  border: 1px solid rgba(62, 40, 40, 0.12);
  border-radius: var(--radius-medium);
  background: var(--color-light);
  color: var(--color-main);
  line-height: 1.5;
}

.bagins-lk-answer,
.bagins-lk-review-box,
.bagins-lk-review-form {
  background: var(--color-soft);
}

.bagins-lk-changes h3,
.bagins-lk-review-box h3,
.bagins-lk-review-form h3 {
  margin: 0 0 12px;
  padding: 0;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 20px;
}

.bagins-lk-change {
  padding-top: 10px;
  border-top: 1px solid rgba(62, 40, 40, 0.12);
}

.bagins-lk-review-box__head,
.bagins-lk-review-form__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.bagins-lk-review-box__head span {
  color: var(--color-accent);
  font-family: var(--font-medium);
  font-size: 20px;
  white-space: nowrap;
}

.bagins-lk-review-box small {
  margin-top: 12px;
  color: rgba(62, 40, 40, 0.58);
  display: block;
}

.bagins-lk-review-delete,
.bagins-lk-actions,
.bagins-lk-order-footer {
  margin-top: 22px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.bagins-lk-review-delete,
.bagins-lk-actions {
  justify-content: flex-end;
}

.bagins-lk-order-footer {
  justify-content: space-between;
  font-family: var(--font-medium);
}

.bagins-lk-review-form {
  display: grid;
  gap: 16px;
}

.bagins-lk-review-form p {
  color: rgba(62, 40, 40, 0.72);
  line-height: 1.55;
}

.bagins-lk-review-form label {
  min-width: 170px;
  display: grid;
  gap: 8px;
  color: var(--color-main);
  font-family: var(--font-medium);
}

.bagins-lk-review-form textarea {
  min-height: 120px;
  resize: vertical;
}

.bagins-lk-empty {
  margin-top: 24px;
  color: var(--color-main);
  font-family: var(--font-medium);
  text-align: center;
}

#admin-products,
#admin-orders,
#admin-statements,
#user-orders,
#user-statements {
  scroll-margin-top: calc(var(--header-height) + 36px);
}

@media (max-width: 1100px) {
  .bagins-lk-nav,
  .bagins-lk-product__head {
    align-items: flex-start;
    flex-direction: column;
  }

  .bagins-lk-nav__links {
    width: 100%;
    justify-content: flex-start;
  }

  .bagins-lk-product-form__grid {
    grid-template-columns: 1fr;
  }

  .bagins-lk-product-form__textarea {
    grid-column: auto;
  }
}

@media (max-width: 760px) {
  .bagins-lk-page {
    width: 92%;
    padding-top: 54px;
  }

  .bagins-lk-title {
    font-size: 34px;
  }

  .bagins-lk-nav,
  .bagins-lk-product,
  .bagins-lk-order,
  .bagins-lk-statement {
    padding: 20px;
    border-radius: 24px;
  }

  .bagins-lk-nav__links {
    display: grid;
    grid-template-columns: 1fr;
  }

  .bagins-lk-nav__links a,
  .bagins-lk-btn,
  .bagins-lk-review-form label,
  .bagins-lk-review-form .bagins-lk-btn {
    width: 100%;
  }

  .bagins-lk-card-head,
  .bagins-lk-review-box__head,
  .bagins-lk-review-form__head,
  .bagins-lk-product-form__bottom,
  .bagins-lk-order-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .bagins-lk-item {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .bagins-lk-item strong {
    grid-column: 2;
  }

  .bagins-lk-review-delete,
  .bagins-lk-actions {
    justify-content: stretch;
  }
}

/* ===== СОГЛАШЕНИЕ О КОНФИДЕНЦИАЛЬНОСТИ И ПОДТВЕРЖДЕНИЕ РЕГИСТРАЦИИ ===== */
.registration-form .field-wrap{width:100%;margin-bottom:10px}
.registration-form input.input-error{border:1px solid #9d2f2f;background:#fff6f6}
.registration-form .field-error{min-height:18px;margin:4px 0 0 4px;color:#9d2f2f;font-family:var(--font-regular);font-size:13px;line-height:1.3}
.registration-form .form-error,
.form-error{margin-bottom:14px;padding:12px 14px;border-radius:16px;background:#fff6f6;color:#9d2f2f;font-family:var(--font-regular);font-size:14px;line-height:1.4}
.form-success{margin:18px 0 10px;padding:12px 14px;border-radius:16px;background:var(--color-success-bg);color:var(--color-success-text);font-family:var(--font-regular);font-size:14px;line-height:1.4}
.agreement-check{display:flex;align-items:flex-start;gap:10px;color:var(--color-main);font-family:var(--font-regular);font-size:13px;line-height:1.35}
.agreement-check input{width:auto;min-width:16px;height:16px;margin:1px 0 0;padding:0;accent-color:var(--color-main)}
.agreement-check a{color:var(--color-accent);font-family:var(--font-medium);text-decoration:underline;text-underline-offset:3px}
.privacy-page,.confirm-page{width:min(90%,1100px);margin:0 auto;padding:56px 0 90px;color:var(--color-main);font-family:var(--font-regular)}
.privacy-hero,.confirm-card{padding:34px;border-radius:var(--radius-large);background:linear-gradient(135deg,var(--color-bg),var(--color-light));box-shadow:var(--shadow-soft)}
.privacy-page__label{margin:0 0 12px;color:var(--color-accent);font-family:var(--font-medium);font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.privacy-hero h1,.confirm-card h1{margin:0 0 14px;padding:0;color:var(--color-main);font-family:var(--font-medium);font-size:34px;line-height:1.2}
.privacy-hero p,.confirm-card p{max-width:760px;margin:0;color:var(--color-main);font-size:16px;line-height:1.6}
.privacy-content{margin-top:28px;padding:32px;border-radius:var(--radius-large);background:#fffdfb;box-shadow:var(--shadow-soft)}
.privacy-section{padding:22px 0;border-bottom:1px solid rgba(62,40,40,.12)}
.privacy-section:first-child{padding-top:0}
.privacy-section:last-of-type{border-bottom:none}
.privacy-section h2{margin:0 0 12px;padding:0;color:var(--color-main);font-family:var(--font-medium);font-size:22px}
.privacy-section p{margin:0;color:var(--color-main);font-size:16px;line-height:1.65}
.privacy-actions{margin-top:28px;display:flex;justify-content:flex-end}
.confirm-page{display:flex;justify-content:center;align-items:flex-start}
.confirm-card{width:min(100%,560px)}
.confirm-form{max-width:none;margin:24px 0 0;padding:0;background:transparent;box-shadow:none}
.confirm-card__link{margin-top:24px}
@media (max-width:760px){.privacy-page,.confirm-page{width:92%;padding:36px 0 70px}.privacy-hero,.privacy-content,.confirm-card{padding:24px;border-radius:22px}.privacy-hero h1,.confirm-card h1{font-size:28px}.privacy-actions{justify-content:stretch}.privacy-actions .btn-primary,.confirm-card__link{width:100%}}

/* ===== ФИЛЬТРАЦИЯ КАТАЛОГА ===== */
.catalog-filter {
  width: min(90%, 1180px);
  margin: -10px auto 28px;
  padding: 24px;
  border-radius: var(--radius-large);
  background: var(--color-bg);
  box-shadow: var(--shadow-soft);
  display: grid;
  grid-template-columns: minmax(240px, 1.4fr) minmax(190px, 0.9fr) minmax(120px, 0.55fr) minmax(120px, 0.55fr) auto;
  align-items: end;
  gap: 16px;
}

.catalog-filter__field {
  display: grid;
  gap: 8px;
}

.catalog-filter__field label {
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 14px;
}

.catalog-filter__field input,
.catalog-filter__field select {
  width: 100%;
  min-height: 46px;
  padding: 12px 15px;
  border: 1px solid rgba(62, 40, 40, 0.18);
  border-radius: var(--radius-pill);
  background: var(--color-light);
  color: var(--color-main);
  font-family: var(--font-regular);
  font-size: 14px;
  outline: none;
}

.catalog-filter__field input:focus,
.catalog-filter__field select:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(115, 82, 59, 0.15);
}

.catalog-filter__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.catalog-filter__submit,
.catalog-filter__reset {
  min-height: 46px;
  padding: 0 20px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-medium);
  font-size: 14px;
  transition: var(--transition-base);
}

.catalog-filter__submit {
  border: none;
  background: var(--color-main);
  color: var(--color-bg);
  cursor: pointer;
}

.catalog-filter__reset {
  border: 1px solid var(--color-main);
  background: transparent;
  color: var(--color-main);
}

.catalog-filter__submit:hover,
.catalog-filter__reset:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(62, 40, 40, 0.16);
}

.catalog-result-info {
  width: min(90%, 1180px);
  margin: 0 auto 24px;
  color: var(--color-main);
  font-family: var(--font-medium);
  font-size: 15px;
  text-align: right;
}

@media (max-width: 1100px) {
  .catalog-filter {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .catalog-filter__field--wide,
  .catalog-filter__actions {
    grid-column: 1 / -1;
  }

  .catalog-filter__actions {
    justify-content: flex-end;
  }
}

@media (max-width: 760px) {
  .catalog-filter {
    width: 92%;
    padding: 18px;
    grid-template-columns: 1fr;
  }

  .catalog-filter__field--wide,
  .catalog-filter__actions {
    grid-column: auto;
  }

  .catalog-filter__actions {
    justify-content: stretch;
  }

  .catalog-filter__submit,
  .catalog-filter__reset {
    width: 100%;
  }

  .catalog-result-info {
    width: 92%;
    text-align: left;
  }
}

/* ===== ОБНОВЛЁННАЯ АДАПТИВНАЯ ШАПКА BAGINS ===== */
:root {
  --header-height: 82px;
}

header {
  height: var(--header-height);
  min-height: var(--header-height);
  border-bottom: 1px solid rgba(62, 40, 40, 0.10);
  box-shadow: 0 8px 22px rgba(62, 40, 40, 0.08);
}

.header-nav {
  width: min(94%, 1240px);
  min-height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.header-logo {
  min-width: max-content;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--color-main);
  transition: var(--transition-base);
}

.header-logo:hover {
  transform: translateY(-1px);
}

.header-logo__mark {
  position: relative;
  width: 48px;
  height: 44px;
  border-radius: 13px 13px 16px 16px;
  background:
    radial-gradient(circle at 70% 28%, rgba(255, 250, 244, 0.84) 0 4px, transparent 5px),
    linear-gradient(145deg, var(--color-main), var(--color-accent));
  box-shadow: 0 8px 16px rgba(62, 40, 40, 0.20);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.header-logo__handle {
  position: absolute;
  top: -8px;
  left: 50%;
  width: 24px;
  height: 18px;
  border: 3px solid var(--color-main);
  border-bottom: 0;
  border-radius: 16px 16px 0 0;
  transform: translateX(-50%);
}

.header-logo__dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-bg);
  box-shadow:
    -9px 8px 0 -3px rgba(255, 250, 244, 0.78),
    9px 8px 0 -3px rgba(255, 250, 244, 0.78);
}

.header-logo__text {
  display: grid;
  gap: 2px;
  line-height: 1;
}

.header-logo__name {
  font-family: var(--font-medium);
  font-size: 24px;
  letter-spacing: 0.08em;
}

.header-logo__tagline {
  color: rgba(62, 40, 40, 0.68);
  font-family: var(--font-regular);
  font-size: 11px;
  letter-spacing: 0.04em;
}

.main-nav {
  flex: 1 1 auto;
}

.main-nav ul,
nav ul {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(12px, 2.4vw, 34px);
  padding: 0;
  margin: 0;
  list-style: none;
}

.main-nav a {
  position: relative;
  min-height: 42px;
  padding: 0 2px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-main);
  font-family: var(--font-medium);
  transition: var(--transition-base);
}

.main-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 5px;
  height: 2px;
  border-radius: 99px;
  background: var(--color-main);
  transform: scaleX(0);
  transform-origin: center;
  transition: var(--transition-base);
}

.main-nav a:hover::after,
.main-nav a:focus-visible::after {
  transform: scaleX(1);
}

.main-nav a:hover,
.main-nav a:focus-visible {
  color: var(--color-accent);
  outline: none;
}

.textHeader {
  font-size: 15px;
  white-space: nowrap;
}

.header-actions {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

.cart-link {
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid rgba(62, 40, 40, 0.16);
  border-radius: var(--radius-pill);
  background: rgba(255, 250, 244, 0.68);
  box-shadow: 0 5px 14px rgba(62, 40, 40, 0.08);
  transition: var(--transition-base);
}

.cart-link:hover,
.cart-link:focus-visible,
.account-button:hover,
.account-button:focus-visible,
.menu-toggle:hover,
.menu-toggle:focus-visible {
  border-color: rgba(62, 40, 40, 0.36);
  background: var(--color-light);
  box-shadow: 0 8px 18px rgba(62, 40, 40, 0.14);
  transform: translateY(-1px);
  outline: none;
}

.cart-link__icon--bag {
  position: relative;
  width: 22px;
  height: 21px;
  border: 2px solid var(--color-main);
  border-radius: 6px 6px 8px 8px;
  display: inline-block;
}

.cart-link__handle {
  position: absolute;
  top: -8px;
  left: 50%;
  width: 12px;
  height: 9px;
  border: 2px solid var(--color-main);
  border-bottom: 0;
  border-radius: 10px 10px 0 0;
  transform: translateX(-50%);
}

.lk {
  opacity: 1;
}

.account-button,
.menu-toggle {
  width: 44px;
  height: 44px;
  border: 1px solid rgba(62, 40, 40, 0.16);
  border-radius: 50%;
  background: rgba(255, 250, 244, 0.68);
  color: var(--color-main);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: var(--transition-base);
}

.account-button__icon {
  position: relative;
  width: 23px;
  height: 23px;
  display: inline-block;
}

.account-button__icon::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 9px;
  height: 9px;
  border: 2px solid var(--color-main);
  border-radius: 50%;
  transform: translateX(-50%);
}

.account-button__icon::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 1px;
  width: 18px;
  height: 11px;
  border: 2px solid var(--color-main);
  border-radius: 14px 14px 7px 7px;
  transform: translateX(-50%);
}

.dropdown {
  top: calc(100% + 12px);
  min-width: 190px;
  overflow: hidden;
  border: 1px solid rgba(62, 40, 40, 0.12);
  border-radius: 18px;
  background: var(--color-light);
  box-shadow: 0 14px 28px rgba(62, 40, 40, 0.18);
}

.dropdown a {
  padding: 12px 16px;
  font-size: 14px;
}

.dropdown a:hover,
.dropdown a:focus-visible {
  background: var(--color-bg);
  outline: none;
}

.menu-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
}

.menu-toggle span {
  width: 20px;
  height: 2px;
  border-radius: 99px;
  background: var(--color-main);
  transition: var(--transition-base);
}

.menu-toggle.is-active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.menu-toggle.is-active span:nth-child(2) {
  opacity: 0;
}

.menu-toggle.is-active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

@media (min-width: 761px) and (max-width: 1100px) {
  :root {
    --header-height: 82px;
  }

  header {
    height: var(--header-height);
    min-height: var(--header-height);
  }

  .header-nav {
    width: 94%;
    min-height: var(--header-height);
    gap: 12px;
  }

  .header-logo {
    gap: 9px;
  }

  .header-logo__mark {
    width: 42px;
    height: 39px;
    border-radius: 12px 12px 14px 14px;
  }

  .header-logo__handle {
    width: 21px;
    height: 16px;
  }

  .header-logo__name {
    font-size: 20px;
  }

  .header-logo__tagline {
    display: none;
  }

  .main-nav ul,
  nav ul {
    flex-wrap: nowrap;
    gap: 10px;
  }

  .main-nav a {
    min-height: 38px;
  }

  .textHeader {
    font-size: 13px;
  }

  .header-actions {
    gap: 8px;
  }

  .cart-link {
    width: 44px;
    padding: 0;
  }

  .cart-link__text {
    display: none;
  }
}

@media (max-width: 760px) {
  :root {
    --header-height: 72px;
  }

  header {
    height: var(--header-height);
    min-height: var(--header-height);
  }

  .header-nav {
    position: relative;
    width: 92%;
    min-height: var(--header-height);
    padding: 0;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 8px;
  }

  .header-logo {
    gap: 8px;
  }

  .header-logo__mark {
    width: 38px;
    height: 35px;
    border-radius: 11px 11px 13px 13px;
  }

  .header-logo__handle {
    top: -7px;
    width: 19px;
    height: 14px;
    border-width: 2px;
  }

  .header-logo__dot {
    width: 11px;
    height: 11px;
  }

  .header-logo__name {
    font-size: 18px;
    letter-spacing: 0.06em;
  }

  .header-logo__tagline {
    display: none;
  }

  .header-actions {
    margin-left: auto;
    gap: 8px;
  }

  .cart-link,
  .account-button,
  .menu-toggle {
    width: 40px;
    height: 40px;
    min-height: 40px;
  }

  .cart-link {
    padding: 0;
  }

  .cart-link__text {
    display: none;
  }

  .cart-link__icon--bag {
    width: 20px;
    height: 19px;
  }

  .account-button__icon {
    width: 21px;
    height: 21px;
  }

  .menu-toggle {
    display: inline-flex;
    flex: 0 0 auto;
  }

  .main-nav {
    position: fixed;
    top: var(--header-height);
    left: 0;
    right: 0;
    z-index: 999;
    width: 100%;
    max-height: 0;
    overflow: hidden;
    background: var(--color-bg);
    border-top: 1px solid rgba(62, 40, 40, 0.10);
    border-bottom: 1px solid rgba(62, 40, 40, 0.10);
    box-shadow: 0 18px 26px rgba(62, 40, 40, 0.14);
    opacity: 0;
    visibility: hidden;
    transition: max-height 0.28s ease, opacity 0.2s ease, visibility 0.2s ease;
  }

  .main-nav.is-open {
    max-height: calc(100vh - var(--header-height));
    opacity: 1;
    visibility: visible;
  }

  .main-nav ul,
  nav ul {
    width: min(92%, 420px);
    margin: 0 auto;
    padding: 12px 0 18px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .main-nav a {
    min-height: 46px;
    padding: 0 16px;
    border: 1px solid rgba(62, 40, 40, 0.12);
    border-radius: 18px;
    background: rgba(255, 250, 244, 0.52);
    justify-content: flex-start;
  }

  .main-nav a::after {
    display: none;
  }

  .main-nav a:hover,
  .main-nav a:focus-visible {
    background: var(--color-light);
    color: var(--color-main);
  }

  .textHeader {
    font-size: 14px;
  }

  .dropdown {
    right: -48px;
    min-width: 178px;
  }

  .cart-badge {
    top: -7px;
    right: -7px;
    min-width: 20px;
    height: 20px;
    font-size: 11px;
  }

  main {
    margin-top: var(--header-height);
  }

  .catalog {
    margin-top: 44px;
  }
}

@media (max-width: 430px) {
  .header-nav {
    width: 94%;
    gap: 6px;
  }

  .header-logo__name {
    font-size: 16px;
  }

  .header-logo__mark {
    width: 34px;
    height: 32px;
  }

  .cart-link,
  .account-button,
  .menu-toggle {
    width: 38px;
    height: 38px;
    min-height: 38px;
  }

  .dropdown {
    right: -44px;
  }
}

@media (max-width: 360px) {
  .header-logo__text {
    display: none;
  }
}

