.ayana-retreat-venue-page {
    overflow: hidden;
}

.ayana-retreat-venue-page img {
    display: block;
    width: 100%;
    height: auto;
}


/* HERO */

.venue-hero {
    padding: 90px 0 110px;
}

.venue-hero__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    align-items: stretch;
}

.venue-hero__image {
    overflow: hidden;
}

.venue-hero__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.venue-hero__image--main {
     grid-column: 1;
    grid-row: 1;
    aspect-ratio: 7 / 5;
}

.venue-hero__content {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 70px;
}
.venue-hero__content h2 {
    margin: 0 0 24px;
    text-transform: uppercase;
}

.venue-hero__content h3 {
    margin: 0 0 28px;
}


.venue-hero__description {
    grid-column: 1;
    grid-row: 2;
    display: flex;
    align-items: center;
    padding: 70px;
}

.venue-hero__description p {
    max-width: 560px;
    margin: 0;
}

.venue-hero__image--secondary {
    grid-column: 2;
    grid-row: 2;
    aspect-ratio: 7 / 5;
}



/* FEATURES */

.venue-features {
    padding: 100px 0 120px;
}

.venue-intro-text {
    max-width: 760px;
    margin: 0 auto 70px;
    text-align: center;
}

.venue-intro-text p {
    margin: 0 0 14px;
}

.venue-intro-text p:last-child {
    margin-bottom: 0;
}

.venue-features__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 55px;
}

.venue-feature-card {
    text-align: center;
}

.venue-feature-card__image {
    aspect-ratio: 9 / 7;
    margin-bottom: 32px;
    overflow: hidden;
}

.venue-feature-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.venue-feature-card h3 {
    margin: 0 0 18px;
    text-transform: uppercase;
}

.venue-feature-card p {
    max-width: 300px;
    margin: 0 auto;
}


/* BOOKING */

.venue-booking {
    position: relative;
    padding: 110px 0 130px;
    margin-bottom: 2px;
    overflow: hidden;
}

.venue-booking__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.ayana-retreat-venue-page .venue-booking__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.venue-booking__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        rgba(92, 76, 45, 0.46),
        rgba(92, 76, 45, 0.46)
    );
}

.venue-booking__inner {
    position: relative;
    z-index: 2;
}

.venue-booking h2 {
    margin: 0 0 60px;
    color: #fff;
    text-align: center;
    text-transform: uppercase;
}

.venue-booking__cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 360px));
    justify-content: center;
    gap: 80px;
}

.venue-booking-card {
    padding: 48px 42px 54px;
    background: #fff;
    text-align: center;
}

.venue-booking-card h3 {
    margin: 0 0 34px;
    text-transform: uppercase;
}

.venue-booking-card__image {
    aspect-ratio: 7 / 5;
    margin: 0 auto 34px;
    overflow: hidden;
}

.venue-booking-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.venue-booking-card > p {
    margin: 0 auto 38px;
}

.venue-booking-card__price p {
    margin: 0 0 8px;
    font-weight: 600;
   
}

.venue-booking-card__price p:last-child {
    margin-bottom: 0;
}


/* TABLET */

@media (max-width: 1024px) {

    .venue-hero {
        padding: 70px 0 85px;
    }

    .venue-hero__content {
        padding: 45px;
    }
   
    .venue-features {
        padding: 80px 0 95px;
    }

    .venue-features__grid {
        gap: 30px;
    }

    .venue-booking__cards {
        gap: 35px;
    }
}


/* MOBILE */

@media (max-width: 767px) {

    .venue-hero {
        padding: 50px 0 65px;
    }

    .venue-hero__grid {
        grid-template-columns: 1fr;
    }

    .venue-hero__content {
        padding: 35px 0;
    }

    .venue-hero__image--secondary {
        grid-column: 1;
    }

    .venue-features {
        padding: 65px 0 75px;
    }

    .venue-intro-text {
        margin-bottom: 45px;
        text-align: left;
    }

    .venue-features__grid {
        grid-template-columns: 1fr;
        gap: 42px;
    }

    .venue-feature-card {
        text-align: left;
    }

    .venue-feature-card p {
        margin-left: 0;
    }

    .venue-booking {
        padding: 75px 0 85px;
      
    }

    .venue-booking h2 {
        margin-bottom: 38px;
    }

    .venue-booking__cards {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .venue-booking-card {
        padding: 36px 28px 42px;
    }

    .venue-booking-card h3 {
        margin-bottom: 26px;
    }
  .venue-hero {
        padding: 50px 0 65px;
    }

    .venue-hero__grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0;
    }

    .venue-hero__content {
        grid-column: 1;
        grid-row: 1;
        padding: 0 0 28px;
    }

    .venue-hero__content h2 {
        margin: 0 0 16px;
    }

    .venue-hero__content h3 {
        margin: 0;
    }

    .venue-hero__image--main {
        grid-column: 1;
        grid-row: 2;
        aspect-ratio: 4 / 3;
    }

    .venue-hero__description {
        grid-column: 1;
        grid-row: 3;
        padding: 28px 0 38px;
    }

    .venue-hero__description p {
        max-width: none;
        margin: 0;
    }

    .venue-hero__image--secondary {
        grid-column: 1;
        grid-row: 4;
        aspect-ratio: 4 / 3;
    }
}


/* FLAG HERO */

.flag-retreat-page .venue-hero__content {
    grid-column: 1;
    grid-row: 1;
}

.flag-retreat-page .venue-hero__image--main {
    grid-column: 2;
    grid-row: 1;
}

.flag-retreat-page .venue-hero__image--secondary {
    grid-column: 1;
    grid-row: 2;
}

.flag-retreat-page .venue-hero__description {
    grid-column: 2;
    grid-row: 2;
}


/* VENUE CONCEPT */

.venue-concept {
    padding: 100px 0 120px;
}

.venue-concept__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
}

.venue-concept__images {
    display: grid;
    grid-template-columns: 1fr;
}

.venue-concept__image {
    aspect-ratio: 7 / 5;
    overflow: hidden;
}

.venue-concept__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.venue-concept__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 70px;
    text-align: center;
}

.venue-concept__content h2 {
    margin: 0 0 14px;
    text-transform: uppercase;
}

.venue-concept__content h3 {
    margin: 0 0 58px;
}

.venue-concept__item {
    max-width: 420px;
    margin: 0 auto 42px;
}

.venue-concept__item:last-child {
    margin-bottom: 0;
}

.venue-concept__item h4 {
    margin: 0 0 14px;
   
}

.venue-concept__item p {
    margin: 0;
}






/* FLAG MOBILE */

@media (max-width: 767px) {

    .flag-retreat-page .venue-hero__content {
        grid-column: 1;
        grid-row: 1;
    }

    .flag-retreat-page .venue-hero__image--main {
        grid-column: 1;
        grid-row: 2;
    }

    .flag-retreat-page .venue-hero__description {
        grid-column: 1;
        grid-row: 3;
    }

    .flag-retreat-page .venue-hero__image--secondary {
        grid-column: 1;
        grid-row: 4;
    }

    .venue-concept {
        padding: 65px 0 75px;
    }

    .venue-concept__grid {
        grid-template-columns: 1fr;
    }

    .venue-concept__content {
        padding: 42px 0 0;
        text-align: left;
    }

    .venue-concept__content h3 {
        margin-bottom: 38px;
    }

    .venue-concept__item {
        max-width: none;
        margin-bottom: 32px;
    }
}


/* COMMON BOTTOM SECTIONS */

.retreat-day {
    position: relative;
    padding: 120px 0;
    overflow: hidden;
}

.ayana-retreat-venue-page .retreat-day__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.retreat-day__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: rgba(92, 76, 45, 0.6);
}

.retreat-day__inner {
    position: relative;
    z-index: 2;
    max-width: 880px;
    margin: 0 auto;
    text-align: center;
}

.retreat-day h2 {
    margin: 0 0 48px;
    color: #fff;
}

.retreat-day__card {
    padding: 60px 70px;
    background: #fff;
    border-radius: 28px;
    text-align: left;
}

.retreat-day__card ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.retreat-day__card li {
    margin: 0 0 16px;
}

.retreat-day__card p {
    margin: 34px 0 0;
}


.retreat-included {
    padding: 120px 0;
}

.retreat-included h2,
.retreat-arranged h2 {
    margin: 0 0 70px;
    text-align: center;
}

.retreat-included__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 42px 90px;
    max-width: 900px;
    margin: 0 auto;
}

.retreat-included__item,
.retreat-arranged__item {
    display: grid;
    grid-template-columns: 86px 1fr;
    align-items: center;
    gap: 28px;
}

.retreat-included__image,
.retreat-arranged__image {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: 50%;
}

.retreat-included__image img,
.retreat-arranged__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.retreat-included__item p,
.retreat-arranged__item p {
    margin: 0;
}


.retreat-arranged {
    padding: 100px 0 120px;
}

.retreat-arranged__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 340px));
    justify-content: center;
    gap: 90px;
}


.retreat-policy {
    padding: 110px 0;
}

.retreat-policy__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 45px;
}

.retreat-policy__item {
    padding: 42px 36px;
    background: #fff;
}

.retreat-policy__item h3 {
    margin: 0 0 24px;
}

.retreat-policy__item p {
    margin: 0 0 16px;
}

.retreat-policy__item p:last-child {
    margin-bottom: 0;
}


.retreat-application {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 620px;
    overflow: hidden;
}

.ayana-retreat-venue-page .retreat-application__bg {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.retreat-application__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: rgba(0, 0, 0, 0.24);
}

.retreat-application__content {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
}

.retreat-application__content h2 {
    margin: 0 0 28px;
    color: #fff
}

.retreat-application__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 34px;
    border: 1px solid #fff;
    border-radius: 999px;
    background: transparent;
    color: #fff;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}


.retreat-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
}

.retreat-modal.is-open {
    display: block;
}

.retreat-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.52);
}

.retreat-modal__dialog {
    position: relative;
    z-index: 2;
    width: calc(100% - 40px);
    max-width: 680px;
    max-height: calc(100vh - 80px);
    margin: 40px auto;
    padding: 50px;
    overflow: auto;
    background: #fff;
}

.retreat-modal__close {
    position: absolute;
    top: 18px;
    right: 22px;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-size: 34px;
    line-height: 1;
}

.retreat-modal__dialog h2 {
    margin: 0 0 24px;
}

.retreat-modal__dialog p {
    margin: 0 0 16px;
}

.retreat-modal__form {
    margin-top: 30px;
}

.retreat-form-placeholder {
    padding: 38px;
    border: 1px dashed currentColor;
    text-align: center;
}


/* COMMON BOTTOM MOBILE */

@media (max-width: 767px) {
 .ayana-retreat-venue-page .retreat-day__bg {
        height: 100%;
        object-fit: cover;
        object-position: center top;
    }
    .retreat-day {
        padding: 75px 0;
    }

    .retreat-day h2 {
        margin-bottom: 34px;
    }

    .retreat-day__card {
        padding: 34px 26px;
        border-radius: 18px;
    }

    .retreat-day__card li {
        margin-bottom: 13px;
    }

    .retreat-included {
        padding: 75px 0;
    }

    .retreat-included h2,
    .retreat-arranged h2 {
        margin-bottom: 42px;
    }

    .retreat-included__grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .retreat-included__item,
    .retreat-arranged__item {
        grid-template-columns: 72px 1fr;
        gap: 20px;
    }

    .retreat-arranged {
        padding: 70px 0 80px;
    }

    .retreat-arranged__grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .retreat-policy {
        padding: 75px 0;
    }

    .retreat-policy__grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .retreat-policy__item {
        padding: 32px 26px;
    }

    .retreat-application {
        grid-template-columns: 1fr;
        min-height: 560px;
    }

    .retreat-application__bg--left {
        display: none;
    }

    .retreat-application__button {
        width: calc(100% - 50px);
        max-width: 360px;
        padding: 0 22px;
    }

    .retreat-modal__dialog {
        width: calc(100% - 30px);
        max-height: calc(100vh - 40px);
        margin: 20px auto;
        padding: 38px 24px;
    }
    
    
}


body.retreat-modal-open {
    overflow: hidden;
}