/* Container fix */
.upsell-swiper {
    padding: 0 15px;
    width: 85%;
}

@media (min-width: 600px) {
    .upsell-swiper {
        width: 90%;
    }
}

@media (min-width: 992px) {
    .upsell-swiper {
        width: 100%;
    }
}

.custom-upsell-section {
    margin-top: 18px;
}

/* Prevent the third slide from being cut */
.custom-upsell-carousel-wrapper {
    position: relative;
    /*overflow: visible; !* changed from hidden to visible *!*/
    margin: 0 -15px;
}

/* Swiper slide spacing and layout */
.upsell-swiper .swiper-wrapper {
    box-sizing: border-box;

    /*overflow: visible;*/
}

.upsell-swiper .swiper-slide {
    box-sizing: border-box;
    background: #fff;
    border-radius: 5px;
    text-align: center;
    transition: box-shadow 0.3s;
}

/*REMOVE*/
.upsell-swiper .swiper-slide.upsell-card {
    position: relative; /* required for shadow */
    z-index: 1;
    box-shadow: 6px 4px 13px rgba(0, 0, 0, 0.13);
    transition: box-shadow 0.3s ease;
    margin-top: 10px; /* optional for visual spacing */
}
.custom-upsell-carousel-wrapper {
    position: relative;
    /*overflow: hidden; !* stays hidden *!*/
    /*padding: 0 16px; !* gives breathing room on sides *!*/
}
.upsell-swiper {
    padding-top: 10px;
    padding-bottom: 10px;
}

.custom-upsell-section .upsell-title-top {
    color: rgba(2, 77, 36, 1);
    font-size: 24px;
    width: 100%;
    text-align: center;
    font-family: "Open Sans", serif;
    margin-top: 60px;
    margin-bottom: 30px;
}

@media (min-width: 922px) {
    .custom-upsell-section .upsell-title-top {
        font-size: 32px;
        margin-bottom: 10px;
        margin-top: 0;
    }
}

.upsell-swiper .swiper-slide .upsell-image {
    position: relative;
}

.upsell-swiper .swiper-slide .upsell-image img {
    border-radius: 5px;
    max-height: 121px;
    object-fit: cover;
}

@media (min-width: 600px) {
    .upsell-swiper .swiper-slide .upsell-image img {
        max-height: 140px;
    }
}

@media (min-width: 922px) {
    .upsell-swiper .swiper-slide .upsell-image img {
        max-height: 172px;
    }
}

.upsell-swiper .swiper-slide .upsell-content {
    margin-top: 12px;
    padding: 20px;
}

@media (max-width: 1050px) {
    .upsell-swiper .swiper-slide .upsell-content {
        padding: 10px;
    }
}

@media (max-width: 921px) {
    .upsell-swiper .swiper-slide .upsell-content {
        margin-top: 12px;
        padding: 20px;
    }
}

.upsell-swiper .swiper-slide .upsell-title {
    font-size:13px;
    font-weight: 700;
    color: rgba(2, 77, 36, 1);
    font-family: Roboto, serif;
    text-align: center;
}

@media (min-width: 922px) {
    .upsell-swiper .swiper-slide .upsell-title {
        font-size: 20px;
    }
}

.upsell-swiper .swiper-slide .product-district {
    font-size: 13px;
    font-weight: 700;
    color: rgba(30, 41, 59, 1);
    font-family: Roboto, serif;
    /*margin-top: 5px;*/
    width: 100%;
    text-align: center;
}

@media (min-width: 922px) {
    .upsell-swiper .swiper-slide .product-district {
        font-size: 16px;
    }
}

.upsell-swiper .swiper-slide .other-information {
    display: flex;
    margin-top: 15px;
    align-items: center;
    flex-wrap: wrap;
}

.upsell-swiper .swiper-slide .other-information .divider {
    background: rgba(222, 222, 222, 1);
    width: 2px;
    height: 35px;
    display: none;
}

.upsell-swiper .swiper-slide .other-information .group,
.upsell-swiper .swiper-slide .other-information .area {
    font-size: 12px;
    font-weight: 700;
    color: rgba(30, 41, 59, 1);
    font-family: Roboto, serif;
    /*margin-top: 5px;*/
    text-align: center;
    width: 100%;
}

.upsell-swiper .swiper-slide .other-information .group {
    margin-top: 15px;
}

@media (min-width: 922px) {
    .upsell-swiper .swiper-slide .product-district,
    .upsell-swiper .swiper-slide .upsell-title {
        text-align: left;
    }

    .upsell-swiper .swiper-slide .other-information {
        flex-wrap: nowrap;
    }

    .upsell-swiper .swiper-slide .other-information .divider {
        display: block;
    }

    .upsell-swiper .swiper-slide .other-information .group,
    .upsell-swiper .swiper-slide .other-information .area {
        width: 50%;
        font-size: 15px;
    }

    .upsell-swiper .swiper-slide .other-information .group {
        margin-top: 0;
    }
}

.upsell-swiper .swiper-slide .other-information .group p,
.upsell-swiper .swiper-slide .other-information .area p {
    margin: 0;
}

.upsell-swiper .swiper-slide .upsell-image .upsell-price {
    position: absolute;
    right: 0;
    bottom: -15px;
    padding: 8px 5px;
    background: #07761C;
    color: #FFF;
    font-size: 10px;
    font-weight: 700;
    font-family: Roboto, serif;
    border-radius: 5px 0 0 5px;
}

@media (min-width: 922px) {
    .upsell-swiper .swiper-slide .upsell-image .upsell-price {
        font-size: 16px;
        padding: 10px;
    }
}


/* Buttons (for now - just styled squares with text) */
.swiper-button-prev,
.swiper-button-next {
    position: absolute;
    top: 57%;
    z-index: 10;
    color: #888888;
    cursor: pointer;
    user-select: none;
    transform: translateY(-50%);
}

.swiper-button-prev {
    left: 10px;
}

.swiper-button-next {
    right: 10px;
}

@media (min-width: 600px) {
    .swiper-button-prev {
        left: 10px;
    }
}

.swiper-button-next {
        right: 10px;
}

@media (min-width: 922px) {
    .swiper-button-prev {
        left: -30px;
    }

    .swiper-button-next {
        right: -30px;
    }
}

.upsell-card .reserve {
    z-index: 99;
    background: #07761C;
    color: #fff;
    height: 35px;
    width: 100px;
    max-width: 95%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    font-size: 12px;
    line-height: 24px;
    font-weight: 700;
    box-shadow: -2px 2px 4px 0 #00000040;
    font-family: Roboto, serif;

    top: 17px;
    right: initial;
    left: 0;
    border-radius: 0px 5px 5px 0px;
}

@media (min-width: 922px) {
    .upsell-card .reserve {
        font-size: 16px;
        height: 45px;
        width: 174px;
    }
}