
/* program_recreation styles
--------------------------------------------- */
.program_recreation {
    margin-top: 80px;
}

.program_recreation:first-child {
    margin-top: 80px;
}

.program_recreation .section__title {
    font-size: 60px;
    font-weight: 300;
    line-height: 1.2;
    letter-spacing: -0.9px;
    margin-bottom: 0;
}

.program_recreation .section__top {
    display: flex;
}

.program_recreation .section__top-left,
.program_recreation .section__top-right {
    width: 50%;
    min-width: 50%;
}

.program_recreation .section__top-left {
    padding-top: 40px;
}

.program_recreation .section__top-right {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.program_recreation .section__title-additional {
    font-family: Inter;
    font-size: 14px;
    line-height: 1.2142857143;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    color: #808284;
    max-width: 540px;
    margin-bottom: 16px;
}

.section__top-gallery {
    margin-top: 65px;
    margin-right: -28px;
    width:100%;
}

.section__top-gallery .swiper-slide {
    width: auto;             /* важное для auto-width */
}

.section__top-gallery img {
    height: 257px;
    width: auto;
    max-width: none;
    border-radius: 20px;      /* если нужно как на макете */
}



.hero + .program_recreation {
    margin-top: 32px;
}

.program_recreation__description {
    font-family: Inter;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    color: #808284;
    margin-top: 50px;
    padding-bottom: 10px;
}

.program_recreation__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    margin: 50px -8px 0;
}

.program_recreation__item {
    position: relative;
    width: 33.33%;
    min-width: 33.33%;
    padding-left: 8px;
    padding-right: 8px;
    margin-bottom: 16px;
}

.program_recreation__item-image img {
    display: block;
    width: 100%;
    border-radius: 24px;
}

.program_recreation__item-labels {
    position: absolute;
    left: 8px;
    top: 0;
    padding: 16px;
}

.program_recreation__item-label {
    display: inline-block;
    color: #FFF;
    font-family: Inter;
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    border-radius: 10em;
    padding: 8px 14px;
    background: rgba(0, 0, 0, 0.25);
    backdrop-filter: blur(10px) saturate(120%);
    -webkit-backdrop-filter: blur(10px) saturate(120%);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.25);
    margin-right: 4px;
}

.program_recreation__item-label--available::before {
    content: '';
    display: inline-block;
    width: 9px;
    height: 9px;
    background-color: #76DC7C;
    border-radius: 10em;
    margin-right: 6px;
}

.program_recreation__item-text {
    position: absolute;
    left: 8px;
    right: 8px;
    bottom: 0;
    padding: 80px 25px 35px 28px;
    border-radius: 0 0 24px 24px;
    background: linear-gradient(180deg, rgba(115, 115, 115, 0) 0%, rgba(115, 115, 115, 0.55) 100%);
    backdrop-filter: blur(10px);
    color: #F7F6F6;
    mask-image: linear-gradient(to top, black 0%, black 70%, rgba(0, 0, 0, 0) 100%);
    -webkit-mask-image: linear-gradient(to top, black 0%, black 70%, rgba(0, 0, 0, 0) 100%);
}

.program_recreation__item-title {
    font-size: 20px;
    line-height: 1.2;
    font-weight: 500;
    text-transform: uppercase;
    color: #F7F6F6;
    margin-bottom: 10px;
    position: relative;
}

.program_recreation__item-title::before {
    content: '';
    display: block;
    position: absolute;
    left: -28px;
    top: 2px;
    width: 6px;
    height: 100%;
    background-color: #E5B467;
}

.program_recreation__item-description {
    color: #F7F6F6;

    font-size: 13px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.195px;
    opacity: 0.75;
    max-width: 380px;
}

.program_recreation__cta .button__custom {
    width: 100%;
    height: 48px;
}

@media only screen and (min-width: 1200px) and (max-width: 1399px) {
    /**/
}

@media screen and (max-width: 1199px) {
    .program_recreation .section__title {
        font-size: 45px;
    }
}

@media screen and (max-width: 991px) {
    .program_recreation {
        margin-top: 40px;
        overflow: hidden;
    }
    .program_recreation:first-child {
        margin-top: 40px;
    }
    .program_recreation .section__title {
        font-size: 49px;
    }
    .program_recreation .section__top {
        display: block;
    }
    .program_recreation .section__title-additional {
        font-size: 18px;
        letter-spacing: 0.27px;
        max-width: none;
    }
    .program_recreation .section__top-left,
    .program_recreation .section__top-right {
        width: 100%;
    }
    .program_recreation .section__top-left {
        padding-top: 0;
    }

    .program_recreation .program_recreation__description {
        margin-top: 32px;
        font-size: 20px;
        padding-bottom: 0;
    }
    .program_recreation .program_recreation__description br {
        display: none;
    }
    .program_recreation__list {
        margin-top: 95px;
        overflow-x: auto;
        margin-right: -28px;
    }
    .program_recreation__item {
        width: 443px;
        min-width: 443px;
    }
    .program_recreation__item-title {
        font-size: 25px;
    }
    .program_recreation__item-description {
        font-size: 16px;
    }
    .program_recreation__item-image img {
        object-fit: cover;
        aspect-ratio: 427/581;
    }
    .program_recreation__cta {
        text-align: center;
    }
    .program_recreation__cta .button__custom {
        width: auto;
    }
}

@media screen and (max-width: 768px) {
    .program_recreation .section__title-additional {
        display: block;
    }
}

@media screen and (max-width: 767px) {
    /**/
}

@media screen and (max-width: 576px) {
    .program_recreation {
        margin-top: 40px;
    }
    .program_recreation:first-child {
        margin-top: 40px;
    }
    .program_recreation .section__title {
        font-size: 26px;
    }
    .program_recreation .section__title br {
        display: none;
    }
    .program_recreation .section__title-additional {
        font-size: 12px;
        margin-bottom: 0;
        margin-top: 16px;
    }
    .program_recreation .section__title-additional br {
        display: none;
    }
    .program_recreation .section__top-left {
        display: flex;
        flex-direction: column;
    }
    .program_recreation .section__top-left .section__title {
        order: -1;
    }
    /*
      .program_recreation .section__top-gallery {
        margin-top: 16px;
      }
      .program_recreation .section__top-image img {
        height: 269px;
        object-fit: cover;
        aspect-ratio: 269/283;
      }
        */
    .program_recreation .program_recreation__description {
        font-size: 12px;
        margin-top: 16px;
    }
    .program_recreation__list {
        margin-top: 64px;
    }
    .program_recreation__item-title {
        font-size: 20px;
    }
    .program_recreation__item-description {
        font-size: 12px;
    }
    .program_recreation__item {
        width: 300px;
        min-width: 300px;
    }
    .program_recreation__cta .button__custom {
        width: 100%;
    }
}
