/* === Visus Filter: кнопки фильтрации === */
.visus-filter-btn .tn-atom {
  background-color: transparent !important;
  transition: background-color 0.2s ease-in-out;
}
.visus-filter-btn .tn-atom__button-text {
  color: #12182f !important;
  transition: color 0.2s ease-in-out;
}
.visus-filter-btn .tn-atom__button-border {
  border-color: #1D4ED8 !important;
}
.visus-filter-btn.is-active .tn-atom,
.visus-filter-btn:hover .tn-atom {
  background-color: #1D4ED8 !important;
}
.visus-filter-btn.is-active .tn-atom__button-text,
.visus-filter-btn:hover .tn-atom__button-text {
  color: #ffffff !important;
}

/* === Visus: стиль карточек каталога === */
.t776__col.js-product .t776__content {
  background-color: #F4F1EC !important;
  border-radius: 24px !important;
  border: 1px solid #FFFFFF !important;
  box-shadow: 0 2px 16px 0 rgba(29, 78, 216, 0.16) !important;
  transition: box-shadow 0.25s ease-in-out !important;
  overflow: hidden;
}

.t776__col.js-product:hover .t776__content {
  box-shadow: 0 2px 16px 0 rgba(29, 78, 216, 0.60) !important;
}
/* === Visus: отступы текста в карточке === */
.t776__col.js-product .t776__textwrapper {
  padding: 0 16px !important;
}

.t776__col.js-product .t776__btn-wrapper {
  padding: 0 16px 16px !important;
}


/* PREMIUM SCROLL ANIMATION: текст и карточки */

/* Текст */

.vl-text-anim {
  opacity: 0;
  transform: translateY(18px);
  filter: blur(5px);
  transition:
    opacity 1.45s cubic-bezier(0.22, 1, 0.36, 1),
    transform 1.45s cubic-bezier(0.22, 1, 0.36, 1),
    filter 1.45s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform, filter;
}

.vl-text-anim.vl-visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}


/* Карточки с синей тенью */

.vl-card-anim {
  opacity: 0;
  transform: translateY(22px);
  filter: blur(5px);

  border-radius: 24px !important;
  overflow: hidden !important;

  box-shadow: 0 2px 16px rgba(29, 78, 216, 0.16);

  transition:
    opacity 1.45s cubic-bezier(0.22, 1, 0.36, 1),
    transform 1.45s cubic-bezier(0.22, 1, 0.36, 1),
    filter 1.45s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.6s ease;
  will-change: opacity, transform, filter, box-shadow;
}

.vl-card-anim.vl-visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.vl-card-anim:hover {
  box-shadow: 0 2px 16px rgba(29, 78, 216, 0.6);
}


/* Карточки только с анимацией, без hover-тени */

.vl-card-anim-2 {
  opacity: 0;
  transform: translateY(22px);
  filter: blur(5px);

  border-radius: 24px !important;

  transition:
    opacity 1.45s cubic-bezier(0.22, 1, 0.36, 1),
    transform 1.45s cubic-bezier(0.22, 1, 0.36, 1),
    filter 1.45s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform, filter;
}

.vl-card-anim-2.vl-visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}


/* На телефонах hover не усиливаем */

@media (hover: none) {
  .vl-card-anim:hover {
    box-shadow: 0 2px 16px rgba(29, 78, 216, 0.16);
  }
}


/* Если у пользователя отключены анимации */

@media (prefers-reduced-motion: reduce) {
  .vl-text-anim,
  .vl-card-anim,
  .vl-card-anim-2 {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: box-shadow 0.6s ease !important;
  }
}