.tbimmo-carousel-block {
  position: relative;
  --tbimmo-carousel-gap: 1.5rem;
}

.tbimmo-carousel {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
}

.tbimmo-carousel__viewport {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
}

.tbimmo-carousel__track {
  display: flex;
  gap: var(--tbimmo-carousel-gap);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding: 0.25rem;
}

.tbimmo-carousel__track::-webkit-scrollbar {
  display: none;
}

.tbimmo-carousel__slide {
  flex: 0 0 calc((100% - (var(--tbimmo-carousel-gap) * (var(--tbimmo-carousel-slides, 3) - 1))) / var(--tbimmo-carousel-slides, 3));
  min-width: 0;
  scroll-snap-align: start;
}

.tbimmo-carousel__slide .tbimmo-card {
  height: 100%;
}

.tbimmo-carousel__nav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  flex: 0 0 3rem;
  border-radius: 9999px;
  border: 1px solid var(--tbimmo-carousel-nav-border, #cbd5e1);
  background: var(--tbimmo-carousel-nav-bg, #ffffff);
  color: var(--tbimmo-carousel-nav-color, #0f172a);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.tbimmo-carousel__nav:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.14);
}

.tbimmo-carousel__nav:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  box-shadow: none;
}

.tbimmo-carousel__nav span {
  font-size: 1.25rem;
  line-height: 1;
  font-weight: 700;
}

@media (max-width: 1023px) {
  .tbimmo-carousel__slide {
    flex-basis: calc((100% - (var(--tbimmo-carousel-gap) * (var(--tbimmo-carousel-slides-md, 2) - 1))) / var(--tbimmo-carousel-slides-md, 2));
  }
}

@media (max-width: 767px) {
  .tbimmo-carousel {
    gap: 0.75rem;
  }

  .tbimmo-carousel__slide {
    flex-basis: calc((100% - (var(--tbimmo-carousel-gap) * (var(--tbimmo-carousel-slides-sm, 1) - 1))) / var(--tbimmo-carousel-slides-sm, 1));
  }

  .tbimmo-carousel__nav {
    width: 2.5rem;
    height: 2.5rem;
    flex-basis: 2.5rem;
  }
}
