/*--------------------------------------------------------------
# Villa Single
--------------------------------------------------------------*/

/* Featured Image
--------------------------------------------- */

.villa-single .featured-image {
  margin-bottom: 1.5rem;
}

.villa-single .featured-image img {
  object-fit: cover;
  width: 100%;
  height: 50vh;
}

@media (min-width: 960px) {
  .villa-single .featured-image img {
    height: 75vh;
  }
}

/* Details
--------------------------------------------- */

@media (min-width: 1140px) {
  .villa-single .details {
    margin-top: -9rem;
  }
}

.villa-single .details > .outer {
  position: relative;
  background-color: rgb(var(--color-primary-50));
  max-width: calc(var(--max-w-lg) + 6rem - 40px);
  margin: 0 auto;
}

.villa-single .details > .outer > .wrapper {
  max-width: var(--max-w-lg);
  margin: 0 auto;
  padding: 3rem 20px;
}

.villa-single .details .grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 720px) {
  .villa-single .details .grid {
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 3rem;
  }
}

.villa-single .details .header .title {
  font-family: var(--font-serif);
  font-weight: var(--font-light);
  font-size: var(--font-6xl);
  line-height: var(--leading-tight);
  margin-bottom: 1.5rem;
}

.villa-single .details .header .excerpt {
  font-family: var(--font-serif);
  font-size: var(--font-xl);
  margin-bottom: 1.5rem;
}

.villa-single .details .content {
  margin-bottom: 2rem;
}

/* Facilities */

.villa-single .details .facilities .title {
  font-size: var(--font-4xl);
  font-weight: var(--font-light);
  line-height: var(--leading-tight);
  margin-bottom: 1.5rem;
}

.villa-single .details .facilities .subtitle {
  font-size: var(--font-xl);
  margin-bottom: 0.25rem;
  color: rgb(var(--color-secondary-700));
}

.villa-single .details .facilities .facilities-grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 1.5rem;
}

@media (min-width: 720px) {
  .villa-single .details .facilities .facilities-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.villa-single .details .facilities ul {
  list-style: disc;
  margin-left: 1rem;
}

@media (max-width: 719px) {
  .villa-single .details .grid .book {
    border-top: 1px solid rgb(var(--color-secondary-200));
    padding-top: 1.5rem;
  }
}

@media (min-width: 720px) {
  .villa-single .details .book {
    border-left: 1px solid rgb(var(--color-secondary-200));
    padding-left: 3rem;
  }
}

.villa-single .details .book .overview li {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.villa-single .details .book .overview li:not(:last-child) {
  margin-bottom: 0.75rem;
}

.villa-single .details .book .overview li .symbol {
  color: rgb(var(--color-secondary-700));
}

.villa-single .details .book .btn-book {
  display: inline-block;
  margin-top: 2rem;
}

/* Gallery
--------------------------------------------- */

/* Main */

.villa-single .gallery > .wrapper {
  max-width: var(--max-w-full);
  margin: 0 auto;
  padding: 1.5rem 20px 4.5rem;
}

.villa-single .gallery img {
  aspect-ratio: 3 / 2;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

/* Modal */

#gallery-modal {
  display: none;
  position: fixed;
  z-index: 3;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgb(var(--color-primary-1000));
}

#gallery-modal.active {
  display: block;
}

#gallery-modal > .wrapper {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

#gallery-modal .swiper {
  width: 100%;
  height: 100%;
}

#gallery-modal .swiper-slide {
  display: flex;
  justify-content: center;
  align-items: center;
}

#gallery-modal .swiper-slide img {
  max-width: calc(100% - 20px);
  max-height: calc(100% - 110px);
  object-fit: contain;
}

#gallery-modal .swiper-slide .caption {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: rgb(var(--color-primary-1000));
  color: rgb(var(--color-primary-50));
}

#gallery-modal .swiper-slide .caption > .wrapper {
  padding: 20px;
  text-align: center;
  font-size: var(--font-sm);
}

#gallery-modal .swiper-pagination {
  position: absolute;
  top: 0;
  left: 0;
  padding: 20px;
  color: rgb(var(--color-primary-50));
}

#gallery-modal .close-modal {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 4;
  margin: 20px;
  cursor: pointer;
  font-size: var(--font-2xl);
  color: rgb(var(--color-primary-50));
}

body.gallery-modal-active {
  overflow: hidden;
}

/* Related Villas
--------------------------------------------- */

.villa-single .related-villas {
  background-color: rgb(var(--color-primary-100));
}

.villa-single .related-villas > .wrapper {
  max-width: var(--max-w-xxl);
  margin: 0 auto;
  padding: 3rem 20px 4.5rem;
}

.villa-single .related-villas .section-title {
  font-size: var(--font-5xl);
  font-weight: var(--font-light);
  line-height: var(--leading-tight);
  margin-bottom: 3rem;
  color: rgb(var(--color-secondary-700));
}

.villa-single .related-villas .villas {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  column-gap: 3rem;
  row-gap: 3rem;
}

@media (min-width: 960px) {
  .villa-single .related-villas .villas {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.villa-single .related-villas .villa img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  aspect-ratio: 3 / 2;
  margin-bottom: 1.5rem;
}

.villa-single .related-villas .villa .title {
  font-family: var(--font-serif);
  font-weight: var(--font-light);
  font-size: var(--font-5xl);
  line-height: var(--leading-tight);
  margin-bottom: 0.75rem;
}

.villa-single .related-villas .villa .excerpt p {
  margin-bottom: 0.75rem;
}

.villa-single .related-villas .villa .overview {
  display: flex;
  flex-wrap: wrap;
  column-gap: 0.75rem;
  margin: 0 0 1.5rem;
  padding: 0.75rem 0;
  border-top: 1px solid rgb(var(--color-secondary-200));
  border-bottom: 1px solid rgb(var(--color-secondary-200));
  font-family: var(--font-serif);
}
