/* -------- КОЛЛАЖ / ГАЛЕРЕЯ -------- */
.gallery{
  width: 100%;
  margin: 0 auto;
  padding-inline: clamp(12px, 4vw, 32px);
  overflow: hidden;
}

/* Ряд: горизонтальный скролл + snap */
.gallery-row{
  display: flex;
  gap: clamp(12px, 2.6vw, 24px);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;  /* вместо mandatory */
  overflow-anchor: none;
  padding-block: 8px;
  touch-action: pan-x pan-y;
  overscroll-behavior-inline: contain;

  /* Базовая стилизация скроллбара (Firefox) — тонкий и полупрозрачный */
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.28) transparent;

  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%);
}

/* на время анимации выезжания карточек снап выключаем */
.gallery-row.no-snap{
  scroll-snap-type: none;
}

.gallery-row.is-dragging{ cursor: grabbing; user-select: none; }

/* WebKit-скроллбар (Chrome/Safari/Edge) — тонкая «капсула» */
.gallery-row::-webkit-scrollbar{
  height: 6px;            /* тонкий, низкий */
}
.gallery-row::-webkit-scrollbar-track{
  background: transparent;
}
.gallery-row::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.28);
  border-radius: 3px;
  border: 2px solid transparent;      /* чтобы казался ещё тоньше */
  background-clip: padding-box;
  transition: background-color .2s ease;
}
.gallery-row:hover::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.45);  /* подсветка при наведении */
}

.gallery-row::-webkit-scrollbar-button {
  display: none; /* полностью убираем стрелки */
}

/* На тач-устройствах — скрываем скроллбар полностью */
@media (hover: none) and (pointer: coarse){
  .gallery-row{
    scrollbar-width: none;
  }
  .gallery-row::-webkit-scrollbar{
    display: none;
  }
}

/* Карточки */
.gallery-item{
  flex: 0 0 clamp(160px, 22vw, 280px);
  scroll-snap-align: start;
}
.gallery-item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 16px;
}

/* Подпись */
.gallery-caption{ text-align: center; margin: 10px 0 6px; }

/* --- АНИМАЦИЯ ЗАЕЗДА РЯДОВ --- */
.gallery-row--top,
.gallery-row--bottom{
  opacity: 0;
  transform: translateX(var(--shift, 0));
  transition: transform 2.8s cubic-bezier(.2,.7,.2,1), opacity 2.8s;
  will-change: transform, opacity;
}
.gallery-row--top    { --shift: 260px; }   /* сверху — въезд справа */
.gallery-row--bottom { --shift: -260px; }  /* снизу  — въезд слева  */

.is-inview .gallery-row--top,
.is-inview .gallery-row--bottom{
  opacity: 1;
  transform: translateX(0);
}

/* Лёгкая «лесенка» по карточкам */
.gallery-row .gallery-item{
  transform: translateX(var(--item-shift, 0));
  opacity: 0;
  transition: transform .6s, opacity .6s;
}
.gallery-row--top    .gallery-item{ --item-shift: 224px; }
.gallery-row--bottom .gallery-item{ --item-shift: -224px; }

.is-inview .gallery-row .gallery-item{
  transform: translateX(0);
  opacity: 1;
}
.gallery-row .gallery-item:nth-child(1){ transition-delay: .02s; }
.gallery-row .gallery-item:nth-child(2){ transition-delay: .08s; }
.gallery-row .gallery-item:nth-child(3){ transition-delay: .14s; }
.gallery-row .gallery-item:nth-child(4){ transition-delay: .20s; }
.gallery-row .gallery-item:nth-child(5){ transition-delay: .26s; }
.gallery-row .gallery-item:nth-child(6){ transition-delay: .32s; }

/* -------- АДАПТИВ -------- */
@media (max-width: 991px){
  .gallery-item{ flex-basis: clamp(160px, 36vw, 220px); }
}
@media (max-width: 767px){
  .gallery-item{ flex-basis: clamp(150px, 58vw, 190px); }
}
@media (max-width: 479px){
  .gallery-item{ flex-basis: clamp(140px, 78vw, 180px); }
}

/* ===== HINT ARROWS (touch only) ===== */
@media (hover: none) and (pointer: coarse) {
  /* родитель ряда уже есть — позиционируем поверх него */
  .gallery-row {
    position: relative;           /* для позиционирования псевдоэлементов */
  }

  .gallery-row::before,
  .gallery-row::after {
    content: "";
    position: absolute;
    top: 50%;
    translate: 0 -50%;
    width: 0; height: 0;          /* рисуем треугольники границами */
    pointer-events: none;
    opacity: .45;
    transition: opacity .25s ease;
    z-index: 2;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,.25));
  }

  /* левая стрелочка */
  .gallery-row::before {
    left: 10px;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-right: 12px solid rgba(255,255,255,.85);
  }

  /* правая стрелочка */
  .gallery-row::after {
    right: 10px;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 12px solid rgba(255,255,255,.85);
  }

  /* глушим стрелку у соответствующего края */
  .gallery-row.at-start::before { opacity: 0; }
  .gallery-row.at-end::after   { opacity: 0; }

  /* полностью скрыть подсказки после первого свайпа/тапа */
  .gallery-row.hint-hidden::before,
  .gallery-row.hint-hidden::after { opacity: 0; }
}

.gallery-caption {
  /* text-align: center;
  width: 100%; */
  font-family: "Playfair Display", serif;
  font-weight: 600;
  font-style: italic;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-align: center;
  color: rgba(255,255,255,.72);
  margin: clamp(8px, 2.2vw, 20px) 0;
  line-height: 1.35;

  /* адаптивный размер: от 0.82rem до 1rem */
  font-size: clamp(.82rem, .45vw + .76rem, 1rem);
}

/* тонкая декоративная линия перед текстом */
.gallery-caption::before {
  content: "";
  display: block;
  width: 256px;
  height: 2px;
  margin: 0 auto 10px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
  border-radius: 2px;
  opacity: .9;
}

/* -------- Появление при скролле -------- */
.reveal-up {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 2.55s ease, transform 2.55s ease;
  will-change: opacity, transform;
}
.reveal-up.is-inview {
  opacity: 1;
  transform: translateY(0);
}

/* Точное попадание под твои брейкпоинты */
@media (max-width: 991px){
  .gallery-caption{ font-size: .95rem; }
}
@media (max-width: 767px){
  .gallery-caption{ font-size: .88rem; }
}
@media (max-width: 479px){
  .gallery-caption{ font-size: .84rem; }
}