
main {
    background: linear-gradient(180deg, #1F1612 50%, #513728 100%);
    padding: 80px 0 160px;
}

.wrapper {
    max-width: 1200px;
    padding: 0 10px;
    margin: 0 auto;
}

/* Banner */
.banner {
    border-radius: 40px;
    background: url(../img/banner.jpg) center / cover no-repeat;
    overflow: hidden;
}

.banner-info {
    display: flex;
    flex-direction: column;
    gap: 14px;
    max-width: 600px;
    padding: 98px 0 108px 104px;
}

.banner__title {
    font: 600 64px/110% var(--font-harmonia);
    color: #ffffff;
    margin: 0;
}

.banner__subtitle {
    font: 600 24px/120% var(--font-harmonia);
    color: #ffffff;
    margin: 0;
}

/* Categories */
.promo-categories {
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin: 45px 0 60px;
}

.promo-categories__title {
    font: 700 40px/120% var(--font-harmonia);
    text-align: center;
    color: #ffffff;
    margin: 0;
}

.promo-categories-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;

    list-style: none;
    padding: 0;
    margin: 0;
}

.promo-category {
    display: flex;
    flex-direction: column;
    gap: 24px;
    text-decoration: none;
    background: rgb(255 255 255 / 20%);
    border-radius: 8px;
    padding: 16px 16px 28px;
}

.promo-category__img {
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 10px;
    background: url(../img/bg-porduct.png) center / cover no-repeat;
    width: 100%;
    height: 147px;
}

.promo-category__title {
    display: flex;
    align-items: center;
    min-height: 44px;
    font: 600 18px/22px var(--font-harmonia);
    color: #ffffff;
    margin: 0;
}

.promo-category__link {
    display: block;
    text-align: center;
    width: 100%;
    font: 600 18px / 120% var(--font-harmonia);
    text-decoration: none;
    background-color: #1F1612;
    border-radius: 10px;
    color: #ffffff;
    padding: 16px 0 19px;
    margin: auto 0 0;
}

.promo-category__link:hover {
    background-color: #442e22;
}

/* Custom TWS */
.custom-tws {
    position: relative;
    border-radius: 40px;
    background-color: rgb(255 255 255 / 20%);
    padding: 66px 0 68px;
}

.custom-tws::before {
    position: absolute;
    content: '';
    top: -81px;
    right: -27px;
    width: 790px;
    height: 410px;
    background: url(../img/custom-tws.png) right center / contain no-repeat;
}

.custom-tws-info {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-width: 410px;
    padding: 0 0 0 125px;
}

.custom-tws-info__title {
    font: 700 30px/36px var(--font-harmonia);
    color: #ffffff;
    margin: 0;
}

.custom-tws-info__link {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 280px;
    font: 600 18px/1 var(--font-harmonia);
    text-decoration: none;
    color: #ffffff;
    background-color: #1F1612;
    border: 1px solid #1F1612;
    cursor: pointer;
    border-radius: 10px;
    padding: 17px 0 20px;
    margin: 13px 0 0 0;
}

.custom-tws-info__link:hover {
    background-color: #442e22;
    border-color: #442e22;
}

/* Selections */

.selection-categories {
    display: flex;
    flex-direction: column;
    gap: 60px;
    margin: 68px 0 0 0;
}

.selection-category {
    display: flex;
    flex-direction: column;
    gap: 35px;
}

/* Selction Heading */
.selection-category-heading {
    display: flex;
    align-items: center;
}

.selection-category-heading__icon {
    width: 40px;
    height: 40px;
    fill: #ffffff
}

.selection-category-heading__title {
    font: 700 40px/1 var(--font-harmonia);
    text-align: center;
    color: #ffffff;
    margin: 0 auto;
}

/* Selection Product */

.selection-category-products-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 12px 20px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.selection-category-product {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    max-width: 380px;
    gap: 6px;
    border-radius: 8px;
    background-color: rgba(255, 255, 255, 0.2);
}

.selection-category-product-info {
    display: flex;
    flex-direction: column;
    gap: 10px;
    height: 100%;
    padding: 16px;
}

.selection-category-product__img {
    flex-shrink: 0;
    position: relative;
    background-color: #ffffff;
    border-radius: 8px;
    overflow: hidden;
}

.selection-category-product__img img {
    display: block;
    max-height: 220px;
    margin: 0 auto;
}

.selection-category-product-heading {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.selection-category-product__title {
    font: 600 18px/21px var(--font-harmonia);
    color: #ffffff;
    margin: 0;
}

.selection-category-product__price {
    font: 600 18px/1 var(--font-harmonia);
    text-align: right;
    color: #ffffff;
    margin: 0;
}

.selection-category-product__descr {
    font: 400 16px/18px var(--font-harmonia);
    color: #ffffff;
    margin: 0;
}

.selection-category-product__buy {
    font-family: var(--font-harmonia);
    display: flex;
    justify-content: center;
    align-items: center;
    font: 600 18px/1 var(--font-harmonia);
    text-decoration: none;
    border-radius: 10px;
    border: 2px solid #1F1612;
    background-color: #1F1612;
    color: #ffffff;
    cursor: pointer;
    padding: 18px 0 20px;
    margin: auto 0 0 0;
}

.selection-category-product__link {
    display: flex;
    justify-content: center;
    align-items: center;
    font: 600 18px/1 var(--font-harmonia);
    border: 2px solid #ffffff;
    text-decoration: none;
    border-radius: 10px;
    color: #ffffff;
    padding: 18px 0 20px;
}

.selection-category-product__buy:hover {
    background-color: #ffffff;
    border-color: #ffffff;
    color: #222222;
}

.selection-category-product__link:hover {
    background-color: #fff;
    color: #222222;
}


/* ? Certificate ? */
.gift-certificate {
    border-radius: 40px;
    background: rgba(255, 255, 255, 20%) url(../img/gift-cards.png) left center / contain no-repeat;
    padding: 46px 18px 48px 30px;
    margin: 0 0 100px;
}

.gift-certificate-info {
    display: flex;
    flex-direction: column;
    gap: 25px;
    max-width: 400px;
    margin: 0 0 0 auto;
}

.gift-certificate-info__title {
    font-size: 30px;
    font-weight: 700;
    line-height: 36px;
    color: #ffffff;
    margin: 0;
}

.gift-certificate-info__link {
    max-width: 280px;
    text-align: center;
    font-size: 18px;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
    border-radius: 10px;
    color: #ffffff;
    background-color: #1F1612;
    border: 1px solid #1F1612;
    padding: 15px 0 20px;
}

.gift-certificate-info__link:hover,
.gift-certificate-info__link:focus {
    background-color: #442e22;;
    border-color: #442e22;;
}


@media(max-width: 1180px) {
    .custom-tws-info {
        max-width: 280px;
        padding: 0 0 0 40px;
    }
}

@media(max-width: 1024px) {
    main {
        padding: 40px 0 120px;
    }

    .banner-info {
        max-width: 400px;
        padding: 80px 20px;
    }

    .banner__title {
        font: 600 40px / 44px var(--font-harmonia);
    }

    /* Sertificate */
    .gift-certificate {
        background: rgba(255, 255, 255, 20%) url(../img/gift-cards.png) -193px center / contain no-repeat;
    }

    .gift-certificate-info {
        max-width: 360px;
    }

    /* Custom TWS */
    .custom-tws::before {
        top: -29px;
        right: -27px;
        width: 600px;
        height: 300px;
    }

    .custom-tws-info {
        padding: 0 0 0 20px;
    }

    .custom-tws-info__title {
        font: 700 34px/38px var(--font-harmonia);
    }
}

@media(max-width: 767px) {
    main {
        padding: 0 0 100px;
    }

    .wrapper {
        padding: 0 16px;
    }

    /* Banner */
    .banner {
        border-radius: 0;
        background: 
            url(../img/top-gradient.png) top center / cover no-repeat, 
            url(../img/banner-m.jpg) center / cover no-repeat;
        height: 346px;
        padding: 35px 0 0;
        margin: 0 -15px;
    }

    .banner-info {
        align-items: center;
        gap: 10px;
        max-width: 260px;
        padding: 0;
        margin: 0 auto;
    }

    .banner__title {
        font: 600 24px/110% var(--font-harmonia);
        text-align: center;
    }

    .banner__subtitle {
        font: 600 14px/120% var(--font-harmonia);
    }

    /* Categories */
    .promo-categories {
        gap: 18px;
        margin: 45px 0 30px;
    }

    .promo-categories__title {
        font: 700 24px/120% var(--font-harmonia);
    }

    .promo-categories-list {
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
        gap: 16px;
    }

    .promo-category {
        gap: 24px;
        border-radius: 8px;
        padding: 16px;
    }

    .promo-category__img {
        border-radius: 8px;
        height: 138px;
    }

    .promo-category__title {
        min-height: auto;
        font: 600 14px/18px var(--font-harmonia);
    }

    .promo-category__link {
        display: none;
    }

    /* Sertificate */
    .gift-certificate {
        border-radius: 15px;
        background: rgba(255, 255, 255, 20%) url(../img/gift-cards-m.png) center -24px / contain no-repeat;
        padding: 261px 20px 15px;
        margin: 0 0 30px;
    }

    .gift-certificate-info {
        align-items: center;
        gap: 18px;
        margin: 0 auto;
    }

    .gift-certificate-info__title {
        font-size: 24px;
        line-height: 120%;
        text-align: center;
        margin: 0 auto;
    }

    .gift-certificate-info__link {
        width: 100%;
    }

    /* Custom TWS */
    .custom-tws {
        border-radius: 15px;
        padding: 165px 0 14px;
    }

    .custom-tws::before {
        top: 10px;
        right: 50%;
        width: 289px;
        height: 150px;
        transform: translate(50%, 0);
    }

    .custom-tws-info {
        gap: 5px;
        max-width: 375px;
        padding: 0 10px;
        margin: 0 auto;
    }

    .custom-tws-info__title {
        font: 700 24px / 29px var(--font-harmonia);
        text-align: center;
    }

    .custom-tws-info__link {
        max-width: 242px;
        margin: 13px auto 0;
    }

    /* Selections */

    .selection-categories {
        gap: 30px;
        margin: 68px 0 0 0;
    }

    .selection-category {
        gap: 22px;
    }

    /* Selction Heading */
    .selection-category-heading__icon {
        width: 40px;
        height: 40px;
        fill: #ffffff
    }

    .selection-category-heading__title {
        font: 700 24px/120% var(--font-harmonia);
    }

    .selection-category-products-list {
        gap: 0;
    }

    .selection-category-content.swiper {
        overflow: hidden;
        position: relative;
        padding: 0 0 36px;
    }

    .selection-category-product.swiper-slide {
        height: auto;
    }

    .selection-category-content.swiper .swiper-pagination-bullet {
        opacity: 1;
        background-color: rgba(255, 255, 255, 0.4);
    }

    .selection-category-content.swiper .swiper-pagination-bullet-active {
        background-color: rgba(255, 255, 255, 1);
    }

    .selection-category-product {
        max-width: 264px;
        gap: 6px;
    }

    .selection-category-product__buy {
        padding: 15px 0 19px;
    }

    .selection-category-product__link {
        padding: 15px 0 19px;
        margin: -2px 0 0 0;
    }
}