/* ==============================
   СЛАЙДЕР ПОХОЖИХ ПУБЛИКАЦИЙ
   ============================== */

.cross-carousel-wrap {
  position: relative;
  overflow: hidden;
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

/* Viewport */
.cs-viewport {
  overflow: hidden;
  width: 100%;
  position: relative;
}

/* Трек */
.cs-track {
  display: flex;
  gap: .6rem;
  transition: transform .42s cubic-bezier(.4, 0, .2, 1);
  will-change: transform;
  touch-action: pan-y pinch-zoom;
}

/* ── Стрелки — внутри viewport поверх карточек ── */
.cs-nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  outline: none;
  transition: background .2s, transform .2s;
  box-shadow: none;
}
.cs-nav-btn:hover:not(:disabled) {
  background: rgba(0,0,0,.65);
  transform: translateY(-50%) scale(1.07);
}
.cs-nav-btn:disabled {
  opacity: .3;
  cursor: default;
}
.cs-nav-btn--prev { left: .55rem; }
.cs-nav-btn--next { right: .55rem; }

/* Карточка */
.cross-card--rel {
  flex: 0 0 var(--cs-card-w, 20%);
  aspect-ratio: 1 / 1;
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid var(--border-light);
  box-shadow: none;
  background: #1a2744;
  display: block;
  text-decoration: none;
  transition: transform .32s cubic-bezier(.25,.46,.45,.94), opacity .32s ease;
  cursor: pointer;
}
.cross-card--rel:hover { transform: scale(1.025); opacity: .92; }

/* Изображение */
.cross-card--rel .cross-image {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  margin: 0;
  border-radius: 0;
  overflow: hidden;
}
.cross-card--rel .cross-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 0;
  box-shadow: none;
  filter: none;
  transition: transform .5s cubic-bezier(.25,.46,.45,.94);
  transform: scale(1.01);
}
.cross-card--rel:hover .cross-image img { transform: scale(1.07); }

/* Градиент снизу */
.cross-card--rel .cross-image::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 55%;
  background: linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,.2) 55%, transparent 100%);
  pointer-events: none;
}

/* Заголовок */
.cross-card--rel .cross-title-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: .45rem .5rem .4rem;
  z-index: 2;
  pointer-events: none;
}
.cross-card--rel .cross-title-overlay span {
  display: -webkit-box;
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  line-height: 1.25;
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* Бейдж */
.cross-card--rel .cs-badge {
  position: absolute;
  top: .45rem;
  right: .45rem;
  z-index: 3;
  background: rgba(0,0,0,.52);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  color: #fff;
  font-size: .62rem;
  font-weight: 700;
  padding: .18rem .5rem;
  border-radius: 2rem;
  letter-spacing: .01em;
  white-space: nowrap;
  pointer-events: none;
}

.cross-card--rel .cross-content { display: none !important; }

/* ── Навигация снизу — как на скрине ── */
.cs-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .3rem;
  margin-top: .75rem;
}
.cs-dot {
  width: 28px;
  height: 5px;
  border-radius: 3px;
  background: #d1d5db;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background .25s, width .25s;
  outline: none;
  display: block;
}
.cs-dot.active {
  background: #374151;
  width: 36px;
}
[data-theme="dark"] .cs-dot { background: #334155; }
[data-theme="dark"] .cs-dot.active { background: #cbd5e1; }

/* ── Адаптив ── */
@media (max-width: 860px) {
  .cs-nav-btn { width: 32px; height: 32px; }
}
@media (max-width: 540px) {
  .cs-nav-btn { width: 28px; height: 28px; }
  .cs-nav-btn svg { width: 10px; height: 10px; }
  .cross-card--rel { border-radius: .75rem; }
  .cross-card--rel .cross-title-overlay span { font-size: .66rem; }
  .cross-card--rel .cs-badge { font-size: .58rem; }
  .cs-dot { width: 22px; }
  .cs-dot.active { width: 30px; }
}
