:root {
    --green-light: #79de90;
    --green-light-rollover: #59c070;
    --green-dark: #0d4a34;
    --grey-light: #f6f6f6;
    --grey-dark: #333333;
    --yellow-medium: #ffc244;
    --yellow-medium-rollover: #f5b026;
    --ff-ernestandemily: 'DM Serif Display', serif;
}

@font-face {
    font-family: 'DM Serif Display';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/dmserifdisplay/v17/-nFnOHM81r4j6k0gjAW3mujVU2B2G_Bx0vrx52g.woff2) format('woff2');
}

*,
:after,
:before {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

img,
picture {
    display: block;
    max-width: 100%;
}

@media (prefers-reduced-motion:reduce) {

    *,
    :after,
    :before {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: .01ms !important;
    }
}

a {
    color: inherit;
}

.container {
    box-sizing: border-box;
    margin-left: auto;
    margin-right: auto;
    padding-left: 14px;
    padding-right: 14px;
    width: 100%;
}

@media (min-width:767px) {
    .container {
        padding-left: 30px;
        padding-right: 30px;
    }
}

@media (min-width:320px) {
    .container {
        max-width: 320px;
    }
}

@media (min-width:480px) {
    .container {
        max-width: 480px;
    }
}

@media (min-width:767px) {
    .container {
        max-width: 767px;
    }
}

@media (min-width:1023px) {
    .container {
        max-width: 1023px;
    }
}

@media (min-width:1410px) {
    .container {
        max-width: 1410px;
    }
}

p {
    margin-bottom: 2rem;
}

h2,
h3 {
    font-weight: 700;
}

h2,
h3 {
    color: var(--green-dark);
    line-height: 1.3;
    text-transform: uppercase;
}

@media (min-width:767px) {

    h2,
    h3 {
        line-height: 1.18;
    }
}

h2 {
    font-size: 22px;
    letter-spacing: 3px;
    line-height: 1.18;
    margin-bottom: 15px;
}

@media (min-width:767px) {
    h2 {
        font-size: 40px;
        letter-spacing: 5px;
    }
}

@media (min-width:1410px) {
    h2 {
        font-size: 44px;
    }
}

@media (min-width:1700px) {
    h2 {
        font-size: 5.2rem;
        letter-spacing: 6px;
    }
}

h3 {
    font-size: 24px;
    line-height: 1.3;
    margin-bottom: .5em;
}

@media (min-width:767px) {
    h3 {
        font-size: 36px;
    }
}

.preheading {
    color: #cb9275;
    font-display: swap;
    font-family: 'Wulkan Display Regular Italic', serif !important;
    font-size: 24px;
}

@media (min-width:767px) {
    .preheading {
        font-size: 3rem;
        line-height: 1;
    }
}

.nooverflow {
    overflow: hidden;
}

.swiper-slide {
    -webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0);
}

.pb-10 {
    padding-bottom: 10px;
}

@media (min-width:767px) {
    .pb-md-20 {
        padding-bottom: 20px;
    }
}

::placeholder {
    color: #aaa;
    opacity: 1;
}

.button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: 2px solid transparent;
    border-radius: 0;
    cursor: pointer;
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    padding: 12px 34px;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
    transition: color .08s ease-in-out, border-color .08s ease-in-out, background-color .08s ease-in-out;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    white-space: nowrap;
}

.button:disabled,
.button:disabled:hover {
    background-color: var(--grey-light-rollover);
    border-color: var(--grey-light-rollover);
    color: #fff;
}

.button--green-light {
    background-color: var(--green-light);
    border-color: var(--green-light);
    color: #fff;
}

.button--green-light:focus,
.button--green-light:hover {
    background-color: var(--green-light-rollover);
    border-color: var(--green-light-rollover);
}

@media (min-width:1023px) {
    .button {
        font-size: 14px;
    }
}

.card-slider {
    background-color: var(--grey-light);
    overflow: hidden;
    position: relative;
    z-index: 0;
}

.card-slider .container {
    display: flex;
    flex-direction: column;
}

.card-slider h2 {
    margin-bottom: .15em;
}

.card-slider .swiper-pagination {
    text-align: left;
    display: flex;
    gap: 8px;
    align-items: center;
}

.card-slider .swiper-pagination-bullet {
    width: 32px;
    height: 3px;
    background-color: #4b3a37 !important;
    opacity: 0.15;
    border-radius: 0;
    margin: 0 !important;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.card-slider .swiper-pagination-bullet-active {
    width: 64px;
    opacity: 1;
    background-color: #cb9275 !important;
}

@media (min-width:1023px) {
    .card-slider .container {
        flex-direction: row;
        align-items: flex-end;
    }
}

.card-slider__text {
    background-color: var(--grey-light);
    margin-bottom: 5px;
    position: relative;
    z-index: 1;
}

.card-slider__text .button {
    margin-bottom: 35px;
}

@media (min-width:1023px) {
    .card-slider__text {
        margin-bottom: 0;
        padding-right: 4rem;
        width: 38%;
        flex-shrink: 0;
        align-self: flex-end;
        padding-bottom: 100px;
    }

    .card-slider__text:not([class*=pt-]) {
        padding-top: 25px;
    }
}

.card-slider__card {
    border-radius: 4px;
    display: block;
    overflow: hidden;
    perspective: 1px;
    position: relative;
    width: 100%;
}

.card-slider__card img {
    transition: transform .2s;
    will-change: transform;
}

.card-slider__card .nooverflow {
    border-radius: 4px;
}

.card-slider__card .nooverflow:after {
    -webkit-backface-visibility: hidden;
    background: linear-gradient(180deg, transparent, #000);
    border-radius: 4px;
    bottom: 0;
    content: "";
    display: block;
    height: 115px;
    left: 0;
    position: absolute;
    -webkit-transform: translateZ(0);
    width: 100%;
    z-index: 0;
}

.card-slider__card:hover img {
    transform: scale(1.1);
}

.card-slider__card-title {
    -webkit-backface-visibility: hidden;
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .5));
    bottom: 0;
    padding: 30px 2rem;
    position: absolute;
    -webkit-transform: translateZ(0);
    width: 100%;
    z-index: 1;
}

.card-slider__card-title h3 {
    color: #fff;
    font-family: 'DM Serif Display', serif;
    font-size: 24px;
    font-weight: 400;
    letter-spacing: 2px;
    line-height: 1.2;
    margin-bottom: 0;
    text-transform: uppercase;
}

.gallery-swiper-wrapper {
    position: relative;
    width: calc(100% + 30px);
}

@media (min-width:1023px) {
    .gallery-swiper-wrapper {
        width: 2000px;
    }
}

@media (min-width:767px) {
    .card-slider .preheading {
        margin-bottom: 6px;
    }

    .card-slider__card {
        height: 540px;
        max-width: 330px;
    }

    .card-slider__card-title {
        padding: 30px;
    }

    .card-slider__card-title h3 {
        font-size: 24px;
    }
}

.swiper-card-item {
    width: 280px !important;
}

@media (min-width:767px) {
    .swiper-card-item {
        width: 330px !important;
    }
}

.swiper-cards-buttons {
    display: flex;
    flex-direction: column;
    gap: 15px;
    position: absolute;
    /* right: -30px; */
    top: 50%;
    transform: translateY(-50%);
    z-index: 100;
}

.swiper-cards-buttons .swiper-button {
    align-items: center;
    background-color: var(--green-light);
    border: 0 !important;
    border-radius: 50%;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
    cursor: pointer;
    display: flex;
    height: 60px;
    justify-content: center;
    margin-top: 0;
    outline: 0 !important;
    position: relative;
    top: auto;
    transition: all 0.3s ease;
    width: 60px;
}

.swiper-cards-buttons .swiper-button svg {
    height: 30px;
    width: 30px;
    fill: none;
    stroke: #000;
    stroke-width: 3px;
    position: relative;
}

.swiper-cards-buttons .swiper-button:hover {
    background-color: var(--green-light-rollover);
    transform: scale(1.05);
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
}

.swiper-cards-buttons .swiper-button:active {
    transform: scale(0.95);
}

.swiper-cards-buttons .swiper-button-prev {
    left: auto;
    margin-top: 2px;
    right: auto;
}

.swiper-cards-buttons .swiper-button-prev svg {
    left: -1px;
}

.swiper-cards-buttons .swiper-button-prev:after {
    display: none;
}

.swiper-cards-buttons .swiper-button-next {
    margin-bottom: 2px;
    right: auto;
}

.swiper-cards-buttons .swiper-button-next svg {
    right: 0;
}

.swiper-cards-buttons .swiper-button-next:after {
    display: none;
}

@media (min-width:767px) {
    .swiper-cards-buttons {
        /* right: -60px; */
        /* Offset outside the container if space permits */
    }
}

a {
    color: var(--grey-medium);
    text-decoration: none;
}

img {
    height: auto;
    max-width: 100%;
}

.container {
    margin-left: auto;
    margin-right: auto;
    max-width: var(--content-width);
    padding-left: 30px;
    padding-right: 30px;
}

.content-block {
    overflow: hidden;
    padding-bottom: 60px;
    padding-top: 60px;
}

@media (min-width:767px) {
    .content-block {
        padding-bottom: 80px;
        padding-top: 80px;
    }
}

@media (min-width:1023px) {
    .content-block {
        padding-bottom: 100px;
        padding-top: 100px;
    }
}

@media (min-width:1700px) {
    .content-block {
        padding-bottom: 140px;
        padding-top: 140px;
    }
}

/*! CSS Used from: Embedded */
.swiper-container {
    list-style: none;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    padding: 0;
    position: relative;
    z-index: 1;
}

.swiper-wrapper {
    box-sizing: content-box;
    display: flex;
    height: 100%;
    position: relative;
    transition-property: transform;
    width: 100%;
    z-index: 1;
}

.swiper-wrapper {
    transform: translateZ(0);
}

.swiper-slide {
    flex-shrink: 0;
    height: 100%;
    position: relative;
    transition-property: transform;
    width: 100%;
}

.swiper-button-next,
.swiper-button-prev {
    align-items: center;
    color: var(--swiper-navigation-color, var(--swiper-theme-color));
    cursor: pointer;
    display: flex;
    height: var(--swiper-navigation-size);
    justify-content: center;
    margin-top: calc(var(--swiper-navigation-size)*-1/2);
    position: absolute;
    top: 50%;
    width: calc(var(--swiper-navigation-size)/44*27);
    z-index: 10;
}

.swiper-button-next:after,
.swiper-button-prev:after {
    font-family: swiper-icons;
    font-size: var(--swiper-navigation-size);
    font-variant: normal;
    letter-spacing: 0;
    line-height: 1;
    text-transform: none !important;
    text-transform: none;
}

.swiper-button-prev {
    left: 10px;
    right: auto;
}

.swiper-button-prev:after {
    content: "prev";
}

.swiper-button-next {
    left: auto;
    right: 10px;
}

.swiper-button-next:after {
    content: "next";
}

.swiper-pagination {
    position: absolute;
    text-align: center;
    transform: translateZ(0);
    transition: opacity .3s;
    z-index: 10;
    margin-top: 32px !important;
}

.swiper-container-horizontal>.swiper-pagination-bullets {
    bottom: 10px;
    left: 0;
    width: 100%;
}

.swiper-pagination-bullet {
    background: #000;
    border-radius: 100%;
    display: inline-block;
    height: 8px;
    opacity: .2;
    width: 8px;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
    cursor: pointer;
}

.swiper-pagination-bullet-active {
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
    opacity: 1;
}

.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 4px;
}

.swiper-container .swiper-notification {
    left: 0;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    z-index: -1000;
}

.itinerary-card__info {
    /* display: none; */
}

@font-face {
    font-family: swiper-icons;
    font-style: normal;
    font-weight: 400;
    src: url("data:application/font-woff;charset=utf-8;base64, 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") format("woff");
}

/* Hide scrollbar for all browsers (Global) */
html,
body {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

html::-webkit-scrollbar,
body::-webkit-scrollbar {
    display: none;
}

/* Hide scrollbars for sliders and overflow containers */
body .swiper-container,
body .nooverflow,
body .gallery-swiper-wrapper {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

body .swiper-container::-webkit-scrollbar,
body .nooverflow::-webkit-scrollbar,
body .gallery-swiper-wrapper::-webkit-scrollbar {
    display: none;
}

/* Ensure new navigation is visible on top of everything */
.navigation {
    z-index: 100 !important;
}


.menu-mobile__logo {
    display: flex;
    align-items: center;
    position: relative;
    z-index: 10;
}

.menu-desktop__logo {
    display: flex;
    align-items: center;
    position: relative;
    z-index: 10;
    margin-top: -42px;
}

.logo {
    width: auto;
    height: 8rem;
    /* Refined from 12rem for better balance */
    max-width: 45rem;
    transition: all 0.3s ease-in-out;
    position: absolute;
    top: 50%;
    margin-top: 23px;
    left: 0;
    transform: translateY(-50%);
    /* Centered on the bar height */
}

/* Scrolled state refinement */
body.is-scrolled .logo {
    /* height: 7rem; */
    /* Slightly larger than the bar height on scroll */
    transform: translateY(-70%);
    margin-top: 78px;
}

/* Dual Logo Toggle */
.logo--scrolled {
    /* display: none; */
}

body.is-scrolled .logo--static {
    display: none;
}

body.is-scrolled .logo--scrolled {
    display: block;
    /* height: 70px; */
    width: auto;
    max-height: 162px;
}

/* Fix for Desktop Menu Overlays in Header Two */
.menu-desktop-overlay__list {
    flex-direction: column !important;
    align-items: flex-start !important;
    margin-top: 0 !important;
    padding-left: 0 !important;
    list-style: none !important;
}

/* Force vertical layout for all list items */
.menu-desktop-overlay__list .menu-desktop-overlay__list-item {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
}

.menu-desktop-overlay__link {
    /* color: #ffffff !important; */
    display: flex !important;
    align-items: center !important;
    /* padding: 0.8rem 0 !important; */
    text-decoration: none !important;
    width: 100% !important;
}

.menu-desktop-overlay__label-thumbnail {
    color: #4e3c38 !important;
    font-size: 1.2rem !important;
    font-weight: 500 !important;
}

.menu-desktop-overlay__image {
    display: none !important;
    /* Hide the large overlay images that might interfere with vertical layout if not needed */
}