/* ────────────────────────────────────────────────
 * Best/Featured items
 * Source: extracted from index.css lines 3561–3713
 * ──────────────────────────────────────────────── */


/* как у .catalogImage img — фикс. высота, ширина auto, не тянет глобальный img{width:100%} */
.partnersItem img {
  width: auto !important;
  max-width: 100%;
  height: 88px;
  object-fit: contain;
  display: block;
  filter: grayscale(1) brightness(0.7) contrast(1.2);
  opacity: 0.6;
  transition: transform 0.3s ease, opacity 0.3s ease, color 0.3s ease, background-color 0.3s ease;
}

.partnersItem:hover img {
  filter: grayscale(0) brightness(1) contrast(1);
  opacity: 1;
}

.partnersItem:hover {
  border-color: var(--color-accent);
  transform: translateY(-5px);
  background: var(--color-bg-card-dark);
}

.bestBox {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  gap: 32px;
}

.bestItem {
  position: relative;
  overflow: hidden;
  flex: 0 0 auto;
  width: calc(33.333% - 22px);
  background: var(--color-bg-card);
  border-radius: 0;
  padding: 64px 48px;
  border: 1px solid var(--color-border);
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), color 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), background-color 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

/* Scroll-triggered: fade-in + slide-up при появлении в viewport */
.bestItem[data-scroll-animate] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), border-color 0.4s ease, box-shadow 0.4s ease;
}

.bestItem[data-scroll-animate].best-item-visible {
  opacity: 1;
  transform: translateY(0);
}

.bestItem[data-scroll-animate][data-animate-delay="1"] { transition-delay: 0.1s; }
.bestItem[data-scroll-animate][data-animate-delay="2"] { transition-delay: 0.2s; }

@media (prefers-reduced-motion: reduce) {
  .bestItem[data-scroll-animate] {
    opacity: 1;
    transform: none;
  }
}

.bestItem::before {
  display: none; /* Pattern disabled - too distracting */
}

.bestItem:hover::before {
  display: none;
}

.bestItem:hover {
  border-color: var(--color-accent);
  transform: translateY(-10px);
  box-shadow: none;
}

.bestItem:hover .bestInfo {
  transform: translateY(-10px);
}

.bestItem:hover .bestTitle {
  color: var(--color-accent-text);
}

.bestItem:hover .bestImage {
  transform: translate3d(12px, 0px, 0.3em) scale(1.2);
}

.bestItem:hover .bestImage img {
  transform: translate3d(12px, 0px, 0.5em) scale(1.2);
}

.bestItem:hover button {
  opacity: 1;
  visibility: visible;
  /* bottom: 80px; */
}

.bestTitle {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 100%;
  margin-bottom: 12px;
  transition: transform 0.6s ease, opacity 0.6s ease, color 0.6s ease, background-color 0.6s ease;
}

.bestText {
  font-weight: 400;
  font-size: 1rem;
  line-height: 150%;
  max-width: 70%;
  margin-bottom: 12px;
}

.bestInfo {
  position: relative;
  z-index: 1;
  max-width: calc(100% - 200px);
  transition: transform 0.6s ease, opacity 0.6s ease, color 0.6s ease, background-color 0.6s ease;
}

.best button {
  /* opacity: 0;
	visibility: hidden; */
  transition: transform 0.6s ease, opacity 0.6s ease, color 0.6s ease, background-color 0.6s ease;
  transform: translateY(0);
  position: absolute;
  bottom: var(--spacing-2xl);
}

.bestImage {
  overflow: hidden;
  transform-style: preserve-3d;
  backface-visibility: hidden;
  transition: transform 0.8s ease, opacity 0.8s ease, color 0.8s ease, background-color 0.8s ease;
  position: absolute;
  right: -156px;
  bottom: -156px;
  border-radius: 0;
}

.bestImage img {
  transition: transform 0.8s ease, opacity 0.8s ease, color 0.8s ease, background-color 0.8s ease;
  width: 315px;
  height: 315px;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 0;
}

