/* Resort Swiper Wrapper */
.cms-resorts-gallery-wrap { margin: 3.125rem 0; max-width: 100%; }
.cms-resorts-gallery-wrap .swiper-container .swiper-lazy-preloader { --swiper-preloader-color: hsl(var(--siteColor1)); }
@media (min-width: 1025px) {
  .cms-resorts-gallery-wrap { max-width: calc(100vw - var(--srpMapContainerWidth) - var(--scrollbarWidth) - 6rem); }
  .map-collapse .cms-resorts-gallery-wrap { max-width: calc(100vw - var(--scrollbarWidth) - 6rem); }
}

/* Resort Swiper Controls */
.resorts-gallery-controls { display: flex; flex-wrap: wrap; justify-content: center; width: 100%; margin: 2rem auto 0; position: relative; gap: 1.5rem; }
.resorts-gallery-controls:has(.swiper-button-lock) { margin: auto; }
.resorts-gallery-controls .resort-btn-next,
.resorts-gallery-controls .resort-btn-prev { width: 2.75rem; height: 2.75rem; margin: 0; position: relative; top: auto; right: auto; left: auto; background-color: transparent; border-radius: var(--borderRadiusCircle); box-shadow: none; color: hsl(var(--siteColor1)); transition: all 0.4s ease-in-out; }
.resorts-gallery-controls .resort-btn-next:hover,
.resorts-gallery-controls .resort-btn-prev:hover,
.resorts-gallery-controls .resort-btn-next:focus,
.resorts-gallery-controls .resort-btn-prev:focus { outline: none; box-shadow: var(--focusShadow); }
.resorts-gallery-controls .resort-btn-next:after,
.resorts-gallery-controls .resort-btn-prev:after { font-size: 1.5rem; }
.resorts-gallery-controls .resort-pagination { display: flex; justify-content: center; align-items: center; position: relative; top: auto; right: auto; bottom: auto; left: auto !important; transform: none !important;  }

/* Resort Swiper Images */
.resort-gallery-img-wrap { width: 100%; position: relative; padding-bottom: 70%; overflow: hidden;  background: var(--placeholderBG); border-radius: var(--borderRadius); box-shadow: var(--dropShadow); }
.resort-gallery-link { display: block; width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
.resort-gallery-img { display: block; width: 100%; height: 100%; object-fit: cover; position: absolute; top: 0; left: 0; z-index: 2; }
.resort-gallery-link .swiper-caption { padding: 0.3125rem 0.75rem 0.3125rem 1rem; position: absolute; bottom: 0; left: 0; z-index: 3; background: hsla(var(--black), 75%); border-top-right-radius: var(--borderRadiusCheckbox); color: hsl(var(--white)); line-height: 1; }

/* CLS Fixes */
/* .resorts-gallery-controls { height: 3rem; } */
.resorts-gallery-img-wrap { height: 15rem; padding-bottom: 0; }
.resorts-gallery-swiper .swiper-slide { --marginRight: 1.875rem; --columns: 1; margin-right: var(--marginRight); width: calc(calc(100% / var(--columns)) - var(--marginRight) + calc(var(--marginRight) / var(--columns))); }
@media (min-width: 0) {
  .resorts-gallery-swiper .swiper-slide { --columns: 1; }
}
@media (min-width: 667px) {
  .resorts-gallery-swiper .swiper-slide { --columns: 2; }
}
@media (min-width: 992px) {
  .resorts-gallery-swiper .swiper-slide { --columns: 3; }
}
@media (min-width: 1200px) {
  .resorts-gallery-swiper .swiper-slide { --columns: 4; }
}

/* Resort Single Image */
.resort-detail-content-wrap { display: flex; flex-wrap: wrap; flex-direction: row; align-items: center;  }
.resort-single-img-wrap { width: 100%; max-width: 43.75rem; position: relative; padding-bottom: 70%; overflow: hidden; background: var(--placeholderBG); border-radius: var(--borderRadius); box-shadow: var(--dropShadow); }
.resort-single-img { display: block; width: 100%; height: 100%; object-fit: cover; position: absolute; top: 0; left: 0; z-index: 2; }
.resort-detail-content-wrap .resort-detail-info-wrap { width: 100%; padding: 1rem; }
@media (min-width: 812px) {
  .resort-single-img-wrap { width: 45%; flex-basis: 45%; padding-bottom: 30%; }
  .resort-detail-content-wrap .resort-detail-info-wrap { width: 55%; flex-basis: 55%; }
}

/* Resort Detail Info */
/* .resort-detail-info-wrap { padding: 1rem; } */
.resort-detail-description { margin-bottom: 1rem; }
.resort-detail-amenities { margin-bottom: 1rem; }