/*
 * blocks.css - Component styles for all block types.
 *
 * Loaded by both the CRM editor (base.html.twig) and the published site
 * (site-templates/layout.php). Copied to PUBLISH_PATH by PublishService::copyAssets().
 *
 * One section per block type, ordered alphabetically.
 * Add new block styles here - never inline in templates.
 */


/* ==========================================================================
   Shared Block Controls
   ========================================================================== */

.block-wrapper {
    width: 100%;
    padding: var(--section-padding) var(--page-gutter);
}

.block-content {
    display: block;
    width: 100%;
}

/* Block Animation */
.bws_animate {
    --bws-animation-offset: 28px;
    --bws-animation-duration: 620ms;
    --bws-animation-delay: 0ms;
    opacity: 0;
    transform: translate3d(0, var(--bws-animation-offset), 0);
    transition:
        opacity var(--bws-animation-duration) ease var(--bws-animation-delay),
        transform var(--bws-animation-duration) ease var(--bws-animation-delay);
    will-change: opacity, transform;
}

.bws_animate--fade-in {
    transform: none;
}

.bws_animate--fade-up {
    transform: translate3d(0, var(--bws-animation-offset), 0);
}

.bws_animate--fade-left {
    transform: translate3d(calc(var(--bws-animation-offset) * -1), 0, 0);
}

.bws_animate--fade-right {
    transform: translate3d(var(--bws-animation-offset), 0, 0);
}

.bws_animate.bws_is_visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

/* Block Width */
.block-wrapper.block-width--narrow > .block-content {
    max-width: var(--block-width-narrow, 800px);
    margin-inline: auto;
}

.block-wrapper.block-width--contained > .block-content {
    max-width: var(--block-width-contained, 1200px);
    margin-inline: auto;
}

.block-wrapper.block-width--full > .block-content {
    max-width: none;
}

/* Block Alignment */
.block-wrapper.block-align--left {
    text-align: left;
    justify-content: start;
}

.block-wrapper.block-align--center {
    text-align: center;
    justify-content: center;
}

.block-wrapper.block-align--right {
    text-align: right;
    justify-content: end;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.block-buttons {
    padding: 32px 0;
}

.block-buttons__list {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.block-buttons--align-center .block-buttons__list {
    justify-content: center;
}

.block-buttons--align-right .block-buttons__list {
    justify-content: flex-end;
}

.block-buttons__list > .bvj-block,
.block-buttons__list > .block-button-item,
.block-buttons__list > .block-buttons__insert,
.block-buttons__list > .block-buttons__placeholder {
    display: inline-flex;
    max-width: 100%;
}

.block-buttons__insert,
.block-buttons__placeholder,
.block-button-item {
    min-width: 0;
}

.block-button-item__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.block-button-item__link--plain {
    color: var(--section-button-background);
    font-size: var(--font-size-button);
    line-height: var(--line-height-normal);
    text-decoration: underline;
    text-underline-offset: 0.18em;
}

.block-button-item__link--plain:hover {
    color: var(--section-button-hover-background);
}

.block-text__content p {
    text-wrap: balance;
}


/* ==========================================================================
   Split Feature
   ========================================================================== */

.block-split-feature {
    display: grid;
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    min-height: var(--split-feature-min-height, 650px);
    padding: 0;
    overflow: hidden;
}

.root-canvas > .block-split-feature {
    padding-inline: 0;
}

.block-split-feature--image-right {
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
}

.block-split-feature--image-right .block-split-feature__media {
    order: 2;
}

.block-split-feature__media {
    min-width: 0;
    min-height: 420px;
    background: color-mix(in srgb, var(--feature-background) 70%, transparent);
}

.block-split-feature__image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.block-split-feature__placeholder {
    width: 100%;
    height: 100%;
    min-height: inherit;
}

.block-split-feature__panel {
    display: flex;
    align-items: center;
    min-width: 0;
    padding: clamp(48px, 7vw, 105px);
}

.block-split-feature__content {
    width: min(100%, 560px);
}

.block-split-feature__eyebrow {
    margin: 0 0 14px;
    color: var(--section-link-colour);
    font-size: var(--font-size-sm, .875rem);
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.block-split-feature__heading {
    margin: 0;
    color: var(--section-heading-colour);
    font-family: var(--font-heading);
    font-size: clamp(2.5rem, 5vw, 4.6rem);
    font-weight: 400;
    line-height: 1.05;
    text-wrap: balance;
}

.block-split-feature__text {
    margin: 24px 0 0;
    color: var(--section-text-colour);
}

.block-split-feature__link {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    margin-top: 27px;
    color: var(--section-link-colour);
    font-size: var(--font-size-button);
    font-weight: 700;
    letter-spacing: .1em;
    text-decoration: none;
    text-transform: uppercase;
}

.block-split-feature__link svg {
    width: 18px;
    height: 18px;
    transition: transform var(--transition-fast, .15s ease);
}

.block-split-feature__link:hover svg {
    transform: translateX(4px);
}


/* ==========================================================================
   Columns
   ========================================================================== */

.block-columns {
    padding: 32px 0;
}

.block-columns__grid {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
}

.block-columns__grid > .block-column,
.block-columns__grid > .bvj-block {
    flex: 0 0 calc(var(--column-width, 100) * 1%);
    max-width: calc(var(--column-width, 100) * 1%);
    min-width: 0;
    box-sizing: border-box;
}

.block-column {
    padding: 12px;
}

.block-column__inner {
    width: 100%;
    height: 100%;
}


/* ==========================================================================
   Google Map
   ========================================================================== */

.block-google-map {
    padding: 32px 0;
}

.block-google-map__content {
    display: grid;
    gap: 16px;
}

.block-google-map__frame-wrap {
    position: relative;
    min-height: 240px;
    height: var(--map-height, 360px);
    overflow: hidden;
    background: color-mix(in srgb, var(--feature-background) 70%, transparent);
}

.block-google-map__frame {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
}

.block-google-map__directions {
    justify-self: start;
}

.block-google-map__placeholder {
    display: grid;
    place-items: center;
    min-height: 180px;
    padding: 24px;
    border: 1px dashed color-mix(in srgb, var(--main-border-subtle) 30%, transparent);
    border-radius: var(--border-radius-lg);
    color: var(--main-text-colour);
    background: color-mix(in srgb, var(--feature-background) 48%, transparent);
}


/* ==========================================================================
   Content Query
   ========================================================================== */

.block-content-query {
    padding: 32px 0;
}

.block-content-query__content {
    max-width: var(--block-width-contained, 1200px);
    margin-inline: auto;
}

.block-content-query__list {
    margin: 0;
    padding-inline-start: 1.2rem;
    list-style-type: none;
}

.root-canvas .block-content-query__list-item {
    font-size: 1.3rem;
}
.block-content-query__list-item + .block-content-query__list-item {
    margin-top: .5rem;
}

.block-content-query__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.block-content-query__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.block-content-query__cards {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    display: grid;
    gap: 16px;
}

.block-content-query--content-carousel .block-content-query__cards {
    grid-auto-columns: clamp(240px, 32vw, 360px);
    grid-auto-flow: column;
    grid-template-columns: none;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    padding-block-end: 12px;
    scroll-padding-inline: 4px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}

.block-content-query--content-carousel .block-content-query__card {
    min-width: 0;
    scroll-snap-align: start;
}

.block-content-query__card {
    display: grid;
    overflow: hidden;
    color: inherit;
    text-decoration: none;
    transition:
        transform var(--transition-fast, 0.15s ease),
        border-color var(--transition-fast, 0.15s ease),
        box-shadow var(--transition-fast, 0.15s ease);
}

.block-content-query__card:hover,
.block-content-query__card:focus-visible {

}

.block-content-query__card-media {
    aspect-ratio: 16 / 10;
    background: color-mix(in srgb, var(--section-accent) 22%, transparent);
}

.block-content-query__card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.block-content-query__card-body {
    display: grid;
    gap: 10px;
    padding: 18px 0;
}

.block-content-query__card-title {
    color: var(--section-heading-colour);
    font-family: var(--font-heading);
    line-height: 1.2;
    font-size: 1.8rem;
    font-weight: 400;
}

.block-content-query__card-summary {
    color: var(--section-text-colour);
}

.block-content-query__card-field {
    display: grid;
    gap: 2px;
    margin: 0;
    color: var(--section-text-colour);
}

.block-content-query__card-field-label {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
}

.block-content-query__empty {
    margin: 0;
    color: var(--section-text-colour);
}

.block-content-query__empty--hint {
    font-style: italic;
}


/* ==========================================================================
   Events
   ========================================================================== */

.block-events {
    padding: 56px var(--page-gutter, 24px);
}

.block-events__content {
    margin-inline: auto;
}

.block-events__list {
    display: grid;
    gap: 28px;
}

.block-event-item {
    display: grid;
    grid-template-columns: minmax(260px, .42fr) minmax(0, 1fr);
    gap: 28px;
    align-items: start;
    padding: 24px 0;
    border-top: 1px solid color-mix(in srgb, var(--section-text-colour) 16%, transparent);
}

.block-event-item__media {
    min-width: 0;
}

.block-event-item__image,
.block-event-item__image-placeholder {
    width: 100%;
    aspect-ratio: 4 / 3;
}

.block-event-item__image {
    display: block;
    height: auto;
    object-fit: cover;
}

.block-event-item__image-placeholder {
    display: grid;
    place-items: center;
    border: 1px dashed color-mix(in srgb, var(--section-text-colour) 28%, transparent);
    color: var(--section-text-colour);
}

.block-event-item__body {
    display: grid;
    gap: 18px;
}

.block-event-item__header {
    display: grid;
    gap: 6px;
}

.block-event-item__date {
    color: color-mix(in srgb, var(--section-text-colour) 68%, transparent);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.3;
    text-transform: uppercase;
}

.block-events--expired-mute .block-event-item--expired {
    opacity: .48;
}

.block-events--expired-mute .block-event-item--expired .block-event-item__image {
    filter: grayscale(1);
}

.root-canvas h3.block-event-item__title,
.block-event-item__description {
    margin: 0;
}


/* ==========================================================================
   Form
   ========================================================================== */

.block-form {
    padding: 56px var(--page-gutter, 24px);
}

.block-form__content {
    margin-inline: auto;
}

.block-form__header {
    display: grid;
    gap: 10px;
    margin-block-end: 24px;
}

.root-canvas .block-form__heading,
.block-form__intro {
    margin: 0;
}

.block-form__form,
.block-form__fields {
    display: grid;
    gap: 18px;
}

.block-form-field {
    display: grid;
    gap: 8px;
}

.block-form-field__label,
.block-form-field__checkbox {
    color: var(--section-text-colour);
    font-size: .95rem;
    font-weight: 700;
    line-height: 1.35;
}

.block-form-field__required {
    color: var(--section-button-background);
    margin-inline-start: 4px;
}

.block-form-field__control {
    width: 100%;
    min-height: 48px;
    border: 1px solid color-mix(in srgb, var(--section-text-colour) 22%, transparent);
    border-radius: 4px;
    background: var(--section-background);
    color: var(--section-text-colour);
    font: inherit;
    line-height: 1.4;
    padding: 12px 14px;
}

textarea.block-form-field__control {
    min-height: 132px;
    resize: vertical;
}

.block-form-field__control:focus {
    border-color: var(--section-button-background);
    outline: 2px solid color-mix(in srgb, var(--section-button-background) 20%, transparent);
    outline-offset: 2px;
}

.block-form-field__checkbox {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.block-form-field__checkbox-input {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    margin-block-start: .15em;
    accent-color: var(--section-button-background);
}

.block-form__actions {
    margin-block-start: 6px;
}

.block-form__submit {
    cursor: pointer;
}

.block-form__submit:disabled {
    cursor: wait;
    opacity: .72;
}

.block-form__result {
    display: grid;
    gap: 16px;
    justify-items: center;
    max-width: 560px;
    margin-inline: auto;
    padding-block: 24px;
    text-align: center;
}

.root-canvas .block-form__result h2,
.block-form__result p {
    margin: 0;
}

/* Gift card checkout */
.block-gift-card-checkout {
    color: var(--section-text-colour, var(--main-text-colour));
}

.block-gift-card-checkout__card {
    display: grid;
    gap: var(--space-lg, 32px);
    padding: clamp(24px, 5vw, 44px);
    border: 1px solid color-mix(in srgb, var(--section-text-colour, currentColor) 16%, transparent);
    border-radius: var(--border-radius-lg, 14px);
    background: var(--feature-background, #fcf9ee);
    box-shadow: 0 24px 80px color-mix(in srgb, var(--main-shadow-colour, #000) 18%, transparent);
}

.block-gift-card-checkout__header {
    display: grid;
    gap: var(--space-xs, 8px);
}

.block-gift-card-checkout__eyebrow {
    font-size: var(--font-size-xs, .75rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--main-link-colour, #895700);
}

.block-gift-card-checkout__title {
    margin: 0;
    color: var(--main-heading-colour, #20211f);
    font-family: var(--font-heading, inherit);
    font-size: clamp(2rem, 8vw, 4rem);
    line-height: 1;
}

.block-gift-card-checkout__intro {
    margin: 0;
    max-width: 62ch;
}

.block-gift-card-checkout__form {
    display: grid;
    gap: var(--space-md, 20px);
}

.block-gift-card-checkout__amounts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-xs, 8px);
}

.block-gift-card-checkout__amount input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.block-gift-card-checkout__amount span {
    display: grid;
    min-height: 58px;
    place-items: center;
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    border-radius: var(--border-radius-sm, 4px);
    background: var(--main-background, #fff);
    color: var(--main-heading-colour, #20211f);
    font-size: var(--font-size-lg, 1.375rem);
    font-weight: 800;
    cursor: pointer;
}

.block-gift-card-checkout__amount input:checked + span {
    border-color: var(--main-brand, #2a3f3f);
    background: color-mix(in srgb, var(--main-brand, #2a3f3f) 12%, #fff);
}

.block-gift-card-checkout__fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-sm, 12px);
}

.block-gift-card-checkout__field {
    display: grid;
    gap: 6px;
}

.block-gift-card-checkout__label {
    font-weight: 700;
}

.block-gift-card-checkout__input {
    width: 100%;
    min-height: 46px;
    padding: 10px 12px;
    border: 1px solid color-mix(in srgb, currentColor 22%, transparent);
    border-radius: var(--border-radius-sm, 4px);
    background: #fff;
    color: var(--main-text-colour, #20211f);
    font: inherit;
}

.block-gift-card-checkout__button {
    justify-self: start;
    min-height: 48px;
    padding: 0 20px;
    border: 0;
    border-radius: var(--border-radius-sm, 4px);
    background: var(--button-background, var(--main-brand, #2a3f3f));
    color: var(--button-text-colour, #fff);
    font: inherit;
    font-weight: 800;
    cursor: pointer;
}

.block-gift-card-checkout__button:disabled {
    cursor: wait;
    opacity: .72;
}

.block-gift-card-checkout__message {
    padding: 12px 14px;
    border-radius: var(--border-radius-sm, 4px);
    background: #fff3f1;
    color: #8d1f12;
    font-weight: 700;
}

@media (max-width: 700px) {
    .block-gift-card-checkout__amounts,
    .block-gift-card-checkout__fields {
        grid-template-columns: 1fr;
    }
}

/* Gift card checkout return */
.block-gift-card-return {
    color: var(--section-text-colour, var(--main-text-colour));
}

.block-gift-card-return__card {
    display: grid;
    gap: var(--space-lg, 32px);
    padding: clamp(24px, 5vw, 44px);
    border: 1px solid color-mix(in srgb, var(--section-text-colour, currentColor) 16%, transparent);
    border-radius: var(--border-radius-lg, 14px);
    background: var(--feature-background, #fcf9ee);
    box-shadow: 0 24px 80px color-mix(in srgb, var(--main-shadow-colour, #000) 18%, transparent);
}

.block-gift-card-return__header,
.block-gift-card-return__state {
    display: grid;
    gap: var(--space-sm, 12px);
}

.block-gift-card-return__eyebrow {
    font-size: var(--font-size-xs, .75rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--main-link-colour, #895700);
}

.block-gift-card-return__title {
    margin: 0;
    color: var(--main-heading-colour, #20211f);
    font-family: var(--font-heading, inherit);
    font-size: clamp(2rem, 8vw, 4rem);
    line-height: 1;
}

.block-gift-card-return__intro,
.block-gift-card-return__state p,
.block-gift-card-return__error p {
    margin: 0;
}

.block-gift-card-return__status {
    display: inline-flex;
    width: fit-content;
    padding: 8px 12px;
    border-radius: var(--border-radius-sm, 4px);
    background: color-mix(in srgb, var(--main-brand, #2a3f3f) 12%, transparent);
    color: var(--main-heading-colour, #20211f);
    font-weight: 700;
}

.block-gift-card-return__loading {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-radius: var(--border-radius-sm, 4px);
    background: color-mix(in srgb, var(--main-brand, #2a3f3f) 12%, transparent);
    color: var(--main-heading-colour, #20211f);
    font-weight: 700;
}

.block-gift-card-return__loader {
    width: 20px;
    height: 20px;
    animation: gift-card-return-spin 900ms linear infinite;
}

@keyframes gift-card-return-spin {
    to {
        transform: rotate(360deg);
    }
}

.block-gift-card-return__details {
    display: grid;
    gap: var(--space-sm, 12px);
    margin: 0;
    padding: 14px;
    border-radius: var(--border-radius-sm, 4px);
    background: #fff;
}

.block-gift-card-return__details div {
    display: grid;
    gap: 4px;
}

.block-gift-card-return__details dt {
    font-size: var(--font-size-xs, .75rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: color-mix(in srgb, currentColor 62%, transparent);
}

.block-gift-card-return__details dd {
    margin: 0;
    font-weight: 700;
}

.block-gift-card-return__button {
    justify-self: start;
    min-height: 44px;
    padding: 0 16px;
    border: 0;
    border-radius: var(--border-radius-sm, 4px);
    background: var(--button-background, var(--main-brand, #2a3f3f));
    color: var(--button-text-colour, #fff);
    font: inherit;
    font-weight: 800;
    cursor: pointer;
}

/* Gift card voucher */
.block-gift-card-voucher {
    color: var(--section-text-colour, var(--main-text-colour));
}

.block-gift-card-voucher__card {
    display: grid;
    gap: var(--space-lg, 32px);
    padding: clamp(24px, 5vw, 44px);
    border: 1px solid color-mix(in srgb, var(--section-text-colour, currentColor) 16%, transparent);
    border-radius: var(--border-radius-lg, 14px);
    background: var(--feature-background, #fcf9ee);
    box-shadow: 0 24px 80px color-mix(in srgb, var(--main-shadow-colour, #000) 18%, transparent);
}

.block-gift-card-voucher__header {
    display: grid;
    gap: var(--space-xs, 8px);
}

.block-gift-card-voucher__eyebrow {
    font-size: var(--font-size-xs, .75rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--main-link-colour, #895700);
}

.block-gift-card-voucher__title {
    margin: 0;
    color: var(--main-heading-colour, #20211f);
    font-family: var(--font-heading, inherit);
    font-size: clamp(2rem, 8vw, 4rem);
    line-height: 1;
}

.block-gift-card-voucher__intro {
    margin: 0;
    max-width: 60ch;
}

.block-gift-card-voucher__state {
    display: grid;
    gap: var(--space-md, 20px);
}

.block-gift-card-voucher__body {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(180px, 240px);
    gap: var(--space-lg, 32px);
    align-items: center;
}

.block-gift-card-voucher__status {
    display: inline-flex;
    width: fit-content;
    padding: 8px 12px;
    border-radius: var(--border-radius-sm, 4px);
    background: color-mix(in srgb, var(--main-brand, #2a3f3f) 12%, transparent);
    color: var(--main-heading-colour, #20211f);
    font-weight: 700;
}

.block-gift-card-voucher__state.is-spent .block-gift-card-voucher__status {
    background: color-mix(in srgb, var(--colour-warning, #fee193) 34%, transparent);
}

.block-gift-card-voucher__amount {
    display: block;
    margin-bottom: var(--space-md, 20px);
    color: var(--main-heading-colour, #20211f);
    font-family: var(--font-heading, inherit);
    font-size: clamp(2rem, 7vw, 3.5rem);
    line-height: 1;
}

.block-gift-card-voucher__details {
    display: grid;
    gap: var(--space-sm, 12px);
    margin: 0;
}

.block-gift-card-voucher__details div {
    display: grid;
    gap: 4px;
}

.block-gift-card-voucher__details dt {
    font-size: var(--font-size-xs, .75rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: color-mix(in srgb, currentColor 62%, transparent);
}

.block-gift-card-voucher__details dd {
    margin: 0;
    font-weight: 700;
}

.block-gift-card-voucher__code {
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
    letter-spacing: .05em;
}

.block-gift-card-voucher__qr {
    padding: 14px;
    border-radius: var(--border-radius-md, 8px);
    background: #fff;
}

.block-gift-card-voucher__qr svg,
.block-gift-card-voucher__qr img {
    display: block;
    width: 100%;
    height: auto;
}

.block-gift-card-voucher__error h2 {
    margin: 0;
    color: var(--main-heading-colour, #20211f);
    font-size: var(--font-size-lg, 1.375rem);
}

@media (max-width: 680px) {
    .block-gift-card-voucher__body {
        grid-template-columns: 1fr;
    }

    .block-gift-card-voucher__qr {
        max-width: 240px;
    }
}


/* ==========================================================================
   Accommodation
   ========================================================================== */

.block-accommodation-rooms {
    padding: 56px var(--page-gutter, 24px);
}

.block-accommodation-rooms__content {
    margin-inline: auto;
}

.block-accommodation-rooms__list {
    display: grid;
    gap: 28px;
}

.block-room-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 28px;
    align-items: start;
    padding: 24px 0;
    border-top: 1px solid color-mix(in srgb, var(--section-text-colour) 16%, transparent);
}

.block-room-item__media {
    min-width: 0;
}

.block-room-item__image-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-template-rows: repeat(2, minmax(0, 1fr));
    gap: 8px;
    aspect-ratio: 2 / 1;
}

.block-room-item__image-tile {
    position: relative;
    display: block;
    overflow: hidden;
    min-width: 0;
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: color-mix(in srgb, var(--section-accent) 20%, transparent);
    cursor: pointer;
}

.block-room-item__image-tile--feature {
    grid-column: span 2;
    grid-row: span 2;
}

.block-room-item__image-tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform var(--transition-fast, .15s ease);
}

.block-room-item__image-tile:hover img,
.block-room-item__image-tile:focus-visible img {
    transform: scale(1.03);
}

.block-room-item__image-tile:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--section-button-background) 48%, transparent);
    outline-offset: 2px;
}

.block-room-item__image-overlay {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 12px;
    background: color-mix(in srgb, var(--colour-black) 54%, transparent);
    color: var(--colour-white);
    font-weight: 700;
    text-align: center;
}

.block-room-item__image-placeholder {
    display: grid;
    place-items: center;
    aspect-ratio: 2 / 1;
    border: 1px dashed color-mix(in srgb, var(--section-text-colour) 28%, transparent);
    color: var(--section-text-colour);
}

.block-room-item__body {
    display: grid;
    gap: 40px;
}

.block-room-item__header {
    display: grid;
    gap: 0px;
}

.root-canvas h3.block-room-item__title,
.block-room-item__beds,
.block-room-item__description,
.block-room-item__facts {
    margin: 0;
}

.block-room-item__beds {
    color: color-mix(in srgb, var(--section-text-colour) 68%, transparent);
    font-size: .92rem;
    line-height: 1.3;
}

.block-room-item__about strong,
.block-room-item__facilities strong {
    color: var(--section-text-colour);
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
}

.block-room-item__booking {
    justify-self: start;
}

.block-room-item__about {
    display: grid;
    gap: 10px;
}

.block-room-item__facilities {
    display: grid;
    gap: 10px;
}

.block-room-item__facility-list {
    display: grid;
    gap: 9px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.block-room-item__facility-list li {
    display: grid;
    grid-template-columns: 20px minmax(0, 1fr);
    gap: 8px;
    align-items: start;
}

.block-room-item__facility-list svg {
    width: 20px;
    height: 20px;
    color: var(--section-button-background);
}

.site-gallery-viewer {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: block;
    padding: 0;
    overflow: hidden;
    background: var(--colour-black);
    color: var(--colour-white);
    isolation: isolate;
}

.site-gallery-viewer[hidden] {
    display: none;
}

.site-gallery-viewer__bar {
    position: absolute;
    inset: 0 0 auto;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    min-height: 68px;
    padding: 12px 18px;
    background: linear-gradient(to bottom, color-mix(in srgb, var(--colour-black) 65%, transparent), transparent);
    pointer-events: none;
}

.site-gallery-viewer__close,
.site-gallery-viewer__nav {
    display: inline-grid;
    place-items: center;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: color-mix(in srgb, var(--main-heading-colour) 78%, transparent);
    color: var(--colour-white);
    cursor: pointer;
    pointer-events: auto;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    transition: background-color var(--transition-fast, .15s ease), transform var(--transition-fast, .15s ease);
}

.site-gallery-viewer__close:hover,
.site-gallery-viewer__nav:hover {
    background: color-mix(in srgb, var(--main-text-colour) 92%, transparent);
}

.site-gallery-viewer__close:focus-visible,
.site-gallery-viewer__nav:focus-visible,
.site-gallery-viewer__thumb:focus-visible {
    outline: 2px solid var(--colour-white);
    outline-offset: 3px;
}

.site-gallery-viewer__close svg,
.site-gallery-viewer__nav svg {
    width: 24px;
    height: 24px;
}

.site-gallery-viewer__close {
    width: 44px;
    height: 44px;
}

.site-gallery-viewer__stage {
    position: relative;
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    min-width: 0;
    min-height: 0;
    padding: 5px;
    overflow: hidden;
}

.site-gallery-viewer__image {
    display: block;
    width: 100%;
    height: 100%;
    min-width: 0;
    min-height: 0;
    object-fit: contain;
}

.site-gallery-viewer__nav {
    position: absolute;
    top: 50%;
    z-index: 2;
    width: 48px;
    height: 48px;
    transform: translateY(-50%);
}

.site-gallery-viewer__nav--prev {
    left: 18px;
}

.site-gallery-viewer__nav--next {
    right: 18px;
}

.site-gallery-viewer__thumbs {
    position: absolute;
    bottom: 14px;
    left: 50%;
    z-index: 3;
    display: flex;
    gap: 6px;
    max-width: calc(100% - 32px);
    overflow-x: auto;
    padding: 7px;
    border-radius: 10px;
    background: color-mix(in srgb, var(--main-heading-colour) 78%, transparent);
    scrollbar-width: thin;
    transform: translateX(-50%);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
}

.site-gallery-viewer__thumb {
    flex: 0 0 58px;
    width: 58px;
    height: 44px;
    padding: 0;
    border: 2px solid transparent;
    border-radius: 6px;
    overflow: hidden;
    background: var(--main-heading-colour);
    cursor: pointer;
    opacity: .62;
    transition: border-color var(--transition-fast, .15s ease), opacity var(--transition-fast, .15s ease);
}

.site-gallery-viewer__thumb.is-active {
    border-color: var(--colour-white);
    opacity: 1;
}

.site-gallery-viewer__thumb:hover {
    opacity: 1;
}

.site-gallery-viewer__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.site-gallery-viewer--single .site-gallery-viewer__nav,
.site-gallery-viewer--single .site-gallery-viewer__thumbs {
    display: none;
}

body.site-gallery-open {
    overflow: hidden;
}

@container root-canvas (max-width: 900px) {
    .block-room-item {
        grid-template-columns: 1fr;
    }
}


/* ==========================================================================
   Hero
   ========================================================================== */

.block-hero {
    --hero-height: 75dvh;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 150px clamp(20px, 7vw, 110px) clamp(70px, 10vw, 120px);
    min-height: min(800px, 88dvh);
    height: var(--hero-height);
    color: var(--section-text-colour);
    background: var(--section-background);
    text-align: center;
    overflow: hidden;
    isolation: isolate;
}

.block-hero--auto-height {
    height: auto;
    min-height: 0;
}

.root-canvas .block-hero {
    color: var(--section-text-colour);
    background-color: var(--section-background);
}

.root-canvas .site-header--floating + .site-main > .block-hero {
    padding-top: 150px;
}

.block-hero--has-media {
    color: var(--section-text-colour);
}

.block-hero__media,
.block-hero__scrim {
    position: absolute;
    inset: 0;
}

.block-hero__media {
    z-index: 0;
}

.block-hero__scrim {
    --hero-overlay-opacity: 0.4;
    z-index: 1;
    background: linear-gradient(180deg, color-mix(in srgb, var(--colour-hero-scrim) 18%, transparent), color-mix(in srgb, var(--colour-hero-scrim) 58%, transparent));
    opacity: var(--hero-overlay-opacity);
}

.block-hero__image,
.block-hero__video {
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    inset: 0;
    object-fit: cover;
}

.block-hero__inner {
    width: min(710px, 100%);
    position: relative;
    z-index: 2;
}

.block-hero--vertical-top { align-items: flex-start; }
.block-hero--vertical-center { align-items: center; }
.block-hero--vertical-bottom { align-items: flex-end; }

.root-canvas .block-hero__eyebrow {
    max-width: 760px;
    margin: 0 0 14px;
    color: var(--section-eyebrow-colour);
    font-family: Arial, Helvetica, sans-serif;
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
}

.root-canvas .block-hero .block-hero__heading {
    margin: 0;
    line-height: 1.04;
    letter-spacing: -.045em;
}

.root-canvas .block-hero__subheading {
    max-width: 600px;
    margin: 24px 0 0;
    color: color-mix(in srgb, var(--section-text-colour) 90%, transparent);
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(1rem, 1.7vw, 1.2rem);
    opacity: 1;
}

.block-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    width: 100%;
    max-width: 760px;
    margin-top: 32px;
}

.block-hero__actions > .bvj-block,
.block-hero__actions > .block-button-item,
.block-hero__actions > .bvj-insert,
.block-hero__actions > .bvj-empty-placeholder {
    flex: 0 0 auto;
}

.block-hero--horizontal-center .block-hero__eyebrow,
.block-hero--horizontal-center .block-hero__heading,
.block-hero--horizontal-center .block-hero__subheading,
.block-hero--horizontal-center .block-hero__actions {
    margin-inline: auto;
}

.block-hero--horizontal-center .block-hero__actions {
    justify-content: center;
}

.block-hero--horizontal-right .block-hero__eyebrow,
.block-hero--horizontal-right .block-hero__heading,
.block-hero--horizontal-right .block-hero__subheading,
.block-hero--horizontal-right .block-hero__actions {
    margin-left: auto;
}

.block-hero--horizontal-right .block-hero__actions {
    justify-content: flex-end;
}

.root-canvas .block-hero.block-wrapper .block-hero__actions .block-button-item__link.button,
.root-canvas .block-hero.block-wrapper .block-hero__actions .block-button-item__link.button-lite {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 12px 22px;
    border: 1px solid var(--section-button-background);
    border-radius: 999px;
    box-shadow: none;
    color: var(--section-button-colour);
    background-color: var(--section-button-background);
    font-family: Arial, Helvetica, sans-serif;
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .08em;
    line-height: 1.2;
    text-decoration: none;
    text-transform: uppercase;
    transition: transform .2s ease, background-color .2s ease;
}

.root-canvas .block-hero.block-wrapper .block-hero__actions .block-button-item__link.button:hover {
    color: var(--section-button-colour);
    background-color: var(--section-button-hover-background);
    transform: translateY(-2px);
}

.root-canvas .block-hero.block-wrapper .block-hero__actions .block-button-item__link.button-lite {
    border-color: color-mix(in srgb, var(--section-button-colour) 66%, transparent);
    color: var(--section-button-colour);
    background-color: color-mix(in srgb, var(--section-button-colour) 10%, transparent);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

.root-canvas .block-hero.block-wrapper .block-hero__actions .block-button-item__link.button-lite:hover {
    color: var(--section-button-colour);
    background-color: color-mix(in srgb, var(--section-button-colour) 20%, transparent);
    transform: translateY(-2px);
}

@media (max-width: 680px) {
    .block-hero:not(.block-hero--auto-height) {
        min-height: 760px;
        padding: 130px 20px 70px;
    }

    .block-hero--auto-height {
        padding: 130px 20px 70px;
    }

    .root-canvas .site-header--floating + .site-main > .block-hero {
        padding-top: 130px;
    }

    .root-canvas .block-hero .block-hero__heading {
        font-size: clamp(3rem, 14vw, 3.4rem);
        overflow-wrap: anywhere;
    }

    .block-hero__actions {
        align-items: flex-start;
        flex-direction: column;
    }

    .block-hero__actions .button,
    .block-hero__actions .button-lite {
        max-width: 100%;
    }
}


/* ==========================================================================
   Heading
   ========================================================================== */

.block-heading {
    padding: 12px 0;
    margin: 0;
    color: var(--section-heading-colour);
    font-family: var(--font-heading);
    line-height: 1.15;
}

.bws_letter-reveal.bws_animate,
.bws_letter-reveal.bws_animate.bws_is_visible {
    opacity: 1;
    transform: none;
    transition: none;
}

.bws_letter-reveal__content {
    display: block;
    text-wrap: balance;
}

.bws_letter-reveal__word {
    display: inline-block;
    line-height: inherit;
    white-space: nowrap;
}

.bws_letter-reveal__mask {
    display: inline-block;
    overflow: hidden;
    line-height: inherit;
    vertical-align: bottom;
}

.bws_letter-reveal__letter {
    display: inline-block;
    line-height: inherit;
    opacity: 0;
    transform: none;
    transition:
        opacity 940ms cubic-bezier(.16, .72, .18, 1) calc(var(--letter-line-index, var(--letter-index)) * 58ms),
        transform 940ms cubic-bezier(.16, .72, .18, 1) calc(var(--letter-line-index, var(--letter-index)) * 58ms);
    will-change: opacity, transform;
}

.bws_letter-reveal--letter-reveal .bws_letter-reveal__letter {
    transform: scale(.96);
}

.bws_letter-reveal--letter-reveal-up .bws_letter-reveal__letter {
    transform: translate3d(0, 1.08em, 0);
}

.bws_letter-reveal--letter-reveal-left .bws_letter-reveal__letter {
    transform: translate3d(-.34em, 0, 0);
}

.bws_letter-reveal--letter-reveal-right .bws_letter-reveal__letter {
    transform: translate3d(.34em, 0, 0);
}

.bws_letter-reveal.bws_is_visible .bws_letter-reveal__letter {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}



/* ==========================================================================
   Image
   ========================================================================== */

.block-image__inner {
    width: 100%;
}
.block-image__inner img {
    display: block;
    width: 100%;
    height: auto;
}


/* ==========================================================================
   Menu Item
   ========================================================================== */

.restaurant-menu-tabs.block-tabs {
    --restaurant-menu-background: var(--section-background);
    --restaurant-menu-action: var(--section-button-background);
    --restaurant-menu-text: var(--section-text-colour);
    width: min(900px, calc(100% - 48px));
    max-width: 900px;
    margin: 48px auto 80px;
    padding: 0;
    color: var(--restaurant-menu-text);
    background: var(--restaurant-menu-background);
}

.restaurant-menu-tabs .block-tabs__tablist {
    position: sticky;
    top: 0;
    z-index: 30;
    flex-wrap: nowrap;
    gap: 16px;
    margin-bottom: 0;
    padding: 18px 20px;
    overflow-x: auto;
    background: var(--site-header-translucent-background);
    scrollbar-width: thin;
    -webkit-backdrop-filter: blur(6px) saturate(110%);
    backdrop-filter: blur(6px) saturate(110%);
    transition: top 0.28s ease;
}

.root-canvas:has(.site-header--floating:not(.site-header--static):not(.is-scroll-hidden)) .restaurant-menu-tabs .block-tabs__tablist {
    top: var(--floating-header-clearance);
}

.restaurant-menu-tabs .block-tabs__trigger {
    white-space: nowrap;
}

.restaurant-menu-tabs .block-tab-item {
    padding: 0;
}

.restaurant-menu-tabs .block-tabs__panels {
    background: var(--restaurant-menu-background);
}

.restaurant-menu-tabs .block-tab-item__content {
    padding: 34px clamp(24px, 7vw, 70px) 64px;
}

.restaurant-menu-tabs .block-heading {
    margin: 34px 0 10px;
    padding: 0;
    color: var(--restaurant-menu-action);
    font-family: Georgia, "Times New Roman", serif;
    font-weight: 500;
    line-height: 1.1;
}

.restaurant-menu-tabs h2.block-heading {
    font-size: 42px;
}

.restaurant-menu-tabs h3.block-heading {
    font-size: 29px;
}

.restaurant-menu-tabs h4.block-heading {
    font-size: 20px;
}

.restaurant-menu-tabs .block-tab-item__content > .block-heading:first-child,
.restaurant-menu-tabs .block-tab-item__content > .bvj-block:first-child > .block-heading {
    margin-top: 0;
    font-size: 42px;
    text-align: center;
}

.restaurant-menu-tabs .block-text {
    padding: 0;
}

.restaurant-menu-tabs .block-text__content {
    color: color-mix(in srgb, var(--restaurant-menu-text) 75%, transparent);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    line-height: 1.55;
}

.restaurant-menu-tabs .block-text__content p {
    margin: 2px 0 9px;
}

.block-menu-item__content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 4px 24px;
    align-items: start;
    padding: 13px 0;
}

.restaurant-menu-tabs .block-menu-item__content {
    border-bottom: 1px solid color-mix(in srgb, var(--restaurant-menu-action) 10%, transparent);
}

.root-canvas .menu_item {
    padding: 0;
}

.root-canvas .block-menu-item__title,
.root-canvas .block-menu-item__price {
    margin: 0;
    color: var(--section-heading-colour);
    font-family: var(--font-heading);
    font-weight: 400;
    line-height: 1.2;
}

.root-canvas .restaurant-menu-tabs .block-menu-item__title,
.root-canvas .restaurant-menu-tabs .block-menu-item__price {
    color: var(--restaurant-menu-action);
    font-family: Georgia, "Times New Roman", serif;
    font-size: 18px;
    line-height: 1.25;
}

.block-menu-item__title {
    min-width: 0;
}

.block-menu-item__price {
    white-space: nowrap;
    text-align: right;
}

.block-menu-item__desc {
    grid-column: 1 / -1;
    color: var(--section-text-colour);
    font-size: var(--font-size-sm, 0.875rem);
    line-height: 1.5;
}

.restaurant-menu-tabs .block-menu-item__desc {
    color: color-mix(in srgb, var(--restaurant-menu-text) 72%, transparent);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
}

.block-menu-item__desc--empty {
    height: 0;
    overflow: hidden;
    line-height: 0;
}

.block-menu-item__desc span {
    display: inline-block;
}

@container root-canvas (max-width: 640px) {
    .restaurant-menu-tabs.block-tabs {
        width: 100%;
        margin-block: 0;
    }

    .restaurant-menu-tabs .block-tabs__tablist {
        justify-content: flex-start;
        padding-inline: 0;
    }

    .restaurant-menu-tabs .block-tab-item__content {
        padding-inline: 22px;
    }

    .restaurant-menu-tabs .block-tab-item__content > .block-heading:first-child,
    .restaurant-menu-tabs .block-tab-item__content > .bvj-block:first-child > .block-heading {
        font-size: 34px;
    }

    .root-canvas .restaurant-menu-tabs .block-menu-item__title,
    .root-canvas .restaurant-menu-tabs .block-menu-item__price {
        font-size: 16px;
    }
}

/* ==========================================================================
   Parallax Image
   ========================================================================== */
.block-parallax-image {
    padding: 0;
}
.bws_parallax-image {
    background-size: auto 120vh;
    background-size: auto 120lvh;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    height: 60vh;
    height: 60lvh;
    overflow: hidden;
}
@media only screen and (min-width: 768px) {
    .bws_parallax-image {
        background-size: auto 120vh;
        background-size: auto 120lvh;
    }
}
@media only screen and (min-width: 1000px) {
    .bws_parallax-image {
        background-size: cover;
        height: 70vh;
        height: 70lvh;
    }
}
/* CSS specific to non iOS devices */
@supports not (-webkit-touch-callout: none) {
    .bws_parallax-image {
        -webkit-background-attachment: fixed;
        background-attachment: fixed;
    }
}
/* CSS specific to iOS devices */
@supports (-webkit-touch-callout: none) {
    @media only screen and (max-width: 1023px) {
        .bws_parallax-image {
            -webkit-background-attachment: fixed;
            background-size: auto 80vh;
            background-size: auto 80lvh;
        }
    }
}

/* ==========================================================================
   Section
   ========================================================================== */

.block-section--padding-none   { padding: 0; }
.block-section--padding-small  { padding: 24px 0; }
.block-section--padding-medium { padding: 60px 0; }
.block-section--padding-large  { padding: 100px 0; }


/* ==========================================================================
   Tab Item
   ========================================================================== */

.block-tab-item {
    width: 100%;
    height: 100dvh;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(10px);
    transition:
        opacity 250ms ease,
        transform 250ms ease,
        visibility 0s linear 250ms;
}

.block-tab-item.is-active {
    height: auto;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    transition-delay: 250ms;
}

.block-tab-item__content {
    padding: 40px 0;
}


/* ==========================================================================
   Tabs
   ========================================================================== */

.block-tabs {
    padding: 32px 0;
}

.block-tabs__tablist {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-sm, 12px);
    padding-bottom: var(--space-md, 20px);
    margin-bottom: var(--space-md, 20px);
}

.block-tabs--align-left .block-tabs__tablist {
    justify-content: flex-start;
}

.block-tabs--align-center .block-tabs__tablist {
    justify-content: center;
}

.block-tabs--align-right .block-tabs__tablist {
    justify-content: flex-end;
}

.block-tabs--align-stretch .block-tabs__tablist {
    align-items: stretch;
}

.block-tabs--align-stretch .block-tabs__tab-entry {
    flex: 1 1 180px;
}

.block-tabs__trigger {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: var(--border-radius-md);
    background: transparent;
    box-shadow: 0 0 0 1px var(--section-button-background);
    color: var(--section-button-background);
    cursor: pointer;
    font-weight: 600;
    padding: 0.7rem 1rem;
    transition:
        color var(--transition-fast, 0.15s ease),
        background var(--transition-fast, 0.15s ease);
}

.block-tabs--align-stretch .block-tabs__trigger {
    width: 100%;
}

.block-tabs__trigger:hover,
.block-tabs__trigger:focus-visible {
    background: color-mix(in srgb, var(--section-accent) 35%, transparent);
    color: var(--section-heading-colour);
    outline: none;
}

.block-tabs__trigger.is-active {
    background: var(--section-brand);
    color: var(--section-button-colour);
}

.block-tabs__tab-entry {
    display: inline-flex;
    min-width: 0;
}

.block-tabs__panels {
    position: relative;
}

.block-tabs__panels > .block-tab-item,
.block-tabs__panels > .bvj-block {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    width: 100%;
}

.block-tabs__panels > .block-tab-item.is-active,
.block-tabs__panels > .bvj-block.is-active {
    position: relative;
    z-index: 1;
}

@media (prefers-reduced-motion: reduce) {
    .block-tab-item,
    .block-tab-item.is-active {
        transition: none;
        transform: none;
    }
}

@media (max-width: 640px) {
    .bws_animate--stacked-up.bws_animate--fade-left,
    .bws_animate--stacked-up.bws_animate--fade-right {
        transform: translate3d(0, var(--bws-animation-offset), 0);
    }
}

@container root-canvas (max-width: 640px) {
    .bws_animate--stacked-up.bws_animate--fade-left,
    .bws_animate--stacked-up.bws_animate--fade-right {
        transform: translate3d(0, var(--bws-animation-offset), 0);
    }

    .block-content-query__buttons {
        flex-direction: column;
    }

    .block-content-query__button {
        width: 100%;
    }

    .block-event-item {
        grid-template-columns: 1fr;
    }

    .block-room-item {
        grid-template-columns: 1fr;
    }

    .block-room-item__image-grid {
        display: flex;
        gap: 10px;
        overflow-x: auto;
        aspect-ratio: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .block-room-item__image-grid::-webkit-scrollbar {
        display: none;
    }

    .block-room-item__image-tile,
    .block-room-item__image-tile--feature {
        flex: 0 0 100%;
        grid-column: auto;
        grid-row: auto;
        aspect-ratio: 4 / 3;
        scroll-snap-align: start;
        cursor: default;
        background: transparent;
    }

    .block-room-item__image-tile img {
        width: 100%;
        height: 100%;
        object-fit: contain;
        transform: none;
    }

    .block-room-item__image-tile:hover img,
    .block-room-item__image-tile:focus-visible img {
        transform: none;
    }

    .block-room-item__image-overlay {
        display: none;
    }

    .site-gallery-viewer {
        padding: 12px;
    }

    .site-gallery-viewer__nav {
        width: 38px;
        height: 48px;
    }

    .block-columns {
        padding: 24px 0;
    }

    .block-split-feature,
    .block-split-feature--image-right {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .block-split-feature--image-right .block-split-feature__media {
        order: initial;
    }

    .block-split-feature__media {
        min-height: 350px;
    }

    .block-split-feature__panel {
        padding: 48px var(--page-gutter);
    }

    .block-columns__grid > .block-column,
    .block-columns__grid > .bvj-block {
        flex-basis: 100%;
        max-width: 100%;
    }

    .block-tabs {
        padding: 24px 0;
    }

    .block-tabs__tablist {
        gap: var(--space-xs, 8px);
    }

    .block-tabs__trigger {
        width: 100%;
        justify-content: flex-start;
        text-align: left;
    }

    .block-tabs__tab-entry {
      /*  width: 100%; */
    }
}

@media (prefers-reduced-motion: reduce) {
    .bws_animate,
    .bws_animate.bws_is_visible,
    .bws_animate--fade-in,
    .bws_animate--fade-up,
    .bws_animate--fade-left,
    .bws_animate--fade-right,
    .bws_animate--stacked-up.bws_animate--fade-left,
    .bws_animate--stacked-up.bws_animate--fade-right,
    .bws_letter-reveal__letter {
        opacity: 1;
        transform: none;
        transition: none;
        will-change: auto;
    }
}


/* ==========================================================================
   Text
   ========================================================================== */

.block-text {
    padding: 24px 0;
}

.block-text--size-small .block-text__content { font-size: .9rem; }
.block-text--size-medium .block-text__content { font-size: 1rem; }
.block-text--size-large .block-text__content { font-size: 1.2rem; }

.block-text__content > * + * { margin-top: .8em; }

.block-list {
    padding: 12px 0;
}

.block-list--align-left { text-align: left; }
.block-list--align-center { text-align: center; }
.block-list--align-right { text-align: right; }

.block-list--narrow .block-list__content { max-width: 480px; }
.block-list--medium .block-list__content { max-width: 720px; }
.block-list--wide .block-list__content { max-width: 960px; }
.block-list--full .block-list__content { max-width: none; }
.block-list--align-center .block-list__content { margin-inline: auto; }

.block-list__content {
    margin-block: 0;
    padding-inline-start: 1.4em;
}

.block-list__content li + li {
    margin-top: .35em;
}


/* ==========================================================================
   Spacer
   ========================================================================== */

.block-spacer {
    width: 100%;
    pointer-events: none;
}


/* ==========================================================================
   Sliding Titles
   ========================================================================== */

.block-sliding-titles {
    padding-top: 100px;
    padding-bottom: 0;
}
.block-sliding-titles h3 {
    font-size: 9.5cqw;
    outline: none;
}
@container root-canvas (min-width: 550px) {
    .block-sliding-titles h3 {
        font-size: 7.5cqw;
    }
}
@container root-canvas (min-width: 821px) {
    .block-sliding-titles h3 {
        font-size: 4cqw;
    }
}
.block-sliding-titles .bws_h-scroll-container {
    overflow: hidden;
    width: 100%;
    position: relative;
}
.block-sliding-titles .bws_h-scroll-element {
    width: calc(100% - 4cqw);
    transition: all 0.3s linear;
    text-align: center;
}
.block-sliding-titles .bws_h-scroll-element.reverse {
    padding-left: 4cqw;
}
