@media print,
(max-width: 767px)
{
    /*-------------------
        Global styles
    -------------------*/
    :root
    {
        --font_size: 14px;
        --font_size_title: 36px;
    }


    .block
    {
        margin-bottom: 60px;
    }



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

        justify-content: center;
    }


    .pagination a
    {
        font-size: 14px;
        line-height: 42px;

        width: 44px;
        height: 44px;
    }



    /*---------------
        Accordion
    ---------------*/
    .accordion_item .head
    {
        padding: 20px 100px 20px 24px;
    }


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


    .accordion_item .head > .icon
    {
        right: 20px;

        width: 40px;
        height: 40px;
    }


    .accordion_item .head .tooltip .icon
    {
        width: 20px;
        height: 20px;
    }


    .accordion_item .data
    {
        padding: 44px 24px 24px;
    }



    /*------------
        Header
    ------------*/
    header .menu_btn .icon
    {
        width: 26px;
        height: 26px;
    }


    header .cart_link .icon
    {
        width: 32px;
        height: 32px;
    }



    /*----------
        Menu
    ----------*/
    .menu .close_btn .icon
    {
        width: 26px;
        height: 26px;
    }


    .menu .logo img
    {
        width: 120px;
    }


    .menu .scroll
    {
        padding: 130px 40px 40px;
    }


    .menu .links
    {
        line-height: 28px;
    }


    .menu .has_question .title
    {
        font-size: 24px;
        line-height: 28px;
    }


    .menu .has_question .desc
    {
        font-size: 12px;
        line-height: 135%;

        margin-top: 14px;
    }


    .menu .has_question .btn
    {
        font-size: 12px;
        line-height: 15px;

        width: 194px;
        height: 59px;
        margin-top: 24px;
    }



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



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

    .block_head.pad_r
    {
        padding: 0;
    }


    .block_head .desc
    {
        margin-top: 30px;
    }



    /*------------------
        Form elements
    ------------------*/
    .form .columns
    {
        --form_columns_offset: 10px;
    }


    .form .line
    {
        margin-bottom: 10px;
    }


    .form .input
    {
        font-size: 12px;

        height: 52px;
        padding: 0 19px;
    }


    .form .icon
    {
        width: 44px;
    }

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

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


    .form textarea
    {
        height: 140px;
        padding: 19px;
    }



    /*----------------
        Typography
    ----------------*/
    .text_block,
    .text_block.min_w,
    .text_block.middle_w2
    {
        font-size: 14px;
        line-height: 22px;
    }

    .text_block.middle_w
    {
        font-size: 14px;
        line-height: 22px;

        padding-left: 0;
    }


    .text_block h1
    {
        font-size: 32px;
        line-height: 125%;
    }

    .text_block h2,
    .text_block h3
    {
        font-size: 26px;
        line-height: 32px;

        margin-bottom: 24px;
    }

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

        margin-bottom: 20px;
    }


    .text_block * + h4
    {
        margin-top: 40px;
    }


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


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

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


    .text_block table td
    {
        font-size: 12px;
        line-height: 14px;

        min-width: 100px;
        padding: 14px 0;
    }

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


    .text_block .table_exp
    {
        font-size: 12px;
        line-height: 155%;

        margin-top: -16px;
    }


    .text_block ul li
    {
        padding-left: 30px;
    }

    .text_block ol li
    {
        padding-left: 48px;
    }

    .text_block ul li:before,
    .text_block ol li:before
    {
        left: 0;
    }


    .text_block blockquote
    {
        font-size: 20px;
        line-height: 26px;

        padding: 27px 0 27px 67px;
    }


    .text_block .slider .swiper-button-next,
    .text_block .slider .swiper-button-prev
    {
        display: none;
    }


    .text_block.middle_w .message
    {
        margin-left: 0;
    }

    .text_block .message
    {
        font-size: 18px;
        line-height: 26px;

        padding-left: 24px;
    }


    .text_block .columns
    {
        column-gap: 0;
        column-count: 1;
    }



    /*-----------------
        Main slider
    -----------------*/
    .main_slider .cont
    {
        min-height: 560px;
        padding-top: 120px;
        padding-bottom: 180px;
    }


    .main_slider .data
    {
        width: 100%;
    }


    .main_slider .title
    {
        color: #484540;
        font-size: 32px;
        line-height: 125%;
    }


    .main_slider .desc
    {
        font-size: 12px;
        line-height: 145%;
    }


    .main_slider .btn
    {
        font-size: 12px;
        line-height: 15px;

        width: 194px;
        height: 59px;
        margin-top: 30px;
    }


    .main_slider .img
    {
        right: -40px;

        width: 280px;
    }


    .main_slider .controls
    {
        width: auto;
        height: 80px;
        padding-right: 23px;

        border-radius: 0 30px 0 0;
    }


    .main_slider .controls > * + *
    {
        margin-left: 24px;
    }



    /*----------------
        Advantages
    ----------------*/
    .advantages .row > *
    {
        width: 240px;
    }


    .advantages .item .name
    {
        font-size: 16px;
        line-height: 125%;
    }


    .advantages .item .desc
    {
        font-size: 13px;
        line-height: 135%;

        margin-top: 4px;
    }



    /*---------------------
        Categories wall
    ---------------------*/
    .categories_wall
    {
        margin-bottom: 60px;
    }


    .categories_wall .row
    {
        margin-left: 0;
        padding: 0 10px;
    }

    .categories_wall .row > *
    {
        width: 100%;
        margin-left: 0;
    }


    .categories_wall .category
    {
        min-height: 324px;
        padding: 50px 24px;
    }


    .categories_wall .category .name
    {
        color: #484540;
        font-size: 28px;
        line-height: 125%;
    }


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


    .categories_wall .category.big .info
    {
        width: 100%;
        margin-bottom: 30px;
    }

    .categories_wall .category.big .links
    {
        width: 100%;
        margin-left: 0;
    }


    .categories_wall .category .img
    {
        max-width: 50%;
    }



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


    .about_block .block_head
    {
        margin-bottom: 30px;
    }


    .about_block .block_head .btn
    {
        display: none;
    }


    .about_block .accordion_item .head
    {
        padding: 20px;
    }


    .about_block .accordion_item .head .icon .title
    {
        font-size: 14px;
        line-height: 16px;
    }


    .about_block .accordion_item .head .icon
    {
        width: 28px;
        height: 28px;
    }

    .about_block .accordion_item .head .icon img
    {
        width: 28px;
        height: 28px;
    }

    .about_block .accordion_item .head .icon + *
    {
        width: calc(100% - 100px);
    }


    .about_block .accordion_item .head .arr
    {
        width: 40px;
        height: 40px;
    }

    .about_block .accordion_item .head .arr svg
    {
        width: 16px;
        height: 9px;
    }


    .about_block .accordion_item .data
    {
        padding: 0 20px 40px;
    }



    /*-------------------
        Category info
    -------------------*/
    .category_info .desc
    {
        line-height: 22px;
    }



    /*--------------
        Products
    --------------*/
    .products .row > *,
    .content .products .row > *
    {
        width: calc(50% - 12px);
    }


    .products .product .price
    {
        font-size: 20px;
        line-height: 24px;
    }



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


    .product_simple_head .product_name
    {
        line-height: 125%;

        width: 100%;
        padding: 30px 24px;
    }


    .product_simple_head .data
    {
        height: 300px;
    }


    .product_simple_head .controls
    {
        padding: 24px;
    }



    /*-------------
        Manager
    -------------*/
    .manager
    {
        padding: 30px 24px 112px;
    }


    .manager .title
    {
        font-size: 26px;
        line-height: 125%;
    }


    .manager .desc
    {
        font-size: 12px;
        line-height: 135%;

        margin-top: 16px;
    }


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



    /*------------------
        Product info
    ------------------*/
    .product_info .images
    {
        padding-left: 75px;
    }


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


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


    .product_info .data .option label div
    {
        padding: 9px 16px;
    }


    .product_info .tabs .btn
    {
        font-size: 15px;
        line-height: 19px;
    }

    .product_info .tabs .btn + .btn
    {
        margin-left: 36px;
    }


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


    .product_info .features .label
    {
        width: 280px;
    }

    .product_info .features .val
    {
        width: calc(100% - 300px);
    }



    /*----------------
        Categories
    ----------------*/
    .categories
    {
        margin-bottom: 60px;
    }


    .categories .swiper-slide
    {
        width: 315px;
    }


    .categories .controls
    {
        display: none;
    }


    .categories .tabs .btn
    {
        font-size: 14px;
        line-height: 16px;
    }


    .categories .category .thumb
    {
        padding-bottom: 100%;
    }


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


    .categories .category .name
    {
        font-size: 18px;
        line-height: 21px;

        width: 200px;
    }


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


    .categories .row > *
    {
        width: calc(50% - 8px);
    }


    .categories .row .category .thumb
    {
        border-radius: 30px;
    }

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

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

        width: 100%;
    }

    .categories .row .category .btn
    {
        width: 50px;
        height: 50px;
    }



    /*------------------
        Action block
    ------------------*/
    .action_block .data
    {
        margin-right: 10px;
        margin-left: 10px;
        padding: 40px 30px;

        border-radius: 10px;
        background-size: 50% auto;
    }


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

    .action_block .title br
    {
        display: none;
    }


    .action_block .desc
    {
        font-size: 14px;
        line-height: 145%;

        margin-top: 20px;
    }


    .action_block .btn
    {
        font-size: 12px;
        line-height: 15px;

        width: 241px;
        height: 59px;
        margin-top: 36px;
        margin-right: auto;
        margin-left: 0;
    }


    .action_block .img
    {
        display: none;
    }



    /*----------------
        Price list
    ----------------*/
    .price_list .cont > * + *
    {
        margin-top: 50px;
    }


    .price_list .exp
    {
        font-size: 14px;
        line-height: 22px;
    }



    /*-------------------
        Contacts info
    -------------------*/
    .contacts_info .data .item + .item
    {
        margin-top: 30px;
    }


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

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


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

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


    .contacts_info .data .item .label
    {
        font-size: 12px;
        line-height: 14px;

        margin-bottom: 6px;
    }


    .contacts_info .data .item .val
    {
        font-size: 18px;
        line-height: 125%;
    }


    .contacts_info .data .item .exp
    {
        font-size: 12px;
        line-height: 125%;

        padding: 14px 18px;
    }


    .contacts_info .has_question
    {
        width: calc(100% + 20px);
        margin-right: -10px;
        margin-left: -10px;
        padding: 30px 30px 80px;
    }


    .contacts_info .has_question .title
    {
        font-size: 32px;
        line-height: 125%;
    }

    .contacts_info .has_question .title br
    {
        display: none;
    }


    .contacts_info .has_question .desc
    {
        line-height: 145%;

        margin-top: 18px;
    }


    .contacts_info .has_question .btn
    {
        font-size: 12px;
        line-height: 15px;

        width: 241px;
        height: 59px;
        margin-top: 50px;
    }


    .contacts_info .requisites,
    .contacts_info .socials
    {
        width: calc(100% + 20px);
        margin-top: 10px;
        margin-right: -10px;
        margin-left: -10px;
        padding: 30px;
    }


    .contacts_info .requisites
    {
        font-size: 12px;
        line-height: 14px;
    }

    .contacts_info .requisites > * + *
    {
        margin-top: 12px;
    }


    .contacts_info .requisites .title
    {
        font-size: 18px;
        line-height: 125%;
    }


    .contacts_info .socials .label
    {
        font-size: 18px;
        line-height: 125%;
    }


    .contacts_info .map
    {
        width: calc(100% + 20px);
        margin-top: 30px;
        margin-right: -10px;
        margin-left: -10px;
    }



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


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


    .about_info_head .data .desc
    {
        font-size: 14px;
        line-height: 22px;

        margin-top: 24px;
    }



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


    .about_advantages .data
    {
        padding: 60px 24px;
    }


    .about_advantages .info .title
    {
        font-size: 32px;

        text-align: center;
    }

    .about_advantages .info .desc
    {
        font-size: 14px;
        line-height: 22px;

        text-align: center;
    }


    .about_advantages .info .btn
    {
        display: block;

        width: 194px;
        height: 59px;
        margin: 30px auto 0;
    }


    .about_advantages .items
    {
        width: 100%;
    }


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

    .about_advantages .row > *
    {
        width: 100%;
        margin-bottom: 24px;
        margin-left: 0;
    }


    .about_advantages .item .icon + *
    {
        align-self: center;
    }


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

        min-height: 0;
    }

    .about_advantages .item .name br
    {
        display: none;
    }



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


    .about_info .block_head
    {
        margin-bottom: 40px;
    }


    .about_info .gallery
    {
        width: 400px;
        margin-top: 40px;
        margin-bottom: 60px;
    }

    .about_info .gallery .controls
    {
        display: none;
    }


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

        top: auto;
        right: 0;
        bottom: -80px;
        left: 0;

        margin: auto;
    }



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


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


    .persons .person .contacts a
    {
        font-size: 12px;
        line-height: 14px;
    }



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


    .partners .controls
    {
        display: none;
    }


    .partners .swiper
    {
        height: 164px;
    }

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


    .partners .item
    {
        height: 80px;
        padding: 11px;
    }



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


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

        padding: 40px 0;
    }



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



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


    .cart_info .product .thumb
    {
        width: 100px;
        height: 100px;
    }


    .cart_info .product .info
    {
        width: calc(100% - 242px);
        margin-left: 12px;
        padding-right: 12px;
    }


    .cart_info .product .type
    {
        font-size: 12px;
        line-height: 14px;
    }


    .cart_info .product .name
    {
        font-size: 14px;
        line-height: 18px;
    }


    .cart_info .product .amount,
    .cart_info .product .price
    {
        margin-left: 12px;
    }


    .cart_info .product .amount
    {
        width: 76px;
        margin-top: 16px;

        align-self: flex-start;
    }


    .cart_info .product .amount .btn
    {
        line-height: 20px;

        width: 20px;
        height: 20px;

        border-radius: 0;
        background: none;
    }


    .cart_info .product .amount .input
    {
        font-size: 14px;

        width: 36px;
        height: 20px;
    }


    .cart_info .product .price
    {
        position: absolute;
        top: 56px;
        right: 48px;

        width: 76px;
    }

    .cart_info .product .price .val
    {
        font-size: 14px;
        line-height: 16px;
    }


    .cart_info .product .delete
    {
        margin-left: 18px;
    }



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


    .checkout_info .block_title
    {
        font-size: 32px;

        margin-bottom: 32px;
    }


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


    .checkout_info .section .title
    {
        font-size: 20px;
        line-height: 26px;

        margin-bottom: 20px;
    }


    .checkout_info .section .desc
    {
        font-size: 12px;
        line-height: 14px;
    }


    .checkout_info .delivery_methods .row
    {
        margin-left: 0;
    }

    .checkout_info .delivery_methods .row > *
    {
        width: 100%;
        margin-left: 0;
    }


    .checkout_info .delivery_methods label .name
    {
        font-size: 16px;
        line-height: 20px;
    }

    .checkout_info .delivery_methods label .desc
    {
        font-size: 12px;
        line-height: 14px;
    }


    .checkout_info .delivery_methods .exp
    {
        font-size: 12px;
        line-height: 14px;

        padding: 14px 20px;
    }


    .checkout_info .payment_methods
    {
        padding: 9px;
    }


    .checkout_info .payment_methods label .info
    {
        padding: 11px 15px;
    }


    .checkout_info .payment_methods label .icon
    {
        width: 24px;
        height: 24px;
        margin-right: 12px;
    }

    .checkout_info .payment_methods label .icon img
    {
        width: 24px;
        height: 24px;
    }


    .checkout_info .payment_methods label .logos
    {
        width: 100%;
        margin-top: 5px;
        margin-left: 0;
        padding-left: 36px;
    }



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


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

        margin-bottom: 24px;
    }


    .cart_total .item + .item
    {
        margin-top: 14px;
        padding-top: 14px;
    }


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


    .cart_total .submit_btn
    {
        height: 59px;
        margin-top: 24px;
        padding: 0;
    }


    .cart_total .exp
    {
        font-size: 12px;
        line-height: 14px;

        margin-top: 12px;
    }



    /*------------
        Footer
    ------------*/
    footer .data
    {
        padding: 60px 0 40px;
    }


    footer .col
    {
        width: 100%;

        text-align: center;
    }


    footer .logo img
    {
        margin-right: auto;
        margin-left: auto;
    }


    footer .desc
    {
        width: 292px;
        max-width: 100%;
        margin-right: auto;
        margin-left: auto;
    }


    footer .callback_btn
    {
        width: 194px;
        height: 59px;
        margin-top: 28px;
    }


    footer .links
    {
        display: none;
    }


    footer .contacts
    {
        width: 100%;
        margin-top: 40px;

        text-align: center;
    }


    footer .contacts .phones .val
    {
        font-size: 20px;
        line-height: 24px;
    }


    footer .socials
    {
        justify-content: center;
    }


    footer .priavcy_policy_link br,
    footer .creator br
    {
        display: block;
    }



    footer .creator a
    {
        margin-left: 0;
    }
}
