@charset "UTF-8";
/* @import url("https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,100..900;1,100..900&display=swap"); */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
/* ==========================================================================
Modern CSS Reset / Normalize
========================================================================== */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin, padding and reset fonts */
* {
  margin: 0;
  padding: 0;
  font: inherit;
  box-sizing: border-box;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role=list],
ol[role=list] {
  list-style: none;
}

ul, li {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Set core root defaults */
html {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

@media (max-width: 992px) {
  body.no-scroll {
    overflow: hidden;
    position: fixed;
    width: 100%;
    height: 100vh; /* опционально, для фиксации высоты */
  }
}
body.no-scroll {
  overflow: hidden;
  position: fixed;
  width: 100%;
  height: 100vh; /* опционально, для фиксации высоты */
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture,
svg,
video {
  max-width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/* Remove default button styles */
button {
  background: none;
  border: none;
  cursor: pointer;
}

/* Remove text decoration from links */
a {
  text-decoration: none;
  color: inherit;
}

/* Table reset */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Fieldset reset */
fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

/* Remove blue highlight on tap for mobile */
input,
textarea,
button,
select,
a {
  -webkit-tap-highlight-color: transparent;
}

/* Remove number input spinners */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox */
input[type=number] {
  -moz-appearance: textfield;
}

/* Remove autofill background color */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-transition: background-color 5000s ease-in-out 0s;
  transition: background-color 5000s ease-in-out 0s;
}

/* Smooth font rendering */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Remove outline for non-keyboard users */
:focus:not(:focus-visible) {
  outline: none;
}

/* Improve focus visibility for keyboard navigation */
:focus-visible {
  outline: 2px solid #007bff;
  outline-offset: 2px;
}

/* Visually hidden utility class */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

body {
  background: #fff;
  font-family: "Inter", sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  max-width: 1920px;
  margin: 0 auto;
  min-width: 320px;
}

.container {
  max-width: 1280px;
  margin: 0 auto;
}

.mt60 {
  margin-top: 60px;
}

.n {
  display: none !important;
}

.button {
  display: inline-flex;
  background: #fae95b;
  color: #000;
  border-radius: 12px;
  font-weight: 500;
  font-size: 14px;
  line-height: 140%;
}

.hr {
  border-left: 1px solid rgba(255, 255, 255, 0.55);
  height: 40px;
  opacity: 0.5;
}

.title {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  line-height: 120%;
  text-align: center;
}

.header__content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 44px;
  flex-wrap: wrap;
  height: 100%;
}
@media (max-width: 992px) {
  .header__content {
    padding: 0 15px;
  }
}
.header__contacts {
  display: flex;
  gap: 12px;
}
@media (max-width: 992px) {
  .header__contacts {
    gap: 8px;
  }
}
.header__socials {
  display: flex;
  gap: 8px;
}
.header__social-item {
  display: flex;
  align-items: center;
  padding: 6px 8px;
  gap: 8px;
}
@media (max-width: 992px) {
  .header__social-item {
    padding: 0;
  }
}
@media (max-width: 1440px) {
  .header__social-item span {
    display: none;
  }
}
.header__phone-wrap {
  display: flex;
  padding: 8px 0 8px 8px;
  gap: 8px;
}
@media (max-width: 992px) {
  .header__phone-wrap {
    padding: 0;
  }
}
.header__phone-desktop {
  font-size: 18px;
  font-weight: 500;
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
@media (max-width: 992px) {
  .header__phone-desktop {
    display: none;
  }
}
@media (min-width: 992px) {
  .header__phone-mob {
    display: none;
  }
}
.header__socials-telegram, .header__socials-whatsapp {
  font-size: 14px;
  font-weight: 400;
}
.header__hr {
  border-left: 1px solid rgb(217, 217, 217);
  height: 28px;
  margin: auto;
}
@media (max-width: 992px) {
  .header__hr {
    display: none;
  }
}

/* .nav {
display: flex;
flex-wrap: wrap;
}*/

.menu-list {
  display: flex;
  flex-wrap: wrap;
  @media (max-width: 992px) {
    display: none;  
  }
}
.nav__link, .menu-item {
  font-size: 16px;
  font-weight: 400;
  line-height: 150%;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  text-transform: uppercase;
}

.menu-item {
  color: #000;
}
@media (max-width: 1440px) {
  .nav__link {
    font-size: 14px;
  }
}
@media (max-width: 992px) {
  
  .menu-item {
    color: #fff;
  }
  .nav__link {
    display: none;
  }
}

.promo {
  position: relative;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
  background-size: cover;
  /* animation: gentleZoom 20s infinite alternate ease-in-out; */
}

body .recommended-swiper {
  padding: 0 15px;
}





@keyframes gentleZoom {
  0% {
    background-size: 100%;
  }
  100% {
    background-size: 110%;
  }
}


.promo::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.55);
  z-index: 1;
}
.promo__container {
  position: relative;
  z-index: 2;
  padding-top: 96px;
  padding-bottom: 96px;
}
@media (max-width: 1440px) {
  .promo__container {
    padding-top: 64px;
    padding-bottom: 72px;
  }
}
@media (max-width: 1280px) {
  .promo__container {
    padding-left: 56px;
    padding-right: 56px;
  }
}
@media (max-width: 992px) {
  .promo {
    background-size: cover!important;
  }
  .promo__container {
    padding: 44px 20px;
  }
}
.promo__title {
  font-size: min(48px, 36px + 12 * (100vw - 430px) / 850);
  color: #ecf0f1;
  font-weight: 300;
  max-width: 669px;
  line-height: 120%;
}
.promo__stats {
  margin-top: 28px;
}
.promo__stat-item {
  color: #ecf0f1;
  font-size: min(20px, 16px + 4 * (100vw - 430px) / 850);
  font-weight: 400;
  font-style: Regular;
  line-height: 140%;
  letter-spacing: 0%;
}
.promo__button {
  margin-top: 40px;
  padding: 14px 40px;
  gap: 3px;
}
.promo__features {
  display: flex;
  justify-content: space-between;
  margin-top: 238px;
  padding-bottom: 73px;
}
@media (max-width: 1440px) {
  .promo__features {
    margin-top: 170px;
  }
}
@media (max-width: 1280px) {
  .promo__features {
    margin-top: 86px;
  }
}
@media (max-width: 992px) {
  .promo__features {
    flex-direction: column;
    gap: 26px;
    font-size: 16px;
  }
}
@media (max-width: 992px) {
  .promo .hr {
    display: none;
  }
}
.promo__feature {
  display: flex;
  align-items: center;
  gap: 20px;
}
@media (max-width: 992px) {
  .promo svg {
    width: 40px;
    height: 40px;
  }
}
.promo__feature-text {
  color: #ecf0f1;
  font-size: 18px;
  font-weight: 400;
}
@media (max-width: 992px) {
  .promo__feature-text {
    font-size: 16px;
  }
}

.products__container {
  padding: 80px 44px;
}
@media (max-width: 992px) {
  .products__container {
    padding: 64px 15px;
  }
}
.products__title {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  line-height: 120%;
  text-align: center;
}
.products__description {
  margin-top: 16px;
  text-align: center;
}
.products__description-text {
  line-height: 155%;
  font-size: 18px;
  font-weight: 400;
  color: #444444;
}
.products__description-text--green {
  color: #009930;
}

.products__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  margin-top: 40px;
}



.products__grid--catalog {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 80px;
}
@media (max-width: 992px) {
  .products__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
}
@media (max-width: 375px) {
  .products__grid {
    grid-template-columns: repeat(1, 1fr);
  }
}
.products__card img {
  border-radius: 16px;
  width: 100%;
  height: auto;
}
.products__content {
  margin: 12px auto;
}
.products__size {
  font-size: 14px;
  font-weight: 600;
  font-weight: 140%;
  text-transform: uppercase;
}
.products__card-title {
  line-height: 150%;
  font-size: 16px;
  font-weight: 400;
  margin-top: 4px;
}
.products__price-wrapper {
  margin-top: 16px;
}
.products__price--current {
  font-size: 20px;
  font-weight: 500;
  color: #009930;
  line-height: 120%;
}
.products__price--old {
  color: #757575;
  line-height: 150%;
  text-decoration: line-through;
  font-size: 16px;
  font-weight: 400;
}
.products__button {
  padding: 14px 40px;
  margin-top: 20px;
}
.products__grid--catalog {
  grid-template-columns: repeat(4, 1fr);
  padding-bottom: 112px;
}
@media (max-width: 992px) {
  .products__grid--catalog {
    grid-template-columns: repeat(1, 1fr);
    /* padding-left: 20px; */
    /* padding-right: 20px; */
    gap: 12px;
    padding-bottom: 0;
  }
}

.tabs {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 40px;
  width: 100%;
  gap: 28px;
  overflow: auto;
  white-space: nowrap;
}
@media (max-width: 992px) {
  .tabs {
    overflow: auto;
    justify-content: flex-start;
  }
}
.tabs__item {
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 400;
  line-height: 140%;
  color: #b3b3b3;
}
.tabs__item--active {
  color: #000;
}

.advantages {
  background-color: #f5f5f5;
}
.advantages__container {
  padding-top: 96px;
  padding-bottom: 112px;
  padding-left: 48px;
  padding-right: 48px;
}
@media (max-width: 992px) {
  .advantages__container {
    padding: 64px 15px;
  }
}
.advantages__title {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  line-height: 120%;
  text-align: center;
}
.advantages__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 64px;
}
@media (max-width: 1920px) {
  .advantages__list {
    grid-template-columns: repeat(5, 1fr);
    display: grid;
    gap: 20px;
  }
}
@media (max-width: 1440px) {
  .advantages__list {
    display: flex;
    gap: 16px;
  }
}
@media (max-width: 1280px) {
  .advantages__list {
    display: flex;
    gap: 12px;
  }
}
.advantages__card {
  padding: 20px;
  background-color: #fff;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 320px;
  flex: 1 0 100%;
}
@media (max-width: 1440px) {
  .advantages__card {
    height: 248px;
    /* width: 437px; */
  }
}
@media (max-width: 1280px) {
  .advantages__card {
    height: 220px;
    width: 100%;
    /* max-width: 386px; */
  }
}
@media (max-width: 992px) {
  .advantages__card {
    gap: 33px;
    min-height: 240px;
    padding: 24px;
    justify-content: initial;
  }
}
.advantages__card-title {
  font-size: 20px;
  font-weight: 400;
  line-height: 120%;
  max-width: 236px;
}
@media (max-width: 992px) {
  .advantages__card-title {
    max-width: 100%;
    font-size: 19px;
  }
}
.advantages__content {
  display: flex;
  align-items: center;
  gap: 16px;
}
.advantages__card-description {
  line-height: 150%;
  font-size: 16px;
  font-weight: 400;
  color: #444444;
}

.catalog__container {
  padding: 80px 44px 96px 44px;
}
@media (max-width: 992px) {
  .catalog__container {
    padding-left: 15px;
    padding-right: 15px;
    padding-top: 64px;
    padding-bottom: 80px;
  }
}
.catalog__title {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  line-height: 120%;
  text-align: center;
}
.catalog__subtitle {
  color: #444444;
  font-size: 18px;
  font-weight: 400;
  line-height: 155%;
  text-align: center;
  margin-top: 16px;
}
.catalog__discount-date {
  color: #009930;
  font-size: 18px;
  font-weight: 400;
  line-height: 155%;
}
.catalog__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 56px;
}
@media (max-width: 992px) {
  .catalog__grid {
    grid-template-columns: repeat(1, 1fr);
  }
}
.catalog__card {
  max-width: 906px;
  min-height: max(220px, min(309px, 220px + 89 * (100vw - 430px) / 1010));
  width: 100%;
  position: relative;
  background-size: cover;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-radius: 16px;
  padding: 32px;
  transition: all 0.3s ease;
}
@media (min-width: 1600px) {
  .catalog__card {
    height: 420px;
  }
}

.catalog__card-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.catalog__card-link:hover .catalog__card {
  transform: translateY(-5px);
  box-shadow: 0 10px 20px rgba(0,0,0,0.1);
  transition: all 0.3s ease;
}



.catalog__card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  border-radius: 16px;
}
.catalog__card-title {
  color: #ffffff;
  font-size: max(20px, min(24px, 20px + 4 * (100vw - 430px) / 850));
  font-weight: 400;
  line-height: 120%;
  position: relative;
  z-index: 2;
}
.catalog__card-description {
  font-size: max(12px, min(14px, 12px + 2 * (100vw - 430px) / 850));
  font-weight: 400;
  line-height: 140%;
  color: #ffffff;
  position: relative;
  z-index: 2;
  margin-top: 16px;
  text-align: center;
}
.catalog__card-button {
  z-index: 2;
  padding: 14px 40px;
  margin-top: 28px;
}

.about {
  position: relative;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  padding-top: 128px;
  padding-bottom: 64px;
  height: 680px;
}
@media (max-width: 1440px) {
  .about {
    padding-top: 96px;
  }
}
@media (max-width: 992px) {
  .about {
    height: auto;
    padding-left: 20px;
    padding-right: 20px;
  }
}
.about::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
}
.about__container {
  position: relative;
  z-index: 2;
}
.about__title {
  color: #ffffff;
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  line-height: 120%;
  text-align: center;
}
.about__description {
  line-height: 150%;
  font-size: 16px;
  font-weight: 400;
  color: #ffffff;
  margin: auto;
  margin-top: 12px;
  text-align: center;
  max-width: 990px;
  width: 100%;
  display: block;
}
.about__features {
  margin-top: 221px;
  display: flex;
  gap: 24px;
}
@media (max-width: 992px) {
  .about__features {
    flex-wrap: wrap;
    margin-top: 114px;
  }
}

.about__feature {
  flex: 1;
}

.about__feature-content {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
}
.about__feature-icon {
  flex: 1 0 auto;
}
.about__feature-title {
  font-size: 16px;
  font-weight: 400;
  line-height: 150%;
  color: #ffffff;
  margin-top: 44px;
}
@media (max-width: 992px) {
  .about__features {
    flex-direction: column;
  }
  .about__feature-title {
    margin-top: 0;
  }
  .about__feature-content {
    flex-wrap: nowrap;
    gap: 24px;
  }
}
.about__feature-title-green {
  color: #10d84f;
}
.about .hr {
  border: 1px solid rgb(0, 0, 0);
  height: auto;
  opacity: 0.1;
}
@media (max-width: 992px) {
  .about .hr {
    display: none;
  }
}

.reviews__container {
  padding: 80px 80px 96px 80px;
  background-color: #f5f5f5;
}
@media (max-width: 992px) {
  .reviews__container {
    padding: 64px 15px;
  }
}
.reviews__title {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  line-height: 120%;
  text-align: center;
}
.reviews__title-accent {
  color: #10d84f;
}
.reviews__slider {
  margin-top: 64px;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 40px;
  max-width: 1280px;
  width: 100%;
  margin: auto;
  margin-top: 64px;
  overflow-x: scroll;
}
.reviews__card-image {
  width: 100%;
  margin: 0 auto;
  max-width: 300px;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 16px;
}
.reviews__pagination {
  display: flex;
  gap: 16px;
  justify-content: center;
  padding: 6px;
  margin-top: 48px;
  align-items: center;
}
.reviews__dot, .swiper-pagination-bullet {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: rgba(12, 12, 13, 0.1215686275);
  cursor: pointer;
}
.reviews__dot--active, .reviews__pagination span.swiper-pagination-bullet-active {
  background-color: #000;
  width: 8px;
  height: 8px;
}

.video-showcase {
  margin: 0 auto;
  padding-top: 96px;
  padding-bottom: 128px;
}
@media (max-width: 992px) {
  .video-showcase {
    padding-top: 64px;
    padding-bottom: 64px;
  }
}

.video-showcase__title {
  text-align: center;
  line-height: 120%;
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  color: #000;
  margin-bottom: 56px;
}

.video-showcase__container {
  position: relative;
  padding: 20px;
  overflow: visible;
}

.video-showcase__slider {
  position: relative;
  height: 450px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.video-showcase__slide {
  position: absolute;
  width: 364px;
  height: 225px;
  border-radius: 20px;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  opacity: 0.5;
  z-index: 1;
  left: 50%;
  transform-origin: center center;
}

.video-showcase__slide--active {
  opacity: 1;
  max-width: 800px;
  width: 100%;
  height: 450px;
  z-index: 10;
  transform: translateX(-50%) scale(1);
}
@media (max-width: 1600px) {
  .video-showcase__slide--active {
    max-width: 608px;
    height: 342px;
  }
}
@media (max-width: 1280px) {
  .video-showcase__slide--active {
    max-width: 534px;
    height: 301px;
  }
}

.video-showcase__slide--prev,
.video-showcase__slide--next {
  opacity: 1;
  width: 100%;
  max-width: 600px;
  height: 337px;
  z-index: 5;
}
@media (max-width: 1600px) {
  .video-showcase__slide--prev,
  .video-showcase__slide--next {
    max-width: 454px;
    height: 255px;
  }
}
@media (max-width: 1280px) {
  .video-showcase__slide--prev,
  .video-showcase__slide--next {
    max-width: 398px;
    height: 224px;
  }
}

.video-showcase__slide--prev {
  transform: translateX(calc(-50% - 400px)) scale(1);
}
@media (max-width: 1600px) {
  .video-showcase__slide--prev {
    transform: translateX(calc(-50% - 300px)) scale(1);
  }
}
@media (max-width: 992px) {
  .video-showcase__slide--prev {
    transform: none;
  }
}

.video-showcase__slide--next {
  transform: translateX(calc(-50% + 400px)) scale(1);
}
@media (max-width: 1600px) {
  .video-showcase__slide--next {
    transform: translateX(calc(-50% + 300px)) scale(1);
  }
}
@media (max-width: 992px) {
  .video-showcase__slide--next {
    transform: none;
  }
}

.video-showcase__slide--prev-2,
.video-showcase__slide--next-2 {
  opacity: 1;
  width: 100%;
  max-width: 364px;
  height: 225px;
  z-index: 3;
}
@media (max-width: 1600px) {
  .video-showcase__slide--prev-2,
  .video-showcase__slide--next-2 {
    max-width: 276px;
    height: 170px;
  }
}
@media (max-width: 1280px) {
  .video-showcase__slide--prev-2,
  .video-showcase__slide--next-2 {
    max-width: 242px;
    height: 150px;
  }
}

.video-showcase__slide--prev-2 {
  transform: translateX(calc(-50% - 700px)) scale(1);
}
@media (max-width: 1600px) {
  .video-showcase__slide--prev-2 {
    transform: translateX(calc(-50% - 500px)) scale(1);
  }
}

.video-showcase__slide--next-2 {
  transform: translateX(calc(-50% + 700px)) scale(1);
}
@media (max-width: 1600px) {
  .video-showcase__slide--next-2 {
    transform: translateX(calc(-50% + 500px)) scale(1);
  }
}

.video-slide__wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  background: #000;
  overflow: hidden;
}
.video-slide__wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 10;
  transition: opacity 0.3s ease;
  opacity: 1;
}
.video-showcase__slide--active .video-slide__wrapper::before {
  opacity: 0;
  pointer-events: none;
}

.video-slide__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transition: transform 0.3s ease;
  pointer-events: none;
}

.video-showcase__slide:hover .video-slide__image {
  transform: scale(1.02);
}

.video-slide__play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 50px;
  height: 50px;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 50%;
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  z-index: 2;
}

.video-showcase__slide--active .video-slide__play-button {
  width: 70px;
  height: 70px;
  display: flex;
}

.video-slide__play-button:hover {
  transform: translate(-50%, -50%) scale(1.1);
  background: #fff;
}

.video-slide__play-button svg {
  width: 20px;
  height: 20px;
  fill: #333;
  margin-left: 2px;
}

.video-showcase__arrow {
  position: absolute;
  top: 44%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  background: rgba(255, 255, 255, 0.95);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  transition: all 0.3s ease;
  z-index: 20;
}
@media (max-width: 1440px) {
  .video-showcase__arrow {
    top: 44%;
  }
}

.video-showcase__arrow:hover {
  background: #fff;
  transform: translateY(-50%) scale(1.1);
}

.video-showcase__arrow:active {
  transform: translateY(-50%) scale(0.95);
}

.video-showcase__arrow--prev {
  left: 20%;
}
@media (max-width: 1600px) {
  .video-showcase__arrow--prev {
    left: 20%;
  }
}

.video-showcase__arrow--next {
  right: 20%;
}
@media (max-width: 1600px) {
  .video-showcase__arrow--next {
    right: 20%;
  }
}

.video-showcase__arrow svg {
  width: 22px;
  height: 22px;
  fill: #333;
}

.video-showcase__pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  margin-top: 56px;
}

.video-showcase__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  border: none;
  background: rgba(12, 12, 13, 0.1215686275);
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0;
}

.video-showcase__dot--active {
  background: #000;
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.video-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.95);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.video-modal--active {
  display: flex;
  opacity: 1;
}

.video-modal__content {
  position: relative;
  width: 90%;
  max-width: 1000px;
  aspect-ratio: 16/9;
  background: #000;
  border-radius: 12px;
  overflow: hidden;
  transform: scale(0.95);
  transition: transform 0.3s ease;
}

.video-modal--active .video-modal__content {
  transform: scale(1);
}

.video-modal__close {
  position: absolute;
  top: 12px;
  right: 20px;
  background: rgba(255, 255, 255, 0.2);
  border: none;
  color: #fff;
  font-size: 32px;
  cursor: pointer;
  z-index: 1001;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  line-height: 1;
}

.video-modal__close:hover {
  background: rgba(255, 255, 255, 0.4);
}

.video-modal__iframe {
  width: 100%;
  height: 100%;
  border: none;
}

@media (max-width: 992px) {
  .video-showcase__slide--active {
    width: 650px;
    height: 366px;
  }
  .video-showcase__slide--prev,
  .video-showcase__slide--next {
    width: 480px;
    height: 270px;
    opacity: 0;
  }
  .video-showcase__slide--prev {
    transform: translateX(calc(-50% - 325px)) scale(1);
    opacity: 0;
  }
  .video-showcase__slide--next {
    transform: translateX(calc(-50% + 325px)) scale(1);
    opacity: 0 !important;
  }
  .video-showcase__slide--prev-2 {
    transform: translateX(calc(-50% - 550px)) scale(1);
    opacity: 0;
  }
  .video-showcase__slide--next-2 {
    transform: translateX(calc(-50% + 550px)) scale(1);
    opacity: 0;
  }
}
@media (max-width: 992px) {
  /* Контейнер слайдера — убираем лишние отступы */
  .video-showcase__slider {
    height: auto;
    min-height: 250px;
    padding: 0 10px;
  }
  /* Базовый стиль для всех слайдов — скрываем */
  .video-showcase__slide {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateX(-50%) scale(0.95) !important;
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
    width: 100%;
  }
  /* Активный слайд — показываем на всю ширину */
  .video-showcase__slide--active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    position: relative; /* меняем с absolute, чтобы не ломать поток */
    left: 0;
    width: 100%;
    max-width: 100%;
    height: auto;
    aspect-ratio: 16/9;
    border-radius: 16px;
    transform: none !important;
    z-index: 10;
  }
  /* Изображение в активном слайде */
  .video-showcase__slide--active .video-slide__image {
    border-radius: 16px;
    -o-object-fit: cover;
    object-fit: cover;
  }
  /* Кнопка Play — адаптируем под мобильные */
  .video-showcase__slide--active .video-slide__play-button {
    width: 56px;
    height: 56px;
    display: flex;
  }
  .video-slide__play-button svg {
    width: 18px;
    height: 18px;
  }
  /* Стрелки навигации — скрываем на мобильном, т.к. слайдов по бокам нет */
  .video-showcase__arrow {
    display: flex;
  }
  .video-showcase__arrow--prev {
    left: 10%;
    opacity: 0.7;
  }
  .video-showcase__arrow--next {
    right: 10%;
    opacity: 0.7;
  }
  /* Пагинация — делаем крупнее для тапа */
  .video-showcase__pagination {
    gap: 12px;
    margin-top: 32px;
  }
  .video-showcase__dot {
    width: 8px;
    height: 8px;
  }
  .video-showcase__dot--active {
    width: 10px;
    height: 10px;
  }
  /* Заголовок — уменьшаем отступы */
  .video-showcase__title {
    font-size: 28px;
    margin-bottom: 32px;
    padding: 0 16px;
  }
  /* Контейнер — убираем лишние padding */
  .video-showcase__container {
    padding: 0;
  }
}
.gallery {
  background: #f5f5f5;
  padding: 96px 0;
}

/* Контейнер ссылки – относительное позиционирование */
.gallery__item a {
  position: relative;
  display: block;
  overflow: hidden;
}

/* Оверлей – скрыт по умолчанию, занимает всю область */
.gallery__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
  border-radius: 16px;
  cursor: pointer;
}

/* При наведении на ссылку – показываем оверлей */
.gallery__item a:hover .gallery__overlay {
  opacity: 1;
}

.gallery__zoom-icon {
  width: 48px;
  height: 48px;
  opacity: 0.8;
  transition: transform 0.2s;
}

.gallery__item a:hover .gallery__zoom-icon {
  transform: scale(1.1);
}

/* Стили для текста призыва */
.gallery__cta {
  color: #fff;
  font-size: 1.2rem;
  font-weight: bold;
  background: rgba(0, 0, 0, 0.7);
  padding: 10px 20px;
  border-radius: 30px;
  text-transform: uppercase;
  letter-spacing: 1px;
  transform: scale(0.9);
  transition: transform 0.2s ease;
}

/* Эффект увеличения текста при наведении на оверлей */
.gallery__item a:hover .gallery__cta {
  transform: scale(1);
}



@media (max-width: 1440px) {
  .gallery {
    padding-top: 64px;
    padding-bottom: 64px;
    padding-left: 20px;
    padding-right: 20px;
  }
}
.gallery__title {
  text-align: center;
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  line-height: 120%;
}
@media (max-width: 576px) {
  .gallery__title {
    font-size: 24px;
    padding: 0 16px;
  }
}
.gallery__description {
  text-align: center;
  font-size: 16px;
  font-weight: 400;
  line-height: 150%;
  margin-top: 16px;
}
@media (max-width: 576px) {
  .gallery__description {
    font-size: 14px;
    padding: 0 20px;
  }
}
.gallery__description--accent {
  color: #009930;
}
.gallery__inner {
  display: grid;
  grid-template-columns: 421px 207px 207px 421px;
  grid-template-rows: 207px 207px;
  gap: 7px;
  margin: 56px auto 0;
  max-width: 1276px;
}

.gallery__inner .gallery__item--tall .gallery__image {
  max-height: 421px;
}
@media (max-width: 1280px) {
  .gallery__inner {
    display: grid;
    grid-template-columns: 390px 191px 191px 390px;
    grid-template-rows: 191px 191px;
    gap: 7px;
    margin: 56px auto 0;
    /* max-width: 1280px; */
    /* margin: auto; */
    justify-content: center;
  }
}
@media (max-width: 1279px) {
  .gallery__inner {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    gap: 8px;
    margin: 32px auto 0;
  }
  .gallery__inner .gallery__item:nth-child(1) {
    grid-column: 1/-1;
    height: 280px;
  }
  .gallery__inner .gallery__item:nth-child(2),
  .gallery__inner .gallery__item:nth-child(3),
  .gallery__inner .gallery__item:nth-child(4),
  .gallery__inner .gallery__item:nth-child(5) {
    grid-column: auto;
    height: 140px;
  }
  .gallery__inner .gallery__item:nth-child(6) {
    grid-column: 1/-1;
    height: 280px;
  }
  .gallery__inner .gallery__item--tall {
    grid-column: auto;
    grid-row: auto;
    height: auto;
  }
}
@media (max-width: 992px) {
  .gallery__inner .gallery__item--tall .gallery__image {
    max-height: 345px;
  }
  .gallery__inner {
    gap: 12px;
  }
  .gallery__inner .gallery__item:nth-child(1),
  .gallery__inner .gallery__item:nth-child(6) {
    height: 390px;
  }
  .gallery__inner .gallery__item:nth-child(2),
  .gallery__inner .gallery__item:nth-child(3),
  .gallery__inner .gallery__item:nth-child(4),
  .gallery__inner .gallery__item:nth-child(5) {
    height: auto;
  }
}

.gallery__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 16px;
  display: block;
}
@media (max-width: 768px) {
  .gallery__image {
    border-radius: 12px;
  }
}

.gallery__item {
  overflow: hidden;
}
.gallery__item:active {
  transform: scale(0.98);
  transition: transform 0.2s ease;
}

.gallery__item--tall:first-child {
  grid-column: 1/2;
  grid-row: 1/3;
}
@media (max-width: 1279px) {
  .gallery__item--tall:first-child {
    grid-column: auto;
    grid-row: auto;
  }
}
.gallery__item--tall:last-child {
  grid-column: 4/5;
  grid-row: 1/3;
}
@media (max-width: 1279px) {
  .gallery__item--tall:last-child {
    grid-column: auto;
    grid-row: auto;
  }
}

@supports (padding: max(0px)) {
  @media (max-width: 992px) {
    .gallery {
      padding-left: max(15px, env(safe-area-inset-left));
      padding-right: max(15px, env(safe-area-inset-right));
    }
  }
}
.delivery__wrapper {
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: start;
}
@media (max-width: 992px) {
  .delivery__wrapper {
    display: block;
  }
}
.delivery__wrapper--page-catalog {
  background: #f5f5f5;
}
.delivery__wrapper--page-catalog .delivery__container {
  padding-bottom: 44px;
}
.delivery__media {
  max-height: 800px;
}
@media (max-width: 1600px) {
  .delivery__media {
    height: 100%;
  }
}
@media (max-width: 992px) {
  .delivery__media {
    height: 430px;
  }
}
.delivery__picture {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 800px;
}
.delivery__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  max-height: 800px;
}
.delivery__container {
  padding: 134px 112px;
}
@media (max-width: 1600px) {
  .delivery__container {
    padding: 48px 64px;
  }
}
@media (max-width: 992px) {
  .delivery__container {
    padding: 32px 15px;
    padding-bottom: 0;
    background: #f5f5f5;
  }
}
.delivery__title {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  color: #000;
  line-height: 120%;
}
.delivery__description {
  font-size: 16px;
  font-weight: 400;
  line-height: 150%;
  margin-top: 16px;
}
.delivery__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 56px;
}
@media (max-width: 1600px) {
  .delivery__list {
    margin-top: 40px;
    gap: 8px;
  }
}
.delivery__item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 32px;
  background-color: #f5f5f5;
  border-radius: 16px;
  transition: all 0.3s ease;
}
@media (max-width: 1600px) {
  .delivery__item {
    padding: 28px;
  }
}
@media (max-width: 992px) {
  .delivery__item {
    background: #fff;
  }
}
.delivery__item:hover {
  background-color: #f0f0f0;
  transform: translateX(5px);
}
.delivery__wrapper--page-catalog .delivery__item {
  background: #fff;
}
.delivery__icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.delivery__content {
  flex: 1;
}
.delivery__subtitle {
  font-size: 20px;
  font-weight: 400;
  line-height: 120%;
}
.delivery__text {
  font-size: 16px;
  color: #444444;
  margin-top: 8px;
  line-height: 150%;
  font-weight: 400;
}

.payment {
  padding-top: 80px;
  padding-bottom: 96px;
  background-color: #f5f5f5;
}
.payment--page-catalog {
  background: #fff;
}
.payment--page-catalog .payment-card {
  background: #f5f5f5;
  box-shadow: none;
}
@media (max-width: 992px) {
  .payment {
    padding: 44px 0;
  }
}
.payment__subtitle {
  font-size: 16px;
  font-weight: 400;
  line-height: 150%;
  text-align: center;
  color: #444444;
  margin-top: 16px;
}
.payment__methods {
  margin-top: 64px;
  display: flex;
  justify-content: center;
  gap: 20px;
}
@media (max-width: 1600px) {
  .payment__methods {
    gap: 16px;
    padding: 0 15px;
  }
}
@media (max-width: 1280px) {
  .payment__methods {
    gap: 12px;
  }
}
@media (max-width: 992px) {
  .payment__methods {
    flex-direction: column;
  }
}

.payment-card {
  padding: 32px;
  border-radius: 16px;
  background-color: #fff;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  width: 100%;
}
.payment-card__title {
  font-size: 20px;
  font-weight: 400;
  line-height: 120%;
  color: #000;
}
.payment-card__text {
  font-size: 14px;
  font-weight: 400;
  line-height: 140%;
  color: #444444;
  margin-top: 12px;
}

.contacts__wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 992px) {
  .contacts__wrapper {
    display: block;
  }
}
.contacts__info {
  padding: 76px 240px;
}
@media (max-width: 1440px) {
  .contacts__info {
    padding: 72px 120px;
  }
}
@media (max-width: 1280px) {
  .contacts__info {
    padding: 72px 80px;
  }
}
@media (max-width: 992px) {
  .contacts__info {
    padding: 48px 15px;
  }
}
.contacts__title {
  -moz-text-align-last: left;
  text-align-last: left;
}

.contacts-list {
  margin-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.contacts-list__link {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  line-height: 140%;
}
.contacts-list__item--address {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  line-height: 140%;
  font-weight: 500;
}

.delivery-calculator {
  margin-top: 40px;
  background: #fff1df;
  padding: 23px;
  padding-bottom: 28px;
  border-radius: 16px;
}

.delivery-calculator__wrapper {
  background: linear-gradient(73.55deg, #00cfff 14.56%, #5b31f8 63.57%, #a628e5 88.6%);
  color: #fff;
  padding: 12px 28px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.delivery-calculator__tabs {
  display: flex;
  gap: 24px;
  margin-top: 12px;
}
.delivery-calculator__tab {
  display: flex;
  align-items: center;
  gap: 8px;
}
.delivery-calculator__tab input {
  width: 24px;
  height: 24px;
}
.delivery-calculator__tab:has(input:checked) {
  border-color: #000;
}
.delivery-calculator__text {
  font-size: 14px;
  font-weight: 500;
  line-height: 140%;
  color: #000;
}
.delivery-calculator__title, .delivery-calculator__subtitle {
  line-height: 120%;
  font-weight: 400;
  font-size: 14px;
}

.form-group {
  margin-top: 12px;
  display: flex;
  gap: 8px;
}
@media (max-width: 992px) {
  .form-group {
    flex-direction: column;
  }
  .delivery-calculator {
    padding: 15px;
  }
}
@media (max-width: 375px) {
  .delivery-calculator__tabs {
    justify-content: space-between;
  }
  .delivery-calculator__tab input {
    width: 20px;
    height: 20px;
  }
  .delivery-calculator__text {
    font-size: 11px;
  }
}

.form-group__input {
  border: 0;
  padding: 18px;
  width: 100%;
  color: #232326;
  line-height: 140%;
  font-size: 14px;
  border-radius: 12px;
  background-color: #fff;
  font-weight: 400;
}
.form-group__btn {
  background-color: #000;
  color: #ffffff;
  padding: 16px 40px;
  border-radius: 12px;
  border: 0;
  font-size: 15px;
  font-weight: 500;
  line-height: 150%;
  flex: 1 0 auto;
}

.page-catalog__description {
  padding-left: 20px;
  padding-right: 20px;
}
.page-catalog__categories {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 12px;
  margin-top: 56px;
}
@media (max-width: 992px) {
  .page-catalog__categories {
    justify-content: center;
    align-items: center;
    /* padding-left: 20px; */
    /* padding-right: 20px; */
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  }
  .page-catalog__categories .category-card__image {
    display: none;
  }
}
.page-catalog__category-card {
  background: #f5f5f5;
  border-radius: 16px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  padding-bottom: 32px;
  outline: none;
  transition: all 0.3s ease;
  /* max-width: 356px; */
  width: 100%;
  height: 233px;
}

.page-catalog__category-card .category-card__title {
  font-size: min(18px, 14px + 4 * (100vw - 430px) / 850);
  font-weight: 500;
  line-height: 155%;
  text-transform: uppercase;
  text-align: center;
  color: #000;
}

.page-catalog__category-card .category-card__image {
  max-width: 220px;
  width: 100%;
  object-fit: contain;
  height: 129px;
} 

.page-catalog__category-card:hover, .page-catalog__category-card.tabs__item--active {
  outline: 1px solid var(--Brand-1000, rgb(0, 0, 0));
  cursor: pointer;
}

@media (max-width: 992px) {
  .page-catalog__category-card.tabs__item.tabs__item--active {
    outline: none;
    cursor: pointer;
    background: #000;
  }
  
  .page-catalog__category-card.tabs__item.tabs__item--active .category-card__title {
    color: #fff;
  }
}
@media (max-width: 1440px) {
  .page-catalog__category-card {
    padding-left: 20px;
    padding-right: 20px;
    
  }
}
@media (max-width: 1280px) {
  .page-catalog__category-card {
    padding-left: 0px;
    padding-right: 0px;
    padding-top: 20px;
  }
}
@media (max-width: 992px) {
  .page-catalog__category-card {
    justify-content: center;
    min-height: 68px;
    padding: 24px 20px;
    height: 68px;
  }
  
  .page-catalog__category-card:hover, .page-catalog__category-card:active .category-card__title {
    outline: none;
    cursor: pointer;
    color: #fff;
  }
  
}
.page-catalog .category-card__title {
  font-size: min(18px, 14px + 4 * (100vw - 430px) / 850);
  font-weight: 500;
  line-height: 155%;
  text-transform: uppercase;
  text-align: center;
}
.page-catalog .category-card__image {
  max-width: 220px;
  height: 129px;
  width: 100%;
}

/* .page-catalog__filters {
display: none;
opacity: 0;
visibility: hidden;
} */

@media (max-width: 992px) {
  .page-catalog__filters {
    /* padding: 0 20px; */
  }
}
.page-catalog__filter-title {
  text-align: center;
  font-size: 14px;
  line-height: 120%;
  font-weight: 500;
  color: #000;
  margin-top: 40px;
}
@media (max-width: 992px) {
  .page-catalog__filter-title {
    text-align: left;
  }
}
.page-catalog__filter-sizes {
  margin-top: 28px;
  display: flex;
  justify-content: center;
  gap: 12px;
}
@media (max-width: 992px) {
  .page-catalog__filter-sizes {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
}
.page-catalog__size-button {
  padding: 12px 32px;
  border-radius: 30px;
  background: #f5f5f5;
  color: #000;
  font-size: 17px;
  font-weight: 400;
  line-height: 155%;
  transition: all 0.3s ease;
  cursor: pointer;
  min-width: 128px;
}
.page-catalog__size-button:hover, .page-catalog__size-button:active, .page-catalog__size-button.page-catalog__size-button--active {
  background: #000;
  color: #ffffff;
}
@media (max-width: 992px) {
  .page-catalog__size-button {
    border-radius: 12px;
    font-size: 15px;
    padding: 12px 20px;
    min-width: 100%;
    white-space: nowrap;
    display: flex;
    justify-content: center;
  }
}

.product-card__content {
  padding: 0;
  padding-bottom: 44px;
  display: flex;
  gap: 50px;
  justify-content: flex-start;
}
@media (max-width: 1440px) {
  .product-card__content {
    gap: 44px;
    padding: 15px;
  }
}
@media (max-width: 992px) {
  .product-card__content {
    flex-direction: column;
    gap: 0;
  }
}
.product-card__gallery {
  max-width: 1000px;
  height: 100%;
  width: 100%;
}
.product-card__info {
  max-width: 600px;
  flex: 0 1 60%;
  @media (max-width: 992px) {
    max-width: 992px;
  }
}
.product-card__info .form-group__btn {
  flex: 1 1 48%;
}
.product-card__title {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 400;
  line-height: 120%;
  max-width: 600px;
  margin: 0 auto;
  text-align: left;
  margin-left: 0;
}
.product-card__price-block {
  margin-top: 16px;
}
.product-card__main-image {
  max-width: 846px;
}
.product-card__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 12px;
  min-height: 846px;
  max-height: 846px;
}

@media (max-width: 1440px) {
  .product-card__image {
    min-height: 606px;
    max-height: 606px;
  }
}

@media (max-width: 1280px) {
  .product-card__image {
    min-height: 526px;
    max-height: 526px;
  }
}

.product-card__price {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 500;
  line-height: 120%;
  margin-top: 16px;
  color: #009930;
  display: flex;
  flex-direction: row-reverse;
  margin: auto;
  justify-content: flex-end;
}
.product-card__price-old, body > main > article > div > div.product-card__info > div.product-card__price-block > span > del > span > bdi {
  text-decoration: line-through;
  color: #b3b3b3;
  margin-left: 8px;
  font-size: 24px;
  font-weight: 500;
  line-height: 120%;
}
.product-card__promo-text {
  font-size: 14px;
  font-weight: 400;
  line-height: 140%;
  color: #009930;
  margin-top: 10px;
  display: block;
}
.product-card__rating {
  margin-top: 18px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.product-card__rating-stars {
  display: flex;
  align-items: center;
  gap: 4px;
}
.product-card__rating-star {
  width: 16px;
}
.product-card__section {
  margin-top: 40px;
  border-radius: 12px;
}
.product-card__section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.product-card__section-title {
  font-size: 14px;
  font-weight: 600;
  line-height: 140%;
  color: #000;
}
.product-card__dimensions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}
@media (max-width: 992px) {
  .product-card__dimensions {
    justify-content: center;
    flex-wrap: wrap;
  }
}
.product-card__dimension-item {
  border-radius: 16px;
  background: #f5f5f5;
  padding: 12px 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.product-card__dimension-value {
  font-size: 24px;
  font-weight: 400;
  line-height: 135%;
  max-width: 144px;
}

.product-card__dimension-label {
  font-size: 14px;
  font-weight: 400;
  line-height: 140%;
}

.product-card__stock {
  display: flex;
  gap: 28px;
  margin-top: 44px;
}
@media (max-width: 992px) {
  .product-card__dimension-item
  {
    padding: 8px 16px; 
    /* flex: 0 1 45%; */
  }
  .product-card__dimension-label {
    font-size: 12px;
  }
  .product-card__dimension-value {
    font-size: 18px;
  }
}




.product-card__stock-items-wrapper {
  display: flex;
  gap: 28px;
}


@media (max-width: 992px) {
  .product-card__stock {
    flex-direction: column;
    gap: 12px;
    margin-top: 24px;
  }
}

@media (max-width: 425px) {
  .product-card__stock-items-wrapper span {
    font-size: 13px;
  }
}
.product-card__stock-item {
  display: flex;
  gap: 8px;
  align-items: center;
  font-weight: 400;
  line-height: 140%;
  font-size: 14px;
  color: #444444;
}
.product-card__stock-item--available {
  color: #009930;
}
.product-card svg {
  width: 24px;
  height: 24px;
}
.product-card__btn {
  width: 100%;
  text-align: center;
  display: block;
  padding: 20px 0;
  font-size: 18px;
  line-height: 155%;
  border-radius: 16px;
  margin-top: 40px;
}
.product-card__btn-note {
  font-size: 14px;
  font-weight: 400;
  line-height: 140%;
  text-align: center;
  margin-top: 12px;
  color: #757575;
}
.product-card__options {
  margin-top: 40px;
  background: #f5f5f5;
  padding: 24px;
  border-radius: 12px;
}
/* .product-card__options-content {
margin-top: 24px;
} */
.product-card__option-title {
  font-size: 14px;
  font-weight: 500;
  line-height: 140%;
}
.product-card__option-variants {
  display: flex;
  gap: 8px;
  width: 100%;
  margin-top: 8px;
}
@media (max-width: 992px) {
  .product-card__option-variants {
    flex-direction: column;
  }
}
.product-card__option-label {
  border-radius: 12px;
  background: #fff;
  padding: 13px;
  gap: 10px;
  display: flex;
  align-items: center;
  flex: 1;
}
.product-card__option-text {
  font-weight: 400;
  font-size: 14px;
  line-height: 140%;
  white-space: nowrap;
}
.product-card__option-group {
  margin-top: 20px;
}
.product-card__option-promo {
  color: #f6890d;
  font-weight: 500;
  font-size: 14px;
  line-height: 140%;
}
.product-card__option-promo del {
  color: #757575;
}
.product-card__specs {
  margin-top: 20px;
  background-color: #f5f5f5;
  padding: 24px;
}
.product-card__spec-item {
  display: flex;
  width: 100%;
  gap: 4px;
}
.product-card__specs-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 32px;
}
.product-card__spec-label {
  font-size: 14px;
  font-weight: 400;
  line-height: 140%;
  color: #757575;
}
.product-card__spec-value {
  font-size: 14px;
  font-weight: 600;
  line-height: 140%;
}
.product-card__thumbnails {
  display: flex;
  max-width: 846px;
  gap: 12px;
  width: 100%;
  margin-top: 12px;
}

.product-card__thumbnail--active img, .swiper-slide-thumb-active img {
  border: 2px solid #000;
}

@media (max-width: 1440px) {
  .product-card__thumbnails {
    justify-content: space-between;
  }
}
.product-card__thumbnail {
  max-width: 120px;
  height: auto;
  @media (max-width: 992px) {
    max-width: 75px;
  }
}
.product-card__thumbnail-image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 12px;
}

.products__grid-wrapper {
  background: #f5f5f5;
  padding: 80px 44px;
}
@media (max-width: 992px) {
  .products__grid-wrapper {
    padding: 56px 15px;
    margin-top: 56px;
  }
}
.products__grid-wrapper .products__grid--catalog {
  padding: 0;
}

.bath-composition__visual {
  max-width: 912px;
  height: auto;
}
.bath-composition__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.bath-composition__container {
  display: flex;
  align-items: center;
  background: #e6e6e6;
  margin-top: 44px;
}
@media (max-width: 992px) {
  .bath-composition__container {
    flex-direction: column;
  }
}
.bath-composition__content {
  padding: 128px 156px;
}
@media (max-width: 1440px) {
  .bath-composition__content {
    padding: 78px 64px;
  }
}
@media (max-width: 1280px) {
  .bath-composition__content {
    padding: 78px 48px;
  }
}
@media (max-width: 992px) {
  .bath-composition__content {
    padding: 56px 15px;
  }
}
.bath-composition__title {
  font-size: min(36px, 28px + 8 * (100vw - 430px) / 850);
  font-weight: 300;
  line-height: 120%;
  margin-bottom: 40px;
}
@media (max-width: 992px) {
  .bath-composition__title {
    text-align: center;
  }
}
.bath-composition__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.bath-composition__item-inner {
  display: flex;
  align-items: center;
  gap: 32px;
}
@media (max-width: 992px) {
  .bath-composition__item-inner {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
  }
}
.bath-composition__item {
  padding: 12px 28px 12px 12px;
  background: #fff;
  border-radius: 12px;
  list-style: none;
}
@media (max-width: 992px) {
  .bath-composition__item {
    padding: 20px;
  }
}
.bath-composition__item-title {
  font-size: 20px;
  font-weight: 400;
  line-height: 120%;
}
.bath-composition__item-image {
  max-width: 108px;
  height: 108px;
  width: 100%;
}
.bath-composition__item-thumb {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 12px;
}
.bath-composition__item-description {
  font-size: 14px;
  font-weight: 400;
  line-height: 140%;
  margin-top: 6px;
}
.bath-composition__item-text {
  max-width: 420px;
}

.faq {
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
  padding: 96px;
}
@media (max-width: 1440px) {
  .faq {
    padding: 112px 64px;
  }
}
@media (max-width: 1280px) {
  .faq {
    display: block;
    padding: 80px 48px;
  }
}
@media (max-width: 992px) {
  .faq {
    display: block;
    padding: 64px 20px;
  }
}

.faq__title {
  font-size: 72px;
  font-weight: 300;
  line-height: 100%;
  color: #000;
}

.faq__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media (max-width: 1280px) {
  .faq__list {
    margin-top: 80px;
  }
}
@media (max-width: 992px) {
  .faq__list {
    margin-top: 40px;
  }
}

.faq__item {
  background-color: #ffffff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  background: #f5f5f5;
  padding: 16px 28px;
}
@media (max-width: 992px) {
  .faq__item {
    padding: 15px;
  }
}

.faq__question {
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  font-size: 16px;
  font-weight: 600;
  color: #1a1a1a;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: background-color 0.3s ease;
  line-height: 150%;
}

.faq__question:hover {
  background-color: #f8f9fa;
}

.faq__icon {
  width: 40px;
  height: 40px;
  position: relative;
  background: rgba(201, 201, 201, 0.1490196078);
  flex-shrink: 0;
  margin-left: 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
}

.faq__item.active .faq__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0;
}

.faq__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
}

.faq__item.active .faq__answer {
  max-height: 200px;
}

.faq__answer-inner {
  font-size: 16px;
  line-height: 1.6;
  color: #444444;
  line-height: 150%;
  font-weight: 400;
  margin-top: 12px;
}

@media (max-width: 768px) {
  .faq {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .faq__title {
    font-size: 36px;
    text-align: center;
  }
  .faq__question {
    padding: 16px 20px;
    font-size: 14px;
  }
}
@media (max-width: 768px) and (max-width: 992px) {
  .faq__question {
    padding: 0;
  }
}
@media (max-width: 768px) {
  .faq__answer-inner {
    padding: 0 20px 16px 20px;
  }
}
.gallery__title--accent {
  color: #009930;
}

.footer__container {
  padding: 40px 0;
  background: #1e1e1e;
}
.footer__text {
  color: #b3b3b3;
  max-width: 515px;
  margin: 0 auto;
  text-align: center;
  font-size: 12px;
  line-height: 150%;
  font-weight: 400;
}
.footer__copy {
  background: #111111;
  color: #b3b3b3;
  text-align: center;
  padding: 20px 0;
}/*# sourceMappingURL=style.css.map */



/* Аккордеон */
.product-card__section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  padding: 15px 0;
  font-weight: 600;
}

.product-card__section-icon {
  transition: transform 0.3s ease;
  display: inline-block;
}

.product-card__section-icon.rotated {
  transform: rotate(180deg);
}

.product-card__options-content,
.product-card__specs-content {
  display: none; /* Скрыто по умолчанию */
  padding: 10px 0;
}

.product-card__options-content.active,
.product-card__specs-content.active {
  display: block;
}

/* Варианты опций */
.product-card__option-variants {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}

/* .product-card__option-label {
display: inline-flex;
align-items: center;
padding: 8px 16px;
border: 2px solid #e0e0e0;
border-radius: 6px;
cursor: pointer;
transition: all 0.2s ease;
background: #fff;
} */

/* .product-card__option-label:hover {
border-color: #009930;
} */

/* .product-card__option-input {
position: absolute;
opacity: 0;
width: 0;
height: 0;
} */

.product-card__option-text {
  font-size: 14px;
  color: #333;
}

/* Акция в опциях */
.product-card__option-promo {
  margin: 10px 0;
  padding: 8px 12px;
  background: #fff3cd;
  border-left: 3px solid #ffc107;
  border-radius: 4px;
  font-size: 13px;
}

.product-card__option-promo-text del {
  color: #999;
  margin-left: 5px;
}





/* ===== КАСТОМНАЯ РАДИОКНОПКА ===== */

/* Скрываем стандартный инпут */
.product-card__option-input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
  padding: 0;
  pointer-events: none;
}

/* Контейнер радиокнопки */
.custom-radio {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  margin-right: 10px;
  flex-shrink: 0;
  cursor: pointer;
  vertical-align: middle;
}

/* SVG иконки — абсолютное позиционирование */
.custom-radio__icon {
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  transition: opacity 0.15s ease, transform 0.15s ease;
  pointer-events: none;
}

/* По умолчанию: показываем пустой круг, скрываем галочку */
.custom-radio__icon--off {
  opacity: 1;
  z-index: 1;
}

.custom-radio__icon--on {
  opacity: 0;
  z-index: 2;
  transform: scale(0.9);
}

/* ===== СОСТОЯНИЕ: ВЫБРАНО (CHECKED) ===== */

/* Скрываем пустой круг, показываем галочку */
.product-card__option-input:checked + .custom-radio__icon--off {
  opacity: 0;
}

.product-card__option-input:checked + .custom-radio__icon--off + .custom-radio__icon--on {
  opacity: 1;
  transform: scale(1);
}

/* ===== HOVER ЭФФЕКТЫ ===== */
.product-card__option-label:hover .custom-radio__icon--off {
  stroke: #0C0C0D;
  stroke-width: 2;
}

/* ===== АКТИВНЫЙ ЛЕЙБЛ ===== */
.product-card__option-label--active .custom-radio__icon--off {
  stroke: #0C0C0D;
  stroke-width: 2;
}

/* ===== ДОСТУПНОСТЬ: Фокус с клавиатуры ===== */
.product-card__option-input:focus-visible + .custom-radio__icon--off {
  outline: 2px solid #0073aa;
  outline-offset: 2px;
  border-radius: 50%;
}

/* Анимация появления галочки */
.custom-radio__icon--on {
  transform: scale(0.8);
}
.product-card__option-input:checked + .custom-radio__icon--off + .custom-radio__icon--on {
  transform: scale(1);
}


body .swiper-pagination {
  position: relative;
}

.product-card__slide.swiper-slide {
  width: 100%!important;
  height: 100%!important;
}

/* === Контейнер сетки === */
#hit-products-grid {
  position: relative;
  min-height: 400px; /* Предотвращает коллапс */
  transition: opacity 0.4s ease, min-height 0.3s ease;
  opacity: 1;
  will-change: opacity, min-height;
}

#hit-products-grid.is-loading {
  opacity: 0.6;
  pointer-events: none;
}

#hit-products-grid.is-loaded {
  opacity: 1;
  pointer-events: auto;
}

/* === Карточка-скелетон === */
.skeleton-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  animation: skeleton-pulse 1.4s ease-in-out infinite;
  transform: translateZ(0); /* Включает аппаратное ускорение */
}

@keyframes skeleton-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

/* === Элементы скелетона === */
.skeleton {
  background: linear-gradient(
  90deg,
  #f0f0f0 25%,
  #e0e0e0 50%,
  #f0f0f0 75%
  );
  background-size: 200% 100%;
  border-radius: 6px;
  animation: skeleton-shimmer 1.5s ease-in-out infinite;
  will-change: background-position;
}

@keyframes skeleton-shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* Размеры элементов */
.skeleton__image {
  width: 100%;
  padding-top: 100%; /* Квадратное изображение */
  border-radius: 8px 8px 0 0;
}

.skeleton__badge {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 40px;
  height: 20px;
  border-radius: 4px;
}

.skeleton__title {
  height: 14px;
  margin: 10px 12px;
  border-radius: 4px;
}

.skeleton__title--line1 { width: 90%; }
.skeleton__title--line2 { width: 70%; }

.skeleton__price-row {
  display: flex;
  gap: 10px;
  margin: 8px 12px;
}

.skeleton__price {
  height: 18px;
  width: 60px;
  background: #d0d0d0;
}

.skeleton__price-old {
  height: 14px;
  width: 40px;
  opacity: 0.6;
}

.skeleton__rating {
  height: 12px;
  width: 80px;
  margin: 8px 12px;
}

.skeleton__button {
  height: 36px;
  margin: 12px;
  border-radius: 8px;
  background: #e8e8e8;
}

/* === Плавное появление контента === */
.product-card:not(.skeleton-card) {
  animation: fade-in-up 0.5s ease forwards;
  opacity: 0;
  transform: translateY(12px);
}

@keyframes fade-in-up {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Задержка для stagger-анимации карточек */
.product-card:not(.skeleton-card):nth-child(1) { animation-delay: 0.05s; }
.product-card:not(.skeleton-card):nth-child(2) { animation-delay: 0.1s; }
.product-card:not(.skeleton-card):nth-child(3) { animation-delay: 0.15s; }
.product-card:not(.skeleton-card):nth-child(4) { animation-delay: 0.2s; }
/* и так далее... */

/* === Сообщение об ошибке / нет результатов === */
.grid-message {
  text-align: center;
  padding: 40px 20px;
  color: #666;
  animation: fade-in 0.3s ease;
}

@keyframes fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}




/* Состояния загрузки */
#hit-products-grid.is-loading {
  pointer-events: none;
}

#hit-products-grid.is-loaded .product-card {
  animation: fadeIn 0.4s ease forwards;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Стили скелетона */
.skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 4px;
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}



@keyframes loadingDot {
  0%, 100% { width: 20px; opacity: 0.3; }
  50% { width: 40px; opacity: 1; }
}

.form-message {
  padding: 15px 20px;
  margin: 20px 0;
  border-radius: 8px;
  font-weight: 500;
}

.form-message--success {
  background: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}

body .fancybox__backdrop {
  background: rgb(0 0 0 / 70%);
}

.form-modal {
  max-width: 540px!important;
  width: 100%;
  padding: 40px 48px 48px 48px!important;
  border-radius: 16px!important;
  background: #fff;
}

body .fancybox__content>.f-button.is-close-btn {
  top: 20px;
  right: 20px;
  opacity: .75;
  background: rgba(255, 0, 0, 0.544);
  border-radius: 50%;
}

body .fancybox__content > .f-button.is-close-btn:not(.form-modal .f-button.is-close-btn) {
  right: 20px!important;
  top: 20px!important;
  background: #F4F4F4;
  color: #000;
  border-radius: 50%;
  padding: 8px;
}

.form-modal__title {
  font-weight: 500;
  font-size: 28px;
  line-height: 120%;
  text-align: center;
  color: #000000;
  margin-bottom: 32px;
}

.form-modal__inputs {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.form-modal__inputs .form-modal__input {
  background: #f5f5f5;
  border-radius: 12px;
  padding: 16px 20px;
  font-weight: 400;
  font-size: 14px;
  line-height: 140%;
  color: #444444;
  border: none;
  outline: none;
  transition: background 0.3s ease;
}



/* Сообщения в модальном окне */
#order-message {
  transition: opacity 0.2s ease;
}
.order-message--success {
  background: #d4edda !important;
  color: #155724 !important;
  border: 1px solid #c3e6cb !important;
}
.order-message--error {
  background: #f8d7da !important;
  color: #721c24 !important;
  border: 1px solid #f5c6cb !important;
}
.order-message--loading {
  background: #fff3cd !important;
  color: #856404 !important;
  border: 1px solid #ffeaa7 !important;
}

/* Сообщение для формы фото */
.photo-message {
  transition: opacity 0.2s ease;
}

.header__burger {
  display: none;
}


@media (max-width: 992px) {
  /* .container {
  max-width: 720px;
  padding: 0 20px;
  } */
  
  
  .header__burger {
    display: flex;
    align-items: center;
    -moz-column-gap: 16px;
    column-gap: 16px;
    cursor: pointer;
  }
  
  .burger {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 30px;
    height: 21px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    position: relative;
    z-index: 1000;
  }
  
  .burger__line {
    display: block;
    height: 3px;
    width: 100%;
    background-color: #122550;
    border-radius: 3px;
    transition: all 0.3s ease;
  }
  
  .burger--active .burger__line:nth-child(1) {
    transform: translateY(9px) rotate(45deg);
    background-color: #fae95b;
  }
  
  .burger--active .burger__line:nth-child(2) {
    opacity: 0;
  }
  
  .burger--active .burger__line:nth-child(3) {
    transform: translateY(-9px) rotate(-45deg);
    background-color: #fae95b;
  }
  
  .menu {
    position: absolute;
    width: 100%;
    min-height: 383px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px); /* Для Safari */
    background: #3c3b3be3;
    transition: transform 0.4s ease;
    z-index: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px;
    top: 83px;
    left: -80px;
    overflow: hidden;
    transform: translateX(-100%);
    flex-direction: column;
  }
  .menu__list {
    list-style: none;
    margin: 0;
    padding: 0;
    text-align: center;
    width: 100%;
  }
  
  .menu--active .menu__item:nth-child(1)
  {
    transition-delay: 0.1s;
  }
  
  .menu--active .menu-item a {
    opacity: 1;
    transform: translateY(0);
    color: #fff!important;
    font-weight: 400;
  }
  
  
  .menu__item {
    margin-bottom: 16px;
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.4s ease;
    background-color: #fdc533;
  }
  
  .menu {
    top: 0;
    left: 0;
    height: 100vh;
  }
  
  .menu--active {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    top: 0;
    left: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 100%;
    opacity: 1;
    transition: transform 0.4s ease;
  }
  
  .menu__link {
    text-decoration: none;
    color: #fdc533;
    font-size: 20px;
    font-weight: 700;
    transition: color 0.3s ease;
    padding: 12px 20px;
    display: block;
    width: 231px;
    height: 51px;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    transition: all 0.3s ease;
    width: 100%;
    border: 1px solid #fdc533;
    border-radius: 5px;
  }
}


#wpgs-gallery img {
  width: 100% !important;
  object-fit: cover;
}

#wpgs-gallery.wcgs-woocommerce-product-gallery.vertical {
  max-width: 1000px !important;
  gap: 50px;
  width: 100%;
}

.wcgs-carousel .spswiper-slide, .wcgs-carousel .wcgs-slider-image {
  width: 100%!important;
  height: 100%!important;
}

#wpgs-gallery.vertical.wcgs-woocommerce-product-gallery .wcgs-carousel {
  width: calc(100% - 15%)!important;
}

body #wpgs-gallery .wcgs-thumb.spswiper-slide img {
  aspect-ratio: 1/1;
}

body #wpgs-gallery .wcgs-carousel .wcgs-spswiper-arrow, body #wpgs-gallery .wcgs-carousel .wcgs-spswiper-arrow  {
  background: #F4F4F4;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  position: absolute;
}
@media (max-width: 992px) {
  body .wcgs-thumb.spswiper-slide.spswiper-slide-visible {
    margin-bottom: 5px!important;
    
  }
}


body #wpgs-gallery .wcgs-carousel .wcgs-spswiper-arrow:before, #wpgs-gallery .wcgs-carousel .wcgs-spswiper-arrow:before {
  color: #000;
}

body #wpgs-gallery .wcgs-carousel .wcgs-spswiper-arrow:hover::before, #wpgs-gallery .wcgs-carousel .wcgs-spswiper-arrow:hover::before {
  color: #fff;
}

body .wcgs-carousel .wcgs-spswiper-arrow.wcgs-spswiper-button-next {
  right: 50px;
}

body .wcgs-carousel .wcgs-spswiper-arrow.wcgs-spswiper-button-prev {
  left: 50px;
}

.wcgs-slider-image img {
  width: 100%; /* Ширина на весь контейнер (или задайте фиксированную, например 300px) */
  aspect-ratio: 1 / 1; /* Принудительно делает блок квадратным */
  object-fit: cover; /* Обрезает лишнее, чтобы фото заполнило квадрат без искажений */
  object-position: center; /* Центрирует изображение (можно менять на top, bottom и т.д.) */
  
  /* Удаляем старые ограничения высоты, чтобы они не мешали */
  height: auto; 
  max-height: none; 
  min-height: auto;
}

body #wpgs-gallery .gallery-navigation-carousel-wrapper {
  margin-top: 0!important;
}
/* === WooGallery Mobile Full-Screen === */
@media (max-width: 992px) {
  body #wpgs-gallery .gallery-navigation-carousel-wrapper {
    margin-left: 0;
  }
  
  body #wpgs-gallery.wcgs-woocommerce-product-gallery.vertical {
    gap: 0;
  }
  
  /* Контейнер галереи на всю ширину экрана */
  .wcgs-woocommerce-product-gallery,
  #wpgs-gallery {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding: 0 10px !important;
    box-sizing: border-box;
  }
  /* .spswiper {
  overflow: visible!important;
  } */
  
  
  #wpgs-gallery.vertical.wcgs-woocommerce-product-gallery .wcgs-carousel {
    width: calc(100% - 0%) !important;
    overflow-x: hidden !important;
  }
  
  #wpgs-gallery.wcgs-woocommerce-product-gallery.vertical {
    flex-direction: column !important;
  }
  
  
  /* Миниатюры: горизонтальная строка */
  .gallery-navigation-carousel.vertical,
  .gallery-navigation-carousel-wrapper.vertical {
    flex-direction: column !important;
    max-height: none !important;
  }
  
  .gallery-navigation-carousel .spswiper-wrapper {
    flex-direction: row !important;
    justify-content: flex-start !important;
    padding: 10px 0 !important;
  }
  
  .wcgs-thumb {
    width: 65px !important;
    height: 65px !important;
    margin: 0 4px !important;
    margin-bottom: 0 !important;
    flex-shrink: 0;
  }
  
  .wcgs-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    border-radius: 6px;
    border: 2px solid transparent;
    transition: border-color 0.2s;
  }
  
  /* Активная миниатюра */
  .wcgs-thumb.spswiper-slide-thumb-active img {
    border-color: #0073aa;
  }
  
  /* Скрываем стрелки — на мобильных удобнее свайпать */
  .wcgs-spswiper-button-next,
  .wcgs-spswiper-button-prev {
    display: none !important;
  }
  
  /* Убираем лишние отступы темы */
  .entry-content .wcgs-woocommerce-product-gallery,
  .woocommerce-product-gallery {
    padding: 0 !important;
    margin: 0 !important;
  }
  
  
  .wcgs-thumb {
    width: 55px !important;
    height: 55px !important;
  }
}

.product-card__price-block del, .product-card__price-block ins {
  text-decoration: none;
}


/* ========== AOS: Premium-настройки ========== */
[data-aos] {
  will-change: transform, opacity;
  transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1);
}

/* Начальное состояние для fade-up */
[data-aos^="fade-up"] {
  transform: translate3d(0, 40px, 0);
  opacity: 0;
}

[data-aos^="fade-up"].aos-animate {
  transform: translate3d(0, 0, 0);
  opacity: 1;
}

/* Для zoom-in */
[data-aos="zoom-in"] {
  transform: scale(0.95);
  opacity: 0;
}
[data-aos="zoom-in"].aos-animate {
  transform: scale(1);
  opacity: 1;
}

/* Для fade-left / fade-right */
[data-aos^="fade-left"] {
  transform: translate3d(30px, 0, 0);
  opacity: 0;
}
[data-aos^="fade-left"].aos-animate {
  transform: translate3d(0, 0, 0);
  opacity: 1;
}
[data-aos^="fade-right"] {
  transform: translate3d(-30px, 0, 0);
  opacity: 0;
}
[data-aos^="fade-right"].aos-animate {
  transform: translate3d(0, 0, 0);
  opacity: 1;
}

/* Accessibility: отключение анимаций при prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  [data-aos] {
    transition: none !important;
    animation: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}

/* Плавное появление карточек при наведении (дополнительный эффект) */
.advantages__card,
.catalog__card {
  transition: transform 0.4s cubic-bezier(0.23, 1, 0.32, 1), 
  box-shadow 0.4s ease;
}
.advantages__card:hover,
.catalog__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
}

.fancybox__content {
  border-radius: 12px;
}

@media (max-width: 992px) {
  .fancybox__slide.has-iframe, .fancybox__slide.has-video, .fancybox__slide.has-html5video, .fancybox__content {
    padding: 0;
  }
  #wpgs-gallery.vertical .gallery-navigation-carousel-wrapper:not(.wcgs-hidden) {
    width: 100%;
  }
  /* Отключаем перетаскивание мини-галереи на мобильных */
  .spswiper-wrapper {
    touch-action: pan-y !important;
    -webkit-user-select: none !important;
    user-select: none !important;
    -webkit-touch-callout: none !important;
  }
  
  /* Разрешаем клики только по самим миниатюрам */
  .spswiper-wrapper .wcgs-thumb {
    pointer-events: auto;
    cursor: pointer;
  }
  
  /* Для мобильных устройств */
  @media (hover: none) and (pointer: coarse) {
    .spswiper-wrapper {
      overscroll-behavior: contain !important;
    }
  }
  
}

/* === Контейнер галереи справа=== */
@media (min-width: 1024px) {
  .wcgs-woocommerce-product-gallery .gallery-navigation-carousel-wrapper .spswiper-wrapper {
    flex-direction: column;
  }
  .eterio-gallery-wrapper {
    display: flex;
    gap: 50px; /* 🔥 отступ между колонками */
    align-items: flex-start;
  }
  
  .eterio-gallery-wrapper__main {
    flex: 1;
    min-width: 0;
  }
  
  /* === Контейнер галереи === */
  .wcgs-woocommerce-product-gallery {
    display: flex !important;
    flex-direction: row-reverse !important; /* миниатюры справа */
    gap: 50px !important; /* отступ между колонками */
    align-items: flex-start;
  }
  
  /* === Мини-галерея (справа) === */
  .wcgs-woocommerce-product-gallery .gallery-navigation-carousel-wrapper {
    order: 1 !important;
    width: 150px !important;        /* 🔥 ширина миниатюр */
    max-height: 850px !important;   /* под 5 шт × 150px + отступы */
    overflow-y: auto !important;
    flex-shrink: 0 !important;
  }
  
  /* Миниатюры 150×150 */
  .wcgs-woocommerce-product-gallery .wcgs-thumb,
  .wcgs-woocommerce-product-gallery .wcgs-thumb img {
    width: 150px !important;
    height: 150px !important;       /* 🔥 высота миниатюр */
    object-fit: cover !important;
    flex-shrink: 0 !important;
    border-radius: 4px;
  }
  
  /* Убираем лишние отступы внутри мини-галереи */
  .wcgs-woocommerce-product-gallery .gallery-navigation-carousel-wrapper .spswiper-wrapper {
    gap: 10px !important; /* расстояние между миниатюрами */
  }
  
  /* === Основное изображение 800×800 === */
  .wcgs-woocommerce-product-gallery .wcgs-carousel {
    order: 2 !important;
    flex: 1 0 auto !important;     /* 🔥 фиксированная ширина */
    max-width: 800px !important;
  }
  
  .wcgs-woocommerce-product-gallery .wcgs-carousel .wcgs-slider-image,
  .wcgs-woocommerce-product-gallery .wcgs-carousel .wcgs-slider-image img {
    width: 100% !important;        /* 🔥 ширина основного */
    height: auto !important;       /* 🔥 высота основного */
    object-fit: cover !important;
    max-width: 800px !important;
  }
}

/* === Адаптив (мобильные) === */
/* @media (max-width: 1100px) {
.wcgs-woocommerce-product-gallery {
flex-direction: column !important;
gap: 20px !important;
}
.wcgs-woocommerce-product-gallery .gallery-navigation-carousel-wrapper {
width: 100% !important;
max-height: none !important;
overflow-x: auto !important;
overflow-y: hidden !important;
order: 3 !important;
}
.wcgs-woocommerce-product-gallery .wcgs-thumb,
.wcgs-woocommerce-product-gallery .wcgs-thumb img {
width: 100px !important;
height: 100px !important;
}
.wcgs-woocommerce-product-gallery .wcgs-carousel,
.wcgs-woocommerce-product-gallery .wcgs-carousel .wcgs-slider-image img {
width: 100% !important;
height: auto !important;
max-width: 100% !important;
}
} */