/* 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-swiper { padding: 1.875rem 0.9375rem; }
.resorts-gallery-controls { display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%; max-width: 25rem; margin: auto; position: relative; }
.resorts-gallery-controls .resort-btn-next,
.resorts-gallery-controls .resort-btn-prev { width: 3.125rem; height: 3.125rem; margin: auto; position: relative; top: auto; right: auto; left: auto; background: transparent; border-radius: 50vw; 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 { background: hsl(var(--siteColor1)); box-shadow: var(--dropShadow); color: hsl(var(--white)); }
.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.875rem; }
.resorts-gallery-controls .resort-pagination { width: auto; display: flex; 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%; }
@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; }