#itinerary-for-cruise-section .btn-check:focus+.btn, .btn:focus {
    box-shadow: none;
}

#itinerary-for-cruise-section > .container-fluid {
    margin-bottom: 1.25rem;
    padding: 0;
    width: 90vw;
    margin: 0 auto 1.25rem;
}

#itinerary-for-cruise-section .itinerary-headline {
    font-weight: 420;
    font-size: var(--display-lg);
    line-height: var(--lh-display-lg);
    text-align: center; 
    margin-bottom: 2rem;
}

#itinerary-for-cruise-section .controls-container {
    padding-top: 5rem;
}

#itinerary-for-cruise-section .itinerary-for-cruise-controls {
    gap: 2rem;
}

/* #itinerary-for-cruise-section .itinerary-for-cruise-controls > * {
    margin: 0 .5rem;
}

#itinerary-for-cruise-section .itinerary-for-cruise-controls > *:first-child {
    margin-left: 0;
}

#itinerary-for-cruise-section .itinerary-for-cruise-controls > *:last-child {
    margin-right: 0;
} */

#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown {
    color: var(--azamara-blue);
    background-color: var(--light-dusk);
    text-decoration: none;
    padding: .375rem .5rem .375rem 1rem;
    font-weight: var(--wt-medium);
}

#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown .chevron-down-icon {
    font-size: var(--txt-lg);
    height: var(--txt-lg);
    width: var(--txt-lg);
    margin-left: .5rem;
    margin-bottom: .25rem;
    color: var(--azamara-blue);
    fill: var(--azamara-blue);
}
#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown::after {
    display: none;
}

#itinerary-for-cruise-section .itinerary-for-cruise-controls .dropdown-menu.show {
    max-height: 500px;
    overflow-y: auto;
    border-radius: .5rem;
}

/* body:has(.itinerary-for-cruise-controls .dropdown-menu.show)::before {
    content: '';
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: black;
    opacity: .7;
    z-index: 1000;
}

body:has(.itinerary-for-cruise-controls .dropdown-menu.show) {
    overflow: hidden;
} */

#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu span.day-desc {
    color: var(--night-sky);
    font-size: var(--txt-sm);
    font-weight: var(--wt-medium);
    text-transform: uppercase;
}

#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu span.port-name {
    display: none;
    margin-left: 0.625rem;
    font-size: var(--txt-md);
    font-weight: var(--wt-medium);
    color: var(--azamara-blue);
    text-transform: capitalize;
    letter-spacing: 0.3px;
}

#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu span.port-name-small {
    display: inline-block;
    margin-left: 0.625rem;
    font-weight: var(--wt-medium);
    color: var(--azamara-blue);
    text-transform: capitalize;
    letter-spacing: 0.3px;
}

#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu > * > button {
    padding: .625rem 1.5rem .625rem 1.25rem
}

/* #itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu > * > button:hover,
#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu > * > button:hover > span {
    color: var(--pure-white);
    background-color: var(--seafoam-green);
} */

#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu > * > button:active,
#itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu > * > button:active > span {
    color: var(--azamara-blue);
    background-color: var(--seafoam-aqua);
}
    

#itinerary-for-cruise-section button.carousel-control-prev, #itinerary-for-cruise-section button.carousel-control-next {
    position: static;
    transform: none;
    width: 2rem;
    height: 2rem;
    max-height: 2rem;
    max-width: 2rem;
}

#itinerary-for-cruise-section {
    background-color: var(--pure-white);
}

#itinerary-for-cruise-section .carousel-item .cruise-day-details {
    position: relative;
    box-shadow: var(--shadow);
    margin: -4rem auto 2rem;
    background-color: #fff;
}

/* disable previous button */
#itinerary-for-cruise-section:has(.carousel-item:first-child.active) button.carousel-control-prev {
    pointer-events: none;
    opacity: .5;
}

/* disable next button */
#itinerary-for-cruise-section:has(.carousel-item:last-child.active) button.carousel-control-next {
    pointer-events: none;
    opacity: .5;
}

/* Carousel slides */
#itinerary-for-cruise-section .carousel-item .image-col img {
    width: 100%;
    aspect-ratio: 2/1;
    object-fit: cover;
    object-position: center;
}

#itinerary-for-cruise-section .carousel-item .card-body {
    padding-bottom: 1.5rem;
    margin-bottom: .5rem;
}


#itinerary-for-cruise-section .carousel-item .card-body .port-timing-line {
    display: flex;
    justify-content: space-between;
}

/* Carousel text */
#itinerary-for-cruise-section .carousel-item .port-timing {
    color: var(--night-sky);
    font-size: var(--txt-md);
    font-style: normal;
    font-weight: 420;
    /* line-height: 24px; */
    letter-spacing: 0.8px;
    margin-bottom: 2rem;
}

#itinerary-for-cruise-section .carousel-item .port-timing > * {
    display: block;
}

#itinerary-for-cruise-section .carousel-item .port-timing .pipe {
    display: none;
    margin: 0 .5rem;
}

#itinerary-for-cruise-section .carousel-item .port-notice {
    display: flex;
    flex-direction: column;
    align-items: end;
    text-align: center;
}

#itinerary-for-cruise-section .carousel-item .port-notice .icon {
    font-size: 1.5rem;
    margin-bottom: .25rem;
    fill: var(--azamara-blue);
}


#itinerary-for-cruise-section .carousel-item .port-notice span {
    display: none;
}

#itinerary-for-cruise-section .carousel-item .port-headline {
    color: var(--azamara-blue);
    font-size: var(--display-sm);
    line-height: var(--lh-display-sm);
    font-weight: var(--wt-medium);
    letter-spacing: 0.9px;
    text-transform: capitalize;
    margin-bottom: .5rem;
}

#itinerary-for-cruise-section .carousel-item .port-description {
    font-size: var(--txt-md);
    font-style: normal;
    font-weight: var(--wt-regular);
    letter-spacing: 0.9px;
    color: black;
}

/* bottom part */

/* #itinerary-for-cruise-section .carousel-item hr {
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
} */

#itinerary-for-cruise-section .carousel-item .featured-excursions {
    display: block;
}

#itinerary-for-cruise-section .carousel-item .featured-card {
    align-self: center;
    padding: 1rem;
    background-color: var(--light-dusk);
    font-size: var(--txt-xs);
    text-align: center;
    font-weight: var(--wt-bold);
    line-height: var(--lh-txt-xs);
}

#itinerary-for-cruise-section .carousel-item .featured-card.featured-land-programs {
    background-color: var(--deep-dusk);
    color: var(--pure-white);
}

#itinerary-for-cruise-section .carousel-item .featured-card.featured-shore-ex {
    background-color: var(--deep-aqua);
    color: var(--pure-white);
}

#itinerary-for-cruise-section .carousel-item .card-programs {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: end;
    padding: 0;
}


#itinerary-for-cruise-section .carousel-item .excursion-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 0.625rem;
    padding: 0 1.5rem;
    margin: 1.5rem 0;
}

#itinerary-for-cruise-section .carousel-item .land-program-name,
#itinerary-for-cruise-section .carousel-item .shore-ex-name {
    color: var(--azamara-blue);
    font-size: var(--txt-md);
    font-weight: var(--wt-medium);
    /* line-height: var(--lh-display-lg); */
    letter-spacing: 0.9px;
    display: block;
    /* height: 2rem; */
    /* margin: .75rem 0; */
}

#itinerary-for-cruise-section .carousel-item .land-program-name:hover,
#itinerary-for-cruise-section .carousel-item .shore-ex-name:hover {
    color: var(--aqua);
}

#itinerary-for-cruise-section .carousel-item .view-all {
    color: var(--azamara-blue);
    text-align: right;
    flex: 1;
    font-size: var(--txt-sm);
    font-style: normal;
    font-weight: 420;
    line-height: 20px;
    letter-spacing: 0.7px;
    text-transform: uppercase;
    display: flex;
    align-self: end;
    justify-content: start;
    width: 100%;
    margin: 1.5rem 0;
    padding: 0 1.5rem;
}

#itinerary-for-cruise-section .carousel-item .view-all a {
    display: flex;
    align-items: center;
    gap: .5rem;
}

#itinerary-for-cruise-section .carousel-item .view-all a .icon {
    font-size: var(--txt-lg);
}


/* shorex modal css */

#itinerary-days-modal {
    /*    position: relative;*/
}

#itinerary-days-modal .modal-dialog {
    width: fit-content;
    position: relative;
}

#itinerary-days-modal .modal-body {
    background-color: #F8F8F8;

    border-radius: 6px;
    padding: 10px;

    word-break: break-all;
    overflow: visible;
}


#itinerary-days-modal ul.itinerary-carousel-slides {
    list-style-type: none;

    padding-left: 0;
}




.pdp-cruise .modal.shore-ex .modal-header {
    background: var(--deep-aqua);
    color: white;
    fill: white;
    gap: 0.375rem;

    border-bottom: none;
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;

    padding: 1.25rem 24px;
}

.pdp-cruise .modal.land-program .modal-header {
    background: var(--deep-dusk);
    color: white;
    fill: white;
    gap: 0.375rem;

    border-bottom: none;
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;

    padding: 1.25rem 24px;
}

.pdp-cruise .modal .modal-header svg {
    /*   font-size: var(--display-xs);
       height: 24px;
       width: 24px;*/
}

.pdp-cruise .modal.shore-ex .modal-header .modal-title, .pdp-cruise .modal.land-program .modal-header .modal-title {
    /* margin-left: 8px;
    margin-top: 6px; */

    font-size: var(--txt-lg);
    line-height: var(--lh-txt-lg);
    font-weight: var(--wt-bold);
}

.pdp-cruise .modal.shore-ex .modal-dialog, .pdp-cruise .modal.land-program .modal-dialog {
    /* max-width: 350px; */
    height: 600px;
}

.pdp-cruise .modal.shore-ex .modal-dialog .modal-body, .pdp-cruise .modal.land-program .modal-dialog .modal-body {
    display: inline-block;
    width: 100%;
    padding: 0;
}

.pdp-cruise .modal.shore-ex .modal-dialog .modal-body .card-body, .pdp-cruise .modal.land-program .modal-dialog .modal-body .card-body {
    padding: 1.875rem;
    position: relative;
}

.pdp-cruise .modal.shore-ex .modal-dialog .modal-body svg, .pdp-cruise .modal.land-program .modal-dialog .modal-body svg {
    fill: var(--azamara-blue);

    font-size: var(--display-xs);
    margin-bottom: 8px;
}

.pdp-cruise .modal .modal-dialog .modal-body .label {
    color: white;

    border-radius: 4px;
    padding: 4px 9px;
    margin-bottom: 30px;

    font-size: var(--txt-xs);
    text-transform: uppercase;

    width: fit-content;
}


.pdp-cruise .modal .modal-dialog .modal-body .label.shore-ex {
    background: var(--deep-aqua);
    font-weight: var(--wt-medium);
}

.pdp-cruise .modal .modal-dialog .modal-body .label.land-program {
    background: var(--deep-dusk);

}

.pdp-cruise .modal .modal-dialog .modal-body .headline {
    color: var(--azamara-blue);

    font-size: var(--display-xs);
    line-height: var(--lh-display-xs);
    font-weight: var(--wt-medium);

    margin-bottom: 8px;
}

.pdp-cruise .modal .modal-dialog .modal-body .blurb {
    color: black;

    font-size: var(--txt-md);
    font-weight: var(--wt-regular);

    margin-bottom: 8px;
}

.pdp-cruise .modal .modal-dialog .modal-body .split-group {
    color: var(--night-sky);

    font-size: var(--txt-lg);
    line-height: var(--lh-txt-lg);
    font-weight: var(--wt-medium);

    display: flex;
    justify-content: start;
    gap: .5rem;
    padding: 0 30px;
}

.pdp-cruise .modal .modal-dialog .modal-body .split-group .price {
    font-size: var(--txt-lg);
    line-height: var(--lh-txt-lg);
    font-weight: var(--wt-medium);
    color: var(--night-sky);
}

.pdp-cruise .modal.shore-ex .modal-dialog .image, .pdp-cruise .modal.land-program .modal-dialog .image {
    width: 100%;
    aspect-ratio: 2/1;
    position: relative;
}

.pdp-cruise .modal.shore-ex .modal-dialog img, .pdp-cruise .modal.land-program .modal-dialog img {
    aspect-ratio: 2/1;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pdp-cruise .modal .modal-body .loading-placeholder {
    width: 100%;
    padding: 3rem;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;

    color: var(--azamara-blue);
    fill: var(--azamare-blue);

    font-size: 18px;
    line-height: 28px;

    gap: 1rem;
}

/* SECTION: ONLY MOBILE MEDIA QUERY */
@media screen and (max-width: 991px) {
    #itinerary-for-cruise-section > .container-fluid {
        width: 280px;
    }
    #itinerary-for-cruise-section .cruise-day-details {
        width: 90vw;
    }
}
/* !SECTION */

/* SECTION: DESKTOP MEDIA QUERY */
@media (min-width: 992px) {

    #itinerary-for-cruise-section button.carousel-control-prev, #itinerary-for-cruise-section button.carousel-control-next {
        width: 3rem;
        height: 3rem;
        max-height: 3rem;
        max-width: 3rem;
    }

    .pdp-cruise .modal.shore-ex .modal-dialog, .pdp-cruise .modal.land-program .modal-dialog {
        max-width: 540px;
        height: 600px;
    }
}
/* !SECTION */

/* SECTION: MODAL */
.pdp-cruise .modal.shore-ex .btn-close svg, .pdp-cruise .modal.land-program .btn-close svg {
    margin: 2px 0 4px 6px;
    fill: white;

    /*   font-size: var(--txt-xl);
 height: 20px;*/
}

.pdp-cruise .modal.shore-ex .btn-close, .pdp-cruise .modal.land-program .btn-close span {
    color: white;

    font-size: var(--txt-sm);
    line-height: var(--lh-txt-sm);
}

.pdp-cruise .modal .modal-footer {
    justify-content: start;
    border-top: 0;
    padding: 1.5rem 30px 2rem;
}

.pdp-cruise .modal .modal-footer p {
    border: none;

    font-size: var(--txt-sm);
    font-weight: var(--wt-bold);
    font-style: italic;
    color: black;
    margin-left: 0;
}

@media screen and (min-width: 768px) {
    .pdp-cruise .itinerary-modal .modal-dialog .table-header {
        display: flex;
        justify-content: space-between;
        flex-direction: row;
        margin-bottom: 0;
    }

    .pdp-cruise .modal .modal-dialog .modal-body .headline {
        font-size: var(--display-sm);
        line-height: var(--lh-display-sm);
    }

    #itinerary-days-modal .modal-body {
        width: fit-content;
    }
}

@media screen and (min-width: 992px) {
    .pdp-cruise .product-hero .image-card-group {
        flex-direction: row;
    }

    #itinerary-for-cruise-section .carousel-item .cruise-day-details {
        display: flex;
        flex-direction: column;
    }

    #itinerary-for-cruise-section .carousel-item .card {
        box-shadow: var(--shadow);
    }

    #itinerary-for-cruise-section .carousel-item .card .card-body {
        padding: 24px 24px 24px 30px;
    }

    #itinerary-for-cruise-section .carousel-item .cruise-day-details {
        position: static;
        box-shadow: none;
        height: var(--card-height) !important;
        background-color: #fff;
        margin: 0;
    }

    #itinerary-for-cruise-section .carousel-item .image-col img {
        width: 100%;
        height: 100%;
    }

    #itinerary-for-cruise-section .itinerary-headline {
        margin-bottom: 0;
    }

    #itinerary-for-cruise-section .carousel-item .port-timing > * {
        display: inline-block !important;
        /* margin: 0 .5rem; */
    }

    #itinerary-for-cruise-section .carousel-item .port-notice {
        /* display: block; */
        /* position: absolute;
        top: 1.5rem;
        right: 1.5rem; */
        width: 110px;
        height: 74px;
    }

    #itinerary-for-cruise-section .carousel-item .port-notice span {
        display: block;
        color: var(--bs-black);
        text-align: center;
        font-size: var(--txt-sm);
        font-style: normal;
        font-weight: var(--wt-medium);
        line-height: var(--lh-txt-sm);
        letter-spacing: 0.7px;    
    }

    #itinerary-for-cruise-section .carousel-item .port-headline {
        font-size: var(--display-sm);
        line-height: var(--lh-display-sm);
        max-width: 82%;
    }

    #itinerary-for-cruise-section .carousel-item .port-description {
        font-size: var(--txt-lg);
        line-height: var(--lh-txt-ld);
        min-height: 8.75rem;
    }
    

    #itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu span.port-name {
        display: inline-block;
    }
    #itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown + .dropdown-menu span.port-name-small {
        display: none;
    }
    
    /* #itinerary-for-cruise-section .itinerary-for-cruise-controls button#itinerary-for-cruise-dropdown {
        margin-right: 1rem;
    } */

    #itinerary-for-cruise-section > .container-fluid {
        width: 100%;
        padding: 0 10%;
        margin-bottom: 0;
    }

    #itinerary-for-cruise-section .carousel-item {
        padding: 1.5rem 10% 5rem;
    }

    /* bottom part */
    #itinerary-for-cruise-section .carousel-item .card-programs {
        background-color: #fff;
    }


    /* #itinerary-for-cruise-section .carousel-item hr {
        position: static;
        width: 100%;
    } */

    #itinerary-for-cruise-section .carousel-item .featured-excursions {
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 1.5rem;
        margin: 0 1.5rem 1.5rem 30px;
        padding-top: 1.5rem;
        border-top: rgba(33, 37, 41, .25) 1px solid;
        }

    #itinerary-for-cruise-section .carousel-item .featured-card {
        margin-bottom: 0;
        width: 8.5rem;
        height: 6.5rem;
        display: flex;
        align-items: center;
        flex: 1;
        max-width: 8rem;
        border-radius: .5rem;
    }

    #itinerary-for-cruise-section .carousel-item .excursion-wrapper {
        width: 45%;
        padding: 0;
        margin: 0;
    }

    #itinerary-for-cruise-section .carousel-item .card-programs .land-program-name,
    #itinerary-for-cruise-section .carousel-item .card-programs .shore-ex-name {
        color: var(--azamara-blue);
        font-size: var(--txt-lg);
        font-weight: var(--wt-medium);
        letter-spacing: 0.2px;
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap;      
    }

    #itinerary-for-cruise-section .carousel-item .view-all {
        text-align: right;
        margin: 0;
        padding: 0;
        letter-spacing: 0.7px;
        display: flex;
        align-self: end;
        justify-content: end;
    }

    /* modal */
    #itinerary-days-modal .modal-dialog {
        position: absolute;
        top: 12rem;
        right: 24rem;
    }
}
/* !SECTION */