.carrousel {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
}

.carrousel__viewport {
    position: absolute;
    width: 100%;
    height: 100%;
    overflow-x: scroll;
    top: 0;
    left: 0;
    z-index: 10;
}

.has-js .carrousel__viewport {
    overflow: hidden;
}

.carrousel__track {
    display: flex;
    white-space: nowrap;
    justify-content: flex-start;
    width: max-content; /* this doesn't grow to fit the children in iOS. So do it explicitly */
}

.carrousel__item {
    position: relative;
    overflow: hidden;
    display: flex;
    flex: 0 0 auto;
}

.carrousel__content-link {
    display: contents;
}

.carrousel__button {
    position: absolute;
    background: rgba(0,0,0,.65) none;
    width: 3rem;
    height: 0;
    padding: 3rem 0 0 0;
    font-size: 0; /* Fix to make Safari hide the button text correctly */
    overflow: hidden;
    top: 50%;
    margin-top: -1.5rem;
    border: 0;
    cursor: pointer;
    z-index: 500;
}

.carrousel__button svg {
    position: absolute;
    width: 1rem;
    height: 1rem;
    top: 50%;
    left: 50%;
    margin-top: -.5rem;
    margin-left: -.5rem;
}

.carrousel__button.carrousel__button--prev {
    left: 0;
}

.carrousel__button.carrousel__button--next {
    right: 0;
}

.carrousel__button.carrousel__button--next svg {
    transform: rotate(180deg);
}

.carrousel__button.carrousel__button--disabled {
    opacity: .5;
}

.carrousel__button.carrousel__button--hidden {
    display: none;
}

.carrousel--lightbox .carrousel__track {
    height: 100%;
}

.carrousel--lightbox .carrousel__item {
    width: calc(100vw - 2rem);
    flex: 0 0 calc(100vw - 2rem);
}

.carrousel--lightbox .carrousel__item-counter {
    font-size: .75rem;
    line-height: 1.5;
    position: absolute;
    top: 0;
    background-color: var(--greyColor60);
    color: var(--greyColor30);
    padding: .125rem .25rem;
    display: block;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
}

.carrousel--lightbox .carrousel__viewport {
    height: calc(100% - 4rem);
}

.carrousel--lightbox .carrousel__button {
    position: absolute;
    display: block;
    bottom: 0;
    top: auto;
    margin-top: 0;
}

.carrousel--lightbox .carrousel__item-current {
    color: var(--greyColor20);
}

.carrousel--lightbox .carrousel__item-total::before {
    content: ' / ';
}

@media only screen and (orientation: landscape), only screen and (min-width: 813px) {
    .carrousel--lightbox .carrousel__viewport {
        height: 100%;
        width: calc(100% - 8rem);
        left: 4rem;
        right: 4rem;
    }

    .carrousel--lightbox .carrousel__item {
        width: calc(100vw - 10rem);
        flex: 0 0 calc(100vw - 10rem);
    }

    .carrousel--lightbox .carrousel__button {
        top: 50%;
        margin-top: -1.5rem;
    }

    .carrousel--lightbox .carrousel__button.carrousel__button--next {
        right: 0;
    }
}

@media (min-width: 813px) {
    .carrousel--lightbox .carrousel__item-counter {
        font-size: 1.25rem;
        line-height: 1.2;
        padding: .25rem .5rem;
    }

    .carrousel--lightbox .carrousel__item {
        width: calc(100vw - 12rem);
        flex: 0 0 calc(100vw - 12rem);
    }
}

.carrousel.carrousel--listing-detail {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    z-index: 0;
}

.carrousel--listing-detail .carrousel__viewport {
    position: relative;
    height: 60vw;
}

.carrousel--listing-detail .carrousel__item {
    height: 60vw;
    max-width: 90vw;
    cursor: pointer;
}

.carrousel--listing-detail .picture--contain .picture__image {
    width: auto;
}

.carrousel--listing-detail .carrousel__button {
    display: none;
}

@media (min-width: 813px) {
    .carrousel--listing-detail .carrousel__viewport {
        height: 60vh;
    }

    .carrousel--listing-detail .carrousel__item {
        height: 60vh;
        max-width: none;
    }

    .carrousel--listing-detail .carrousel__button {
        display: block;
    }

    .carrousel--listing-detail .carrousel__button.carrousel__button--hidden {
        display: none;
    }

    .carrousel--listing-detail .carrousel__track {
        background-color: white;
    }
}

.carrousel--listings-carrousel .carrousel__item {
    flex: 0 0 18.75rem;
    margin-left: 1rem;
    align-items: start;
}

.carrousel--listings-carrousel .carrousel__item:first-child {
    margin-left: 0;
}

.carrousel__button {
    background-color: var(--primaryColor);
    border-radius: 50%;
    box-shadow:
        var(--boxShadow1),
        var(--boxShadow2)
    ;
}

.carrousel__button.carrousel__button--prev {
    left: .25rem;
}

.carrousel__button.carrousel__button--next {
    right: .25rem;
}

.carrousel__track {
    gap: 0 2rem;
}

.carrousel.carrousel--explore-cities {
    position: relative;
}

.carrousel.carrousel--explore-cities .carrousel__viewport {
    position: relative;
}

.carrousel.carrousel--explore-cities .carrousel__item {
    flex: 0 0 18.75rem;
    margin-left: 2rem;
    align-items: start;
}

.carrousel.carrousel--explore-cities .carrousel__item:first-child {
    margin-left: 0;
}

.carrousel--listing-detail .carrousel__button {
    display: block;
    background-color: var(--secondaryColor);
}

.carrousel--listing-detail .carrousel__button.carrousel__button--next {
    border-radius: 50%;
}

.carrousel--listing-detail .carrousel__button.carrousel__button--prev {
    border-radius: 50%;
}

.carrousel.carrousel--listings-carrousel {
    position: relative;
}

.carrousel--listings-carrousel .carrousel__item {
    flex: 0 0 auto;
    margin-left: 0;
    border-radius: .5rem;
    background: #FFFFFF;
    width: 16.25rem;
    line-height: 1.5rem;
}

.carrousel--listings-carrousel .carrousel__viewport {
    position: relative;
}

@media (min-width: 813px) {
    .carrousel--listings-carrousel .carrousel__item {
        width: 22.5rem;
    }
}
