.image-gallery {
  width: 100%;
  object-fit: cover;
  margin: 0 auto;
  font-family: sans-serif;
  user-select: none;
  margin-bottom: var(--margin-bottom-element);
}

.gallery-main {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.gallery-main-viewport {
  width: 100%;
  overflow: hidden;
  border-radius: var(--normal-border-radius);
}

.gallery-main-track {
  display: flex;
  transform: translateX(var(--gallery-offset, 0%));
  transition: transform 0.4s ease-in-out;
}

.gallery-main-img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  flex-shrink: 0;
}

.gallery-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.gallery-arrow.left {
  left: 10px;
}

.gallery-arrow.right {
  right: 10px;
}

.gallery-thumbs-container {
  display: flex;
  align-items: center;
  gap: 8px;
  background-color: var(--element-bkg);
  border-radius: var(--normal-border-radius);
  box-shadow: var(--shadow-element);
}

.gallery-thumbs-wrapper {
  flex: 1;
  overflow-x: auto;
  white-space: nowrap;
  scroll-behavior: smooth;
  overflow-y: hidden;
  scrollbar-width: none;
}

.gallery-thumbs {
  display: inline-flex;
  gap: 0px;
}

.thumbs-arrow {
  margin: 10px;
}


.gallery-thumb {
  width: 90px;
  height: 60px;
  object-fit: cover;
  cursor: pointer;
  opacity: 0.6;
  border: 2px solid transparent;
  transition: opacity 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
  border-radius: var(--small-border-radius);
  transform: translateY(2px);
}

.gallery-thumb:hover {
  opacity: 0.85;
  animation: pulse 0.4s ease-in-out;
}

.gallery-thumb.active {
  opacity: 1;
  border-color: var(--lr-blue);
}

/* ── Comparison slide inside gallery ───────────────────────────────────── */

.gallery-comparison-slide {
  margin-bottom: 0;
}

/* ── Comparison thumbnail ───────────────────────────────────────────────── */

.gallery-thumb-comparison {
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}

.gallery-thumb-comparison-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
}

.gallery-thumb-comparison-before {
  clip-path: inset(0 50% 0 0);
}

.gallery-thumb-comparison-after {
  clip-path: inset(0 0 0 50%);
}