/* Specials - Grid Module */
.cms-specials-grid-wrap { margin: 3.125rem 0; }
.cms-specials-grid-wrap > .row > [class^=col] { margin-bottom: 1.875rem; }
.cms-specials-grid-wrap .card { overflow: hidden; width: 100%; min-height: 19rem; display: flex; flex-direction: column; position: relative; border: none; border-radius: var(--borderRadius); box-shadow: var(--dropShadow); }
.cms-specials-grid-wrap .card:hover { box-shadow: var(--dropShadow), var(--dropShadow); background-color: hsl(var(--black)); }
.cms-specials-grid-wrap .card-link { overflow: hidden; display: block; width: 100%; min-height: 19rem; background: hsl(var(--black)); }
.cms-specials-grid-wrap .card-img-left { opacity: 0.85; width: 100%; min-height: 19rem; object-fit: cover; transform: scale(1); transition: all ease-in-out 0.4s; }
.cms-specials-grid-wrap .card:hover .card-img-left { opacity: 1; transform: scale(1.2); }
.cms-specials-grid-wrap .card-body { display: flex; flex-direction: column; width: 100%; height: 100%; padding: 1rem 1.25rem; background-color: hsl(var(--white)); }
.cms-specials-grid-wrap .card-text { height: 100%;}
.cms-specials-grid-wrap .card-text,
.cms-specials-grid-wrap .card-text p:only-child { margin: 0; max-height: 11.25rem; overflow-y: auto;  }
.cms-specials-grid-wrap .card-title, .cms-specials-grid-wrap .card-sub-title { font-weight: var(--wMedium); }
.cms-specials-grid-wrap em { margin-top: auto; }
.cms-specials-grid-wrap .btn { display: block; margin-top: auto; background-color: hsl(var(--siteColor1)); border-radius: var(--borderRadiusPill); color: hsl(var(--white)); font-weight: var(--wRegular); transition: all ease-in-out 0.4s; }
.cms-specials-grid-wrap .btn:hover { background-color: hsl(var(--siteColor2)); }

@media(min-width: 769px) {
  .cms-specials-grid-wrap .card { overflow: hidden; width: 100%; height: 19rem; display: flex; flex-direction: row; position: relative; border: none; border-radius: var(--borderRadius); box-shadow: var(--dropShadow); }
  .cms-specials-grid-wrap .card:hover { box-shadow: var(--dropShadow), var(--dropShadow); background-color: hsl(var(--black)); }
  .cms-specials-grid-wrap .card-link { overflow: hidden; display: block; width: 40%; height: 19rem; background: hsl(var(--black)); }
}

/* Specials Wrapper */
.cms-specials-properties-wrap { padding: 6.25rem 0; position: relative; z-index: 1; }
.cms-specials-properties-wrap .container { width: 100%; max-width: 87.5rem; margin-top: 0.9375rem; }
.cms-specials-properties-wrap .subtitle { color: hsl(var(--siteColor1)); font-weight: var(--wMedium); }

/* Specials Swiper */
.cms-specials-properties-wrap .swiper-container .swiper-lazy-preloader { --swiper-preloader-color: hsl(var(--siteColor1)); }
.specials-properties-swiper { max-width: 112.5rem; padding: 1.875rem 0.9375rem; }
.specials-properties-controls { display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%; max-width: 25rem; margin: auto; position: relative; }
.specials-properties-controls .specials-btn-next,
.specials-properties-controls .specials-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; }
.specials-properties-controls .specials-btn-next:hover,
.specials-properties-controls .specials-btn-prev:hover { background: hsl(var(--siteColor1)); box-shadow: var(--dropShadow); color: hsl(var(--white)); }
.specials-properties-controls .specials-btn-next:focus,
.specials-properties-controls .specials-btn-prev:focus { outline: none; box-shadow: var(--focusShadow); }
.specials-properties-controls .specials-btn-next:after,
.specials-properties-controls .specials-btn-prev:after { display: none; }
.specials-properties-controls .specials-btn-next .icon,
.specials-properties-controls .specials-btn-prev .icon { width: 1.75rem; height: 1.75rem; }

.specials-properties-controls .specials-pagination { display: flex; align-items: center; position: relative; top: auto; right: auto; left: auto; }

/* Specials Property */
.specials-property { overflow: hidden; display: flex; flex-direction: column; border-radius: var(--borderRadius); box-shadow: var(--dropShadow); font-family: var(--siteFont2), sans-serif; }
.specials-property:hover { box-shadow: var(--dropShadow), var(--dropShadow); }
.specials-property-img-wrap { position: relative; padding-bottom: 62.5%; position: relative; z-index: 1; background-color: var(--placeholderBG); }
.specials-property-img-link { display: block; width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
.specials-property-img { display: block; width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
.specials-property-info-wrap { display: flex; flex-direction: column; position: relative; padding: 1rem 1.25rem; background: hsl(var(--white)); line-height: 1; }
.specials-property-info-wrap .col { display: flex; flex-wrap: wrap; align-content: center; padding: 0 0.3125rem; }
.specials-property-title { display: flex; flex-wrap: wrap; margin: 0 0 0.25rem; }
.specials-property-title .h3 { margin: 0; font-family: var(--bodyFont); font-size: 1.25rem !important; line-height: 1.25; font-weight: var(--wRegular); }
.specials-property-title .h5 { margin: 0.75rem 0 0; font-family: inherit; font-size: 1rem !important; color: hsl(var(--bodyFontColor)); line-height: 1.25; font-weight: var(--wNormal); text-transform: capitalize; }
.specials-property-title .icon { width: 0.75rem; height: 1rem; margin-right: 0.1875rem; color: hsl(var(--siteColor1)); }
.specials-property-title-link, .specials-property-title-link:hover { color: hsl(var(--bodyFontColor)); }
.specials-property-info { display: flex; flex-wrap: wrap; justify-content: space-around; margin: 0; padding: 0; font-size: 1rem; line-height: 1; font-weight: var(--wNormal); }
.specials-property-info-item { display: flex; margin-top: 0.75rem; padding: 0 0.25rem; text-align: center; }
.specials-property-info-item .icon { height: 0.85rem; width: 1.25rem; margin-right: 0.25rem; color: hsl(var(--siteColor1)); }

/* CLS Fixes */
.specials-property-title-link { display: block; width: 95%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.specials-property-title .h3 { width: 100%; }
.specials-properties-controls { height: 3rem; }
.specials-property-img-wrap { height: 15rem; padding-bottom: 0; }
.specials-property-info-wrap { min-height: 7rem; }
.specials-property-info { flex-wrap: nowrap; }
.specials-property-info-item { display: block; justify-content: center; }
.specials-properties-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) {
  .specials-properties-swiper .swiper-slide { --columns: 1; }
}
@media (min-width: 667px) {
  .specials-properties-swiper .swiper-slide { --columns: 2; }
}
@media (min-width: 992px) {
  .specials-properties-swiper .swiper-slide { --columns: 3; }
}
@media (min-width: 1200px) {
  .specials-properties-swiper .swiper-slide { --columns: 4; }
}