/* ========================================
   SLIDER THUMB — BANNER
   ======================================== */
.vector-slide-thumbs-banner {
  position: relative;
  width: 100%;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  background-color: #000;
}

/* ========================================
   BG LAYER
   ======================================== */
.vector-slide-thumbs-bg-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.vector-slide-thumbs-bg-item {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.2s ease-in-out;
  will-change: opacity;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.vector-slide-thumbs-bg-item.active {
  opacity: 1;
}

.vector-slide-thumbs-bg-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Overlay — controlled by Elementor Group_Control_Background on ::after */
.vector-slide-thumbs-bg-item::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
}

/* ========================================
   MAIN LAYOUT
   ======================================== */
.vector-slide-thumbs-main {
  position: relative;
  z-index: 2;
  flex: 1;
  display: flex;
  align-items: center;
  margin: 0 auto;
}

/* ========================================
   DOTS (VERTICAL — DESKTOP)
   ======================================== */
.vector-slide-thumbs-dots-nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  position: relative;
  width: 50px;
  flex-shrink: 0;
  min-height: 500px;
  height: 500px;
  align-self: center;
}

.vector-slide-thumbs-dots-nav .vector-slide-thumbs-dot-line {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  z-index: 0;
}

.vector-slide-thumbs-dot {
  position: relative;
  z-index: 1;
  width: 16px;
  height: 16px;
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  outline: none;
  flex-shrink: 0;
  padding: 0px !important;
}

.vector-slide-thumbs-dot span {
  font-size: 0;
  opacity: 0;
  font-weight: 700;
  transition: all 0.4s ease;
  line-height: 1;
  pointer-events: none;
}

.vector-slide-thumbs-dot:hover {
  transform: scale(1.15);
}

.vector-slide-thumbs-dot.active {
  width: 36px;
  height: 36px;
}

.vector-slide-thumbs-dot.active span {
  font-size: 14px;
  opacity: 1;
}

/* ========================================
   CONTENT AREA
   ======================================== */
.vector-slide-thumbs-content-area {
  flex: 0 0 auto;
  width: 100%;
  max-width: 600px;
  display: flex;
  align-items: center;
  align-self: center;
  position: relative;
  min-height: 400px;
}

.vector-slide-thumbs-content-wrapper {
  position: relative;
  width: 100%;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
}

/* --- Content Item States --- */
.vector-slide-thumbs-content-item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  transform: translateY(30px);
  pointer-events: none;
  transition: none;
  visibility: hidden;
  display: flex;
  flex-flow: column nowrap;
}

.vector-slide-thumbs-content-item.active {
  position: relative;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  visibility: visible;
}

.vector-slide-thumbs-content-item.exiting {
  position: relative;
  visibility: visible;
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.4s ease-in, transform 0.4s ease-in;
  pointer-events: none;
}

.vector-slide-thumbs-content-item.entering {
  position: relative;
  visibility: visible;
  opacity: 0;
  transform: translateY(40px);
  transition: none;
}

.vector-slide-thumbs-content-item.entering.animate-in {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.55s ease-out 0.05s, transform 0.55s ease-out 0.05s;
}

/* --- Headings --- */
.vector-slide-thumbs-subtitle {
  display: block;
}

.vector-slide-thumbs-title {
  line-height: 1.15;
}

/* --- Text / Description --- */
.vector-slide-thumbs-text p {
  line-height: 1.65;
}

.vector-slide-thumbs-text p strong {
  font-weight: 700;
}

.vector-slide-thumbs-text p a {
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* --- CTAs / Buttons --- */
.vector-slide-thumbs-ctas {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.vector-wdg-button {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  transition: all 0.3s ease;
  cursor: pointer;
  white-space: nowrap;
}

.vector-wdg-button__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.vector-wdg-button__icon svg {
  fill: currentColor;
}

/* ========================================
   RIGHT PANEL
   ======================================== */
.vector-slide-thumbs-right-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  align-self: center;
}

.vector-slide-thumbs-group-title {
  display: block;
  text-align: left;
  letter-spacing: 0.02em;
}

/* --- Gallery Wrapper --- */
.vector-slide-thumbs-gallery-wrapper {
  position: relative;
  overflow: hidden;
}

.vector-slide-thumbs-gallery {
  display: flex;
  align-items: flex-start;
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
  will-change: transform;
  padding: 2px 0px;
}

.vector-slide-thumbs-gallery.is-dragging {
  cursor: grabbing;
}

.vector-slide-thumbs-gallery.no-drag {
  cursor: default;
}

.vector-slide-thumbs-gallery.no-transition {
  transition: none !important;
}

.vector-slide-thumbs-gallery.with-transition {
  transition: transform 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* --- Thumb Item (base) --- */
.vector-slide-thumbs-item {
  flex-shrink: 0;
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

/* --- Thumb Type: Image --- */
.vector-slide-thumbs-gallery.thumbs-type-image .vector-slide-thumbs-item {
  transition: height 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    border-width 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    border-color 0.45s ease;
}

.vector-slide-thumbs-item .vector-slide-thumbs-item-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
}

.vector-slide-thumbs-gallery.thumbs-type-image .vector-slide-thumbs-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.60);
  transition: background 0.4s ease;
  pointer-events: none;
}

.vector-slide-thumbs-gallery.thumbs-type-image .vector-slide-thumbs-item.active .vector-slide-thumbs-overlay,
.vector-slide-thumbs-gallery.thumbs-type-image .vector-slide-thumbs-item.next-active .vector-slide-thumbs-overlay {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.50) 54.33%, rgba(0, 0, 0, 0.90) 100%);
}

.vector-slide-thumbs-gallery.thumbs-type-image .vector-slide-thumbs-item-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  pointer-events: none;
}

/* --- Thumb Type: Icon --- */
.vector-slide-thumbs-item-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: color 0.4s ease, fill 0.4s ease;
}

.vector-slide-thumbs-item-icon svg {
  fill: currentColor;
}

/* --- Thumb Type: Color --- */
.vector-slide-thumbs-item-color {
  display: block;
  flex-shrink: 0;
  transition: border-color 0.4s ease;
}

/* --- Thumb Item Text --- */
.vector-slide-thumbs-item-subtitle {
  display: block;
}

.vector-slide-thumbs-item-title {
  display: block;
  line-height: 1.25;
}

/* ========================================
   CONTROLS ROW
   ======================================== */
.vector-slide-thumbs-controls-row {
  display: flex;
  align-items: center;
  gap: 20px;
}

.vector-slide-thumbs-arrows {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.vector-slide-thumbs-arrow {
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  outline: none;
  padding: 0px !important;
  background: transparent;
  height: 60px;
  width: 60px;
}


.vector-slide-thumbs-arrow:focus,
.vector-slide-thumbs-arrow:active,
.vector-slide-thumbs-arrow:hover {
  background: transparent;
}

.vector-slide-thumbs-arrow svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* --- Progress Bar --- */
.vector-slide-thumbs-progress {
  flex: 1;
  height: 3px;
  border-radius: 2px;
  overflow: hidden;
}

.vector-slide-thumbs-progress-bar {
  height: 100%;
  border-radius: 2px;
  width: 0%;
}

.vector-slide-thumbs-progress-bar.animating {
  transition: width linear;
}

/* --- Counter --- */
.vector-slide-thumbs-counter {
  display: flex;
  align-items: baseline;
  gap: 6px;
  white-space: nowrap;
  flex-shrink: 0;
}

.vector-slide-thumbs-counter-current {
  line-height: 1;
}

.vector-slide-thumbs-counter-separator {
  font-weight: 400;
}

.vector-slide-thumbs-counter-total {
  line-height: 1;
}

/* ========================================
     MOBILE (< 1024px)
     ======================================== */
@media (max-width: 1024px) {
  .vector-slide-thumbs-banner {
    height: auto;
    min-height: auto;
    background-color: #000;
  }

  .vector-slide-thumbs-main {
    flex-direction: column;
    padding: 0;
    align-items: stretch;
  }

  .vector-slide-thumbs-dots-nav {
    display: none;
  }

  /* BG overlay changes to gradient on mobile */
  .vector-slide-thumbs-bg-item::after {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.40) 68.75%, #000 100%);
  }

  .vector-slide-thumbs-content-area {
    width: 100%;
    max-width: 100%;
    padding: 0;
    order: 1;
    min-height: auto;
    position: relative;
    overflow: hidden;
  }

  .vector-slide-thumbs-content-wrapper {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: flex-end;
  }

  .vector-slide-thumbs-content-item {
    top: auto;
    left: auto;
    position: absolute;
    width: 100%;
  }

  .vector-slide-thumbs-content-item.active {
    position: relative;
  }

  .vector-slide-thumbs-headings {
    text-align: center;
  }

  .vector-slide-thumbs-headings .vector-slide-thumbs-title {
    font-size: 30px;
  }

  .vector-slide-thumbs-text {
    text-align: center;
  }

  .vector-slide-thumbs-text p {
    font-size: 14px;
  }

  .vector-slide-thumbs-ctas {
    justify-content: center;
  }

  .vector-wdg-button {
    flex: 1;
    justify-content: center;
    padding: 14px 20px;
  }

  .vector-slide-thumbs-right-panel {
    padding: 30px 0 0;
    order: 2;
    background: #000;
    width: 100%;
  }

  .vector-slide-thumbs-group-title {
    padding: 0 24px;
  }

  .vector-slide-thumbs-gallery-wrapper {
    padding-left: 24px;
    margin-bottom: 24px;
  }

  .vector-slide-thumbs-gallery.thumbs-type-image .vector-slide-thumbs-item {
    width: 200px;
    height: 160px;
  }

  .vector-slide-thumbs-gallery.thumbs-type-image .vector-slide-thumbs-item.active,
  .vector-slide-thumbs-gallery.thumbs-type-image .vector-slide-thumbs-item.next-active {
    height: 160px;
  }

  .vector-slide-thumbs-controls-row {
    padding: 0 24px 10px;
    gap: 16px;
  }

  .vector-slide-thumbs-arrow {
    width: 42px;
    height: 42px;
  }

  .vector-slide-thumbs-arrow svg {
    width: 18px;
    height: 18px;
  }

  .vector-slide-thumbs-divider {
    height: 30px;
  }

  .vector-slide-thumbs-counter-current,
  .vector-slide-thumbs-counter-total {
    font-size: 24px;
  }

  .vector-slide-thumbs-counter-separator {
    font-size: 16px;
  }

  .vector-slide-thumbs-dots-mobile {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 24px 24px 32px;
    background: #000;
  }

  .vector-slide-thumbs-dots-mobile-row {
    display: flex;
    align-items: center;
    width: 100%;
    position: relative;
  }

  .vector-slide-thumbs-dots-mobile-row .vector-slide-thumbs-dot-line-h {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 3px;
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-50%);
    z-index: 0;
    border-radius: 2px;
  }

  .vector-slide-thumbs-dots-mobile .vector-slide-thumbs-dot {
    z-index: 1;
    margin: 0;
    flex-shrink: 0;
  }

  .vector-slide-thumbs-dots-mobile-spacer {
    flex: 1;
    min-width: 16px;
  }

  .vector-slide-thumbs-banner.vector-slide-nav-dots_arrows .vector-slide-nav-dots_arrows {
    display: none !important;
  }
}

@media (min-width: 1024px) {
  .vector-slide-thumbs-dots-mobile {
    display: none;
  }
}