/* =========================================================================
   Postmark Travel — clean uniform-size carousel
   Override Elementor's image-carousel default styling on country pages.
   ========================================================================= */

/* Container — modest width with padding for the arrows. Let Swiper
   calculate its own slide widths so internal state stays consistent. */
.elementor-widget-image-carousel {
  max-width: 900px;
  margin: 48px auto;
  padding: 0 64px;
}

.elementor-widget-image-carousel .elementor-image-carousel-wrapper {
  position: relative;
  overflow: hidden;
}

/* The carousel itself */
.elementor-widget-image-carousel .elementor-image-carousel {
  display: flex;
}

/* Each slide — uniform 4:3 landscape, full slide width (Swiper sets it). */
.elementor-widget-image-carousel .swiper-slide {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 4 / 3;
  height: auto !important;
  background: #f5f0ed;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

/* Force the slide-inner (figure) to fill the slide */
.elementor-widget-image-carousel .swiper-slide-inner,
.elementor-widget-image-carousel .swiper-slide figure {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Make all images fill the slide uniformly, cropping as needed */
.elementor-widget-image-carousel .swiper-slide img,
.elementor-widget-image-carousel .swiper-slide .swiper-slide-image,
.elementor-widget-image-carousel .swiper-slide-inner img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 14px;
  display: block !important;
}

/* Hide any caption text that would break uniformity */
.elementor-widget-image-carousel .elementor-image-carousel-caption {
  display: none !important;
}

/* Navigation arrows — bigger, visible, sat against the carousel edges */
.elementor-widget-image-carousel .elementor-swiper-button {
  width: 48px;
  height: 48px;
  background: rgba(61, 138, 134, 0.92);
  color: #fff !important;
  border-radius: 50%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
  z-index: 5;
  top: 50%;
  transform: translateY(-50%);
}

.elementor-widget-image-carousel .elementor-swiper-button:hover {
  background: rgba(47, 110, 107, 1);
  transform: translateY(-50%) scale(1.05);
}

.elementor-widget-image-carousel .elementor-swiper-button-prev {
  left: 4px;
}

.elementor-widget-image-carousel .elementor-swiper-button-next {
  right: 4px;
}

/* Force-show the arrow content (svg / i) */
.elementor-widget-image-carousel .elementor-swiper-button svg,
.elementor-widget-image-carousel .elementor-swiper-button i {
  font-size: 18px;
  width: 18px;
  height: 18px;
  color: #fff !important;
  fill: #fff !important;
  display: inline-block !important;
}

/* Remove the swiper wrapper's default ~30px bottom padding (Elementor reserves
   it for absolutely-positioned pagination). Our dots are relative with their
   own top margin, so that padding is just dead space before the next section. */
.elementor-widget-image-carousel .swiper,
.elementor-widget-image-carousel .elementor-image-carousel-wrapper,
.elementor-widget-image-carousel .swiper-container {
  padding-bottom: 0 !important;
}

/* Pagination dots — clean, teal accent */
.elementor-widget-image-carousel .swiper-pagination {
  position: relative;
  margin-top: 12px;
  bottom: auto !important;
  text-align: center;
  width: 100%;
  display: block;
}

.elementor-widget-image-carousel .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.18);
  opacity: 1;
  margin: 0 5px !important;
  transition: background 0.2s, transform 0.2s;
  cursor: pointer;
  display: inline-block;
}

.elementor-widget-image-carousel .swiper-pagination-bullet-active {
  background: var(--c-teal, #3D8A86);
  transform: scale(1.2);
}

/* Mobile responsiveness */
@media (max-width: 768px) {
  .elementor-widget-image-carousel {
    padding: 0 20px;
    /* Reduced bottom margin (24 -> 8) so the carousel doesn't leave an
       oversized gap before the next section (e.g. "You may also like"). */
    margin: 20px auto 8px;
  }
  .elementor-widget-image-carousel .elementor-swiper-button {
    width: 36px;
    height: 36px;
    font-size: 14px;
  }
  .elementor-widget-image-carousel .swiper-slide {
    aspect-ratio: 1 / 1; /* square on mobile, looks better with portrait phone photos */
  }
}

/* Variant for carousels with multiple slides per view (e.g. "coverflow" celebrate
   reunions). Keep them uniform but smaller. */
.elementor-widget-image-carousel .swiper-slide.swiper-slide-prev,
.elementor-widget-image-carousel .swiper-slide.swiper-slide-next {
  opacity: 0.65;
}
