@media print,
(max-width: 1279px)
{
    /*-------------------
        Global styles
    -------------------*/
    :root
    {
        --sidebar_width: 260px;
        --font_size: 15px;
        --font_size_title: 44px;
    }


    html.custom_scroll ::-webkit-scrollbar
    {
        width: 5px;
        height: 5px;
    }


    .content_flex .content
    {
        width: calc(100% - var(--sidebar_width) - 24px);
    }


    .block
    {
        margin-bottom: 80px;
    }



    /*----------------
        Pagination
    ----------------*/
    .pagination
    {
        margin-top: 40px;
    }


    .pagination a
    {
        font-size: 15px;
        line-height: 46px;

        width: 48px;
        height: 48px;
    }



    /*---------------
        Accordion
    ---------------*/
    .accordion_item .head
    {
        padding: 30px 150px 30px 40px;
    }


    .accordion_item .head .title
    {
        font-size: 22px;
        line-height: 28px;
    }


    .accordion_item .data
    {
        padding: 50px 40px 40px;
    }



    /*------------
        Header
    ------------*/
    header .links
    {
        margin-left: 32px;
    }

    header .links > * + *
    {
        margin-left: 24px;
    }


    header .contacts
    {
        display: none;
    }


    header .cart_link
    {
        margin-left: auto;
    }



    /*----------
        Menu
    ----------*/
    .menu .row + .row
    {
        display: flex;
    }


    .menu .has_question
    {
        margin-top: 40px;
        padding-top: 0;

        border: none;
    }



    /*------------
        Filter
    ------------*/
    .filter .item
    {
        padding: 20px;
    }


    .filter .item .label
    {
        font-size: 16px;
        line-height: 20px;
    }


    .filter .item .data
    {
        padding-bottom: 0;
    }



    /*---------------
        Page head
    ---------------*/
    .page_head
    {
        margin-bottom: 52px;
    }



    /*-------------
        Sidebar
    -------------*/
    aside .links
    {
        padding: 40px 20px;
    }


    aside .links .title
    {
        font-size: 18px;
        line-height: 22px;

        margin-bottom: 24px;
    }



    /*----------------
        Block head
    ----------------*/
    .block_head
    {
        margin-bottom: 48px;
    }

    .block_head.pad_r
    {
        padding-right: 172px;
    }



    /*------------------
        Form elements
    ------------------*/
    .form .checkbox
    {
        font-size: 13px;
        line-height: 17px;
    }


    .form .input
    {
        height: 60px;
        padding: 0 23px;
    }


    .form .icon
    {
        width: 60px;
    }

    .form .icon svg
    {
        width: 26px;
        height: 26px;
    }

    .form .icon ~ .input
    {
        padding-left: 59px;
    }


    .form textarea
    {
        padding: 23px;
    }



    /*----------------
        Typography
    ----------------*/
    .text_block
    {
        font-size: 16px;
        line-height: 24px;
    }

    .text_block.min_w,
    .text_block.middle_w2
    {
        font-size: 15px;
        line-height: 23px;
    }


    .text_block h1
    {
        font-size: 40px;
    }

    .text_block h2
    {
        font-size: 32px;

        margin-bottom: 28px;
    }

    .text_block h3
    {
        font-size: 28px;
        line-height: 34px;

        margin-bottom: 28px;
    }


    .text_block * + h2
    {
        margin-top: 60px;
    }


    .text_block table th
    {
        font-size: 14px;
        line-height: 18px;

        padding-bottom: 11px;
    }


    .text_block table th:first-child,
    .text_block table th + th,
    .text_block table td:first-child,
    .text_block table td + td
    {
        padding-left: 24px;
    }

    .text_block table th:last-child,
    .text_block table td:last-child
    {
        padding-right: 24px;
    }


    .text_block table td
    {
        font-size: 15px;
        line-height: 17px;

        min-width: 150px;
        padding: 20px 0;
    }

    .text_block table td:last-child
    {
        min-width: 180px;
    }


    .text_block blockquote
    {
        font-size: 24px;
        line-height: 30px;

        margin-top: 50px;
        margin-bottom: 50px;
        padding: 36px 0 36px 72px;
    }


    .text_block .slider
    {
        margin-top: 50px;
        margin-bottom: 50px;
    }


    .text_block .slider .swiper-button-next,
    .text_block .slider .swiper-button-prev
    {
        width: 50px;
        height: 50px;
    }

    .text_block .slider .swiper-button-prev
    {
        left: 24px;
    }

    .text_block .slider .swiper-button-next
    {
        right: 24px;
    }


    .text_block .columns
    {
        column-gap: 40px;
    }



    /*-----------------
        Main slider
    -----------------*/
    .main_slider .cont
    {
        min-height: 650px;
        padding-top: 80px;
        padding-bottom: 80px;
    }


    .main_slider .data
    {
        width: 480px;
    }


    .main_slider .title
    {
        font-size: 40px;
        line-height: 44px;
    }


    .main_slider .desc
    {
        width: 452px;
        margin-top: 24px;
    }


    .main_slider .btn
    {
        width: 236px;
        height: 70px;
    }


    .main_slider .img
    {
        width: 472px;
        margin-top: 0;

        transform: translateY(20px);
    }


    .main_slider .controls
    {
        width: 260px;
    }



    /*----------------
        Advantages
    ----------------*/
    .advantages .row
    {
        display: block;
        overflow: auto;

        width: calc(100% + 48px);
        margin: 0 -24px;
        padding: 0 24px;

        white-space: nowrap;

        scrollbar-color: transparent transparent !important;
        scrollbar-width: thin !important;
    }

    .advantages .row::-webkit-scrollbar
    {
        display: none;

        width: 0 !important;
        height: 0 !important;

        background-color: transparent !important;
    }

    .advantages .row::-webkit-scrollbar-thumb
    {
        display: none;

        background-color: transparent !important;
    }


    .advantages .row > *
    {
        display: inline-block;

        width: 264px;
        max-width: none;
        margin: 0;

        vertical-align: top;
        white-space: normal;
    }

    .advantages .row > * + *
    {
        margin-left: 36px;
    }



    .advantages .item .name
    {
        font-size: 18px;
        line-height: 22px;
    }



    /*---------------------
        Categories wall
    ---------------------*/
    .categories_wall .category
    {
        padding: 60px 40px;
    }


    .categories_wall .category .name
    {
        font-size: 32px;
    }


    .categories_wall .category .desc
    {
        margin-top: 30px;
    }


    .categories_wall .category .links
    {
        margin-top: 30px;
    }

    .categories_wall .category .links a
    {
        font-size: 16px;
        line-height: 20px;

        padding: 12px 32px;
    }


    .categories_wall .category.big .info
    {
        width: 288px;
    }

    .categories_wall .category.big .links
    {
        margin-left: 80px;
    }



    /*-----------------
        About block
    -----------------*/
    .about_block
    {
        margin-bottom: 100px;
    }


    .about_block .block_head
    {
        width: calc(50% - 20px);
    }


    .about_block .block_head .btn
    {
        line-height: 70px;

        width: 260px;
        height: 70px;
    }


    .about_block .accordion
    {
        width: calc(50% - 20px);
    }


    .about_block .accordion_item .head .title
    {
        font-size: 18px;
        line-height: 22px;
    }



    /*-------------------
        Category info
    -------------------*/
    .category_info
    {
        --sidebar_width: 240px;
    }


    .category_info .content
    {
        width: calc(100% - var(--sidebar_width) - 24px);
    }


    .category_info .desc
    {
        font-size: var(--font_size);
        line-height: 23px;
    }


    .category_info .products
    {
        margin-top: 30px;
        padding-top: 30px;
    }



    /*--------------
        Products
    --------------*/
    .products .row
    {
        margin-bottom: -12px;
        margin-left: -12px;
    }

    .products .row > *,
    .content .products .row > *
    {
        width: calc(33.333% - 12px);
        margin-bottom: 12px;
        margin-left: 12px;
    }


    .products .tabs
    {
        margin-bottom: 40px;
    }


    .products .tabs .btn
    {
        font-size: 16px;
        line-height: 20px;

        padding: 12px 32px;
    }


    .products .product
    {
        padding: 220px 15px 15px;
    }


    .products .product .price
    {
        font-size: 22px;
        line-height: 26px;
    }


    .products .product .details .icon,
    .products .product .buy_btn
    {
        width: 50px;
        height: 50px;
        margin-right: 0;
    }

    .products .product .buy_btn .icon
    {
        width: 28px;
        height: 28px;
    }



    /*-------------------------
        Product simple head
    -------------------------*/
    .product_simple_head
    {
        margin-bottom: 80px;
    }


    .product_simple_head .product_name
    {
        font-size: 36px;

        width: 532px;
        padding: 60px 40px;
    }


    .product_simple_head .data
    {
        height: 380px;
    }


    .product_simple_head .controls
    {
        left: 0;

        margin-left: 0;
        padding: 30px 40px;
    }


    .product_simple_info .col
    {
        width: calc(50% - 16px);
    }



    /*-------------
        Manager
    -------------*/
    .manager
    {
        padding: 40px 148px 40px 40px;
    }


    .manager .title
    {
        font-size: 28px;
    }


    .manager .link
    {
        width: 100px;
        height: 100px;
    }



    /*------------------
        Product info
    ------------------*/
    .product_info .images
    {
        width: calc(50% - 20px);
        padding-left: 82px;
    }


    .product_info .images .thumbs
    {
        width: 72px;
    }


    .product_info .data
    {
        width: calc(50% - 20px);
    }


    .product_info .data .product_name
    {
        font-size: 32px;
    }


    .product_info .data .options
    {
        margin-top: 30px;
    }


    .product_info .data .option label div
    {
        padding: 11px 19px;
    }


    .product_info .data .prices
    {
        margin-top: 30px;
        padding-top: 30px;
    }


    .product_info .data .prices .price
    {
        font-size: 24px;
        line-height: 28px;
    }


    .product_info .data .buy
    {
        margin-top: 30px;
        padding-top: 30px;
    }


    .product_info .data .amount .btn
    {
        line-height: 50px;

        width: 50px;
        height: 50px;
    }

    .product_info .data .amount .input
    {
        width: 40px;
    }


    .product_info .data .buy_btn
    {
        width: 232px;
        height: 70px;
    }

    .product_info .data .buy_btn .icon
    {
        width: 32px;
        height: 32px;
    }


    .product_info .tabs_container
    {
        margin-top: 60px;
    }


    .product_info .tabs
    {
        margin-bottom: 40px;
    }


    .product_info .description .title,
    .product_info .features .title
    {
        font-size: 36px;
    }



    /*----------------
        Categories
    ----------------*/
    .categories .tabs
    {
        width: 100%;
        margin-top: 30px;
        margin-left: 0;
    }


    .categories .controls
    {
        width: auto;
        margin-bottom: 40px;
    }


    .categories .swiper-button-next,
    .categories .swiper-button-prev
    {
        width: 60px;
        height: 60px;
    }


    .categories .category .info
    {
        padding: 30px;
    }


    .categories .category .name
    {
        font-size: 16px;
        line-height: 22px;

        width: 180px;
    }


    .categories .category .btn
    {
        width: 60px;
        height: 60px;
    }


    .categories .all_link a
    {
        width: 160px;
        height: 160px;
    }



    /*------------------
        Action block
    ------------------*/
    .action_block
    {
        margin-bottom: 80px;
    }


    .action_block .data
    {
        padding: 68px 40px 68px 400px;
    }


    .action_block .title
    {
        font-size: 40px;
    }


    .action_block .desc
    {
        font-size: 15px;
        line-height: 23px;

        width: 300px;
        margin-left: auto;
    }


    .action_block .btn
    {
        width: 100%;
        height: 60px;
        margin-top: 40px;
        margin-left: auto;
    }



    /*-------------------
        Contacts info
    -------------------*/
    .contacts_info .data
    {
        width: calc(50% - 20px);
    }


    .contacts_info .data .item + .item
    {
        margin-top: 40px;
    }


    .contacts_info .data .item .icon
    {
        width: 50px;
        height: 50px;
    }

    .contacts_info .data .item .icon svg
    {
        width: 26px;
        height: 26px;
    }


    .contacts_info .data .item .icon ~ *
    {
        width: calc(100% - 70px);
    }

    .contacts_info .data .item .icon + * ~ *
    {
        margin-top: 20px;
    }


    .contacts_info .data .item .exp
    {
        padding: 16px 24px;
    }


    .contacts_info .data .item .val
    {
        font-size: 24px;
        line-height: 28px;
    }


    .contacts_info .info
    {
        width: calc(50% - 20px);
    }


    .contacts_info .has_question
    {
        padding: 40px;
    }


    .contacts_info .has_question .title
    {
        font-size: 36px;
    }

    .contacts_info .has_question .btn
    {
        height: 70px;
        margin-top: 40px;
    }


    .contacts_info .requisites,
    .contacts_info .socials
    {
        padding: 30px 40px;
    }


    .contacts_info .socials a
    {
        width: 50px;
        height: 50px;
    }

    .contacts_info .socials .icon
    {
        width: 22px;
        height: 22px;
    }


    .contacts_info .map
    {
        height: 440px;
        margin-top: 60px;
    }



    /*---------------------
        About info head
    ---------------------*/
    .about_info_head
    {
        padding-bottom: 80px;
    }


    .about_info_head .data
    {
        margin-top: 60px;
    }


    .about_info_head .data .title
    {
        font-size: 100px;
    }


    .about_info_head .data .desc
    {
        font-size: 16px;
        line-height: 24px;

        width: 800px;
    }



    /*----------------------
        About advantages
    ----------------------*/
    .about_advantages
    {
        margin-bottom: 80px;
    }


    .about_advantages .info
    {
        width: 280px;
    }


    .about_advantages .info .title
    {
        font-size: 36px;
    }


    .about_advantages .info .desc
    {
        font-size: 15px;
        line-height: 23px;

        margin-top: 24px;
    }


    .about_advantages .info .btn
    {
        width: 230px;
        height: 70px;
        margin-top: 40px;
    }


    .about_advantages .items
    {
        width: calc(100% - 340px);
    }


    .about_advantages .row
    {
        margin-left: -24px;
    }

    .about_advantages .row > *
    {
        width: calc(50% - 24px);
        margin-left: 24px;
    }


    .about_advantages .item .icon
    {
        width: 60px;
        height: 60px;
        padding: 12px;
    }


    .about_advantages .item .name
    {
        font-size: 18px;
        line-height: 22px;

        min-height: 60px;
    }



    /*----------------
        About info
    ----------------*/
    .about_info
    {
        margin-bottom: 80px;
    }


    .about_info .link
    {
        font-size: 16px;
        line-height: 22px;

        top: -100px;
        left: 280px;

        width: 200px;
        height: 200px;
    }


    .about_info .gallery
    {
        width: 560px;
    }


    .about_info .gallery .swiper-button-next,
    .about_info .gallery .swiper-button-prev
    {
        width: 60px;
        height: 60px;
    }



    /*-------------
        Persons
    -------------*/
    .persons
    {
        margin-bottom: 80px;
    }


    .persons .person .name
    {
        font-size: 18px;
        line-height: 135%;
    }


    .persons .more_btn
    {
        margin-top: 40px;
        padding: 30px;
    }



    /*--------------
        Partners
    --------------*/
    .partners
    {
        margin-bottom: 80px;
    }


    .partners .controls
    {
        margin-bottom: 41px;
    }

    .partners .swiper-button-next,
    .partners .swiper-button-prev
    {
        width: 60px;
        height: 60px;
    }


    .partners .swiper
    {
        height: 204px;
    }

    .partners .swiper-slide
    {
        height: 100px;
    }


    .partners .item
    {
        height: 100px;
    }



    /*-------------
        History
    -------------*/
    .history
    {
        margin-bottom: 120px;
    }


    .history .years .swiper-slide
    {
        font-size: 120px;
    }


    .history .data
    {
        margin-top: 60px;
    }


    .history .block_head
    {
        width: 292px;
    }


    .history .text_block
    {
        width: calc(100% - 332px);
    }



    /*---------------
        Cart info
    ---------------*/
    .cart_info
    {
        margin-bottom: 100px;

        --sidebar_width: 100%;
    }


    .cart_info .content
    {
        width: 100%;
    }


    .cart_info .product .name
    {
        font-size: 17px;
        line-height: 23px;
    }



    /*-------------------
        Checkout info
    -------------------*/
    .checkout_info
    {
        margin-top: 80px;
    }


    .checkout_info .block_title
    {
        font-size: 36px;
    }


    .checkout_info .section + .section
    {
        margin-top: 60px;
    }


    .checkout_info .section .title
    {
        font-size: 24px;
        line-height: 30px;

        margin-bottom: 24px;
    }


    .checkout_info .section .desc
    {
        margin-bottom: 24px;
    }


    .checkout_info .delivery_methods label .info
    {
        padding: 21px 23px 23px 69px;
    }


    .checkout_info .delivery_methods .exp
    {
        padding: 20px 28px;
    }



    /*----------------
        Cart total
    ----------------*/
    .cart_total
    {
        padding: 40px;
    }


    .cart_total .title
    {
        font-size: 28px;

        margin-bottom: 28px;
    }


    .cart_total .item.total_price .label,
    .cart_total .item.total_price .val
    {
        font-size: 28px;
    }



    /*------------
        Footer
    ------------*/
    footer .contacts
    {
        width: 272px;
    }


    footer .contacts .phones .val
    {
        font-size: 21px;
    }


    footer .socials a
    {
        width: 52px;
        height: 52px;
    }

    footer .socials .icon
    {
        width: 22px;
        height: 22px;
    }



    /*-----------
        PopUp
    -----------*/
}
