*{
    margin: 0;
    padding: 0;
    outline: none;
}

html{
    background: rgb(142, 142, 142);
}

body{
    max-width: 100%;
    width: 100%;
    margin: auto;
    font-family: 'TT Norms Pro';
    background: #F5F4F9;
}

.img{
    display: block;
    width: 100%;
}

.open-menu,
.close-menu{
    display: none;
}

.container{
    max-width: 1664px; 
    width: 100%;
    margin: auto;
}

.wrapper{
    margin-top: 50px;
}

button{
    background: none;
    border: none;
    font-family: 'TT Norms Pro';
}

.button{
    height: 58px;
    background: #F80215;
    border-radius: 3px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 18.028846%; /* 300/1664 */
    color: white;
    font-weight: 500;
    font-family: 'TT Norms Pro';
    cursor: pointer;
    line-height: normal;
    position: relative;
    overflow: hidden;
    transition: .3s;
}

.button::before{
    content: '';
    position: absolute;
    width: 30px;
    height: 300px;
    background: rgba(255, 255, 255, 0.215);
    box-shadow: 0 0 5px white;
    transform: rotate(45deg) translateX(-300px);
}

.button:hover::before{
    animation: btnHover 2.5s forwards;
}

@keyframes btnHover {
    to{
        transform: rotate(45deg) translateX(300px);
    }
}

.button:hover{
    transform: translateY(-3px);
    box-shadow: 0 0 10px #F80215;
}

.button.min{
    height: 43px;
    max-width: 13.581731%; /* 226/1664 */
}

a{
    color: #FFFFFF;
    text-decoration: none;
    transition: .3s;
    width: fit-content;
    position: relative;
    cursor: pointer;
}

a::before{
    content: '';
    position: absolute;
    bottom: 0px;
    left: 0;
    height: 2px;
    width: 100%;
    transform: translateY(-3px);
    background: #F80215;
    opacity: 0;
    transition: .3s;
}

a:hover::before{
    opacity: 1;
    transform: translateY(3px);
}

ul{
    list-style: none;
}

header{
    background: #1D1C1C;
    padding: 18px 0;
    color: #FFFFFF;
    z-index: 10;
}

.working_mode{
    font-weight: 700;
    display: flex;
    align-items: center;
    column-gap: 10px;
}

.circle-working_mode{
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid white;
    display: flex;
    align-items: center;
    justify-content: center;
}

.circle-working_mode div{
    display: block;
    width: 8px;
    height: 8px;
    background-color: #F80215;    
    border-radius: 50%;
    /* animation: circle_header 1s infinite 2s; */
    transform: scale(1);
}

@keyframes circle_header {
    0%{
        transform: scale(1);
    }
    50%{
        transform: scale(2);
    }
    100%{
        transform: scale(1);
    }
}

.wrapper-header{
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.list-contact_header{
    display: flex;
    align-items: center;
    column-gap: 38px;
}

.list-contact_header > li{
    display: flex;
    align-items: center;
    column-gap: 20px;
}

.list-contact_header > li::before{
    content: '';
    display: block;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    width: 24px;
    height: 24px;
}

.list-contact_header > li.call::before{
    background-image: url(../img/svg/call.svg);
}
.list-contact_header > li.mail::before{
    background-image: url(../img/svg/mail.svg);
}
.list-contact_header > li.sity::before{
    background-image: url(../img/svg/sity.svg);
}

.wrapper-nav{
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 3.786058%; /* 63/1664 */
    position: relative;
}

.wrapper-nav .button{
    position: absolute;
    right: 0;
}

nav{
    position: sticky;
    top: 0;
    background: #E0E0E0;
    z-index: 10;
}

.menu{
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 50px;
    font-weight: 500;
}

.menu a{
    display: block;
    padding: 22px 0;
    color: #1D1C1C;
}

.section-home{
    background-image: url(../img/home.webp);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    width: 100%;
}

.wrapper-home{
    width: 100%;
    height: calc(100vh - 136px);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
}

h1{
    font-weight: 700;
    text-shadow: 0px 0px 4px rgba(0, 0, 0, 0.2);
}

h1 span{
    color: #F80215;
}

.content-home h3{
    margin: 36px 0 62px;
}

.content-home a.button{
    background: green;
    margin-bottom: 10px;
}

.content-home a.button:hover{
    box-shadow: 0 0 10px green;
}

.content-home a.button::before{
    display: none;
}

.list-home{
    display: flex;
    column-gap: 50px;
}

.list-home h6{
    position: relative;
    width: fit-content;
    margin-bottom: 10px;
    padding-bottom: 4px;
}

.list-home h6::before{
    content: '';
    position: absolute;
    bottom: 0;
    display: block;
    width: 100%;
    height: 3px;
    background: #F80215;
    border-radius: 10px;
}

.section{
    margin-top: 100px;
}

.wrapper-stage_works h5{
    font-weight: 400;
}

.wrapper-stage_works ul li span{
    display: block;
    font-weight: 700;
    font-size: 128px;
    line-height: 153px;
    color: #E0E0E0;
}

.wrapper-stage_works ul li{
    display: grid;
    grid-template-columns: 18.681319% 1fr;
    align-items: center;
    column-gap: 60px;
}

.wrapper-stage_works ul{
    max-width: 54.6875%; /* 910/1664 */
    width: 100%;
    display: flex;
    flex-direction: column;
    row-gap: 50px;
}

.wrapper-stage_works{
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.img-stage_works{
    max-width: 32.572115%; /* 542/1664 */
    width: 100%;
}

.wrapper-about_company{
    display: flex;
    position: relative;
}

.content-about_company{
    position: absolute;
    background: #1D1C1C;
    border-radius: 0px 0px 0px 50px;
    max-width: 77.447917%; /* 1487/1920 */
    width: 100%;
    height: 100%;
    right: 0;
    top: 70px;
    display: flex;
    align-items: center;
}

.img-about_company{
    position: relative;
    z-index: 1;
    max-width: 32.552083%; /* 625/1920 */
    width: 100%;
}

.img-about_company > img{
    display: block;
    width: 100%;
    border-radius: 0px 50px 0px 0px;
}

.img-about_company > span img{
    display: block;
    width: 76.712329%; /* 112/146 */
    margin: auto;
}

.img-about_company > span{
    padding: 20px 0 50px;
    position: absolute;
    right: 30.8%;
    bottom: 0;
    display: block;
    max-width: 23.36%; /* 146/625 */
    width: 100%;
    background: #F5F4F9;
    border-radius: 0px 50px 0px 0px;
}

.text-about_company{
    max-width: 71.486214%; /* 1063/1487 */
    margin: 0 8.338937% 0 auto;
    color: white;

}

.text-about_company h4{
    margin-top: 30px;
    font-weight: 400;
}

.text-about_company .title{
    position: relative;
    z-index: 1;
}

.text-about_company .title::before{
    content: '';
    position: absolute;
    background: #F80215;
    border-radius: 2px;
    width: 50px;
    height: 100%;
    z-index: -1;
    left: -5px;
}

.list-advantages{
    display: flex;
    justify-content: space-between;
}

.list-advantages > li{
    width: 100%;
}


.list-advantages > li:nth-child(1){
    max-width: 20.192308%; /* 336/1664 */
}

.list-advantages > li:nth-child(2){
    max-width: 13.701923%; /* 228/1664 */
}

.list-advantages > li:nth-child(3){
    max-width: 23.978365%; /* 399/1664 */
}

.list-advantages > li:nth-child(4){
    max-width: 19.831731%; /* 330/1664 */
}


.icon-advantages{
    display: flex;
    align-items: flex-end;
    margin-bottom: 20px;
}

.icon-advantages img{
    display: block;
    max-width: 100px;
    width: 100%;
    margin-right: 20px;
}

section.section-advantages{
    margin-top: 140px;
}

.list-servises{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}

.list-servises > li{
    cursor: pointer;
    position: relative;
}

.list-servises > li:hover::before{
    opacity: 1;
}

.list-servises > li::before{
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: #000000b6;
    opacity: 0;
    transition: .3s;
}

.list-servises > li img{
    display: block;
    width: 100%;
    height: 100%;
}

.text-item_servises{
    width: 100%;
    position: absolute;
    bottom: 0;
    color: white;
    display: flex;
    align-items: flex-end;
    padding: 20px 10px;
    box-sizing: border-box;
}

.text-item_servises span{
    display: block;
    width: 100%;
    text-align: right;
    position: absolute;
    right: 20px;
}

.text-item_servises > h4{
    max-width: 50%;
}

.text-item_servises h4{
    font-weight: 500;
}

.wrapper-my_cars{
    display: flex;
    column-gap: 8.413462%; /* 140/1664 */
    background-image: url(../img/my-cars/backgr.webp);
    background-position: right;
    background-repeat: no-repeat;
    background-size: cover;
    filter: drop-shadow(0px 0px 40px rgba(0, 0, 0, 0.25));
}

.img-my_cars{
    max-width: 55.889423%; /* 930/1664 */
    width: 100%;
    margin-left: -65px;
}

.img-my_cars img{
    display: block;
    width: 100%;
}

.content-my_cars{
    display: flex;
    flex-direction: column;
    row-gap: 60px;
    padding: 80px 0 160px;
}

.content-my_cars .button{
    max-width: 62.5%; /* 300/480 */
}

.list-char_my_cars h3,
.list-char_my_cars h4{
    font-weight: 500;
}

.list-char_my_cars h3{
    margin-bottom: 30px;
    width: fit-content;
    position: relative;
}

.list-char_my_cars h3::before{
    content: '';
    position: absolute;
    bottom: -10px;
    left: 0;
    width: calc(100% + 50px);
    height: 3px;
    background: #F80215;
    border-radius: 10px;
}

.list-char_my_cars{
    display: flex;
    flex-direction: column;
    row-gap: 15px;
}

.content-my_cars .title{
    position: relative;
    width: fit-content;
}

.content-my_cars .title::before{
    content: '';
    position: absolute;
    background: #F80215;
    border-radius: 2px;
    width: 50px;
    height: 100%;
    z-index: -1;
    right: -10px;
}

.item-galary_grid{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 310px  440px;
    gap: 10px;
}

.item-galary_grid img{
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}


.item-galary_grid div:nth-child(1){
    grid-column-start: 1;
    grid-column-end: 3;
    grid-row-start: 1;
    grid-row-end: 3;
}

.item-galary_grid div:nth-child(2){
    grid-column-start: 3;
    grid-column-end: 5;
    grid-row-start: 1;
    grid-row-end: 2;
}

.swiper-btn{
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
    width: auto;
    height: auto;
    margin: 0;
}

.swiper-btn::after{
    content: '';
}

.swiper-btn.swiper-button-next{
    transform: rotate(180deg);
}

.wrapper-swiper-btn{
    display: flex;
    justify-content: flex-end;
    column-gap: 35px;
    position: relative;
    z-index: 11;
    margin-top: 20px;
}

.swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal{
    bottom: 0;
    --swiper-theme-color: #F80215;
}

.swiper-btn{
    max-width: 3.966346%; /* 66/1664 */
    width: 100%;
}

.swiper-btn img{
    display: block;
    width: 100%;
}

.swiper_photo_mob{
    display: none;
}

.swiper_photo_mob img{
    display: block;
    width: 100%;
    height: 300px;
    object-fit: cover;
}

.swiper-horizontal>.swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal{
    top: auto;
    bottom: 0;
    --swiper-theme-color: #F80215;
}

.wrapper-contact_form{
    position: relative;
    padding: 80px 0;
    box-sizing: border-box;
    background-image: url(../img/contact-form/img.webp);
    background-position: left;
    background-size: cover;
    background-repeat: no-repeat;
    box-shadow: 0px 0px 40px rgba(0, 0, 0, 0.25);
    border-radius: 0px 10px 10px 10px;
}

.wrapper-contact_form::before{
    content: '';
    height: 44px;
    width: 28.725962%; /* 478/1664 */
    background: #F80215;
    position: absolute;
    top: -44px;
    left: 0;
    border-radius: 0 30px 0 0;
}

form input[type = text]{
    display: flex;
    align-items: center;
    padding-left: 23px;
    box-sizing: border-box;
    height: 58px;
    background: #E9E9E9;
    border-radius: 5px;
    border: none;
    width: 100%;
}

.contact_form{
    position: relative;
    z-index: 3;
    max-width: 29.206731%; /* 486/1664 */
    width: 100%;
    margin: 0 4.807692% 0 auto;
}

.contact_form::before{
    content: '';
    width: 30%;
    height: 230px;
    background: #F80215;
    position: absolute;
    left: -30px;
    top: -30px;
    z-index: -1;
    border-radius: 0px 50px 0px 0px;
}

.contact_form::after{
    content: '';
    width: 77%;
    height: 32px;
    background: #F80215;
    border-radius: 0px 10px 0px 0px;
    position: absolute;
    right: 0;
    top: 0;
}

.contact_form form,
.contact_form .button{
    width: 100%;
    max-width: 100%;
}

.contact_form .button{
    margin-top: 10px;
}

.contact_form form{
    display: flex;
    flex-direction: column;
    row-gap: 15px;
    background: #FFFFFF;
    border: 2px solid #FFFFFF;
    box-shadow: 0px 0px 50px rgba(0, 0, 0, 0.15);
    border-radius: 10px;
    padding: 50px 28px;
    box-sizing: border-box;
}

.contact_form h4{
    font-weight: 500;
}

.wrapper-content_contacts{
    position: relative;
    background: #1D1C1C;
    border-radius: 0px 50px;
    padding: 50px 0 70px;
    max-width: 89.302885%; /* 1486/1664 */
    width: 100%;
}

.wrapper-contacts{
    display: flex;
    position: relative;
}

.location-contacts{
    height: 100%;
}

.location-contacts{
    position: absolute;
    right: 0;
    top: 26px;
    height: 100%;
    max-width: 48.076923%; /* 800/1664 */
    width: 100%;
}

.location-contacts iframe{
    height: 100%;
    width: 100%;
    border-radius: 10px;
}

.content-contacts{
    max-width: 372px; /* 372/1483 */
    width: 100%;
    margin: 0 auto 0 13.45895%; /* 200/1486 */
    color: white;
}

.list-contacts_info{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    row-gap: 20px;
}

.list-contacts_info h5{
    font-weight: 500;
}

.list-widjet{
    display: flex;
    column-gap: 6.72043%; /* 25/372 */
    margin-top: 35px;
}

.list-widjet a::before{
    opacity: 0;
}

.list-widjet > li{
    max-width: 12.903226%; /* 48/372 */
    width: 100%;
}

.list-widjet > li img{
    display: block;
    width: 100%;
}

.content-contacts .button{
    max-width: 80.645161%; /* 300/372 */
    margin-top: 48px;
}

.wrapper-content_contacts::before{
    content: '';
    position: absolute;
    left: 0;
    top: -20px;
    max-width: 10.65408%; /* 158/1483 */
    width: 100%;
    height: 267px;
    background: #F80215;
    border-radius: 0px 50px 0px 0px;
}

.location-contacts::before{
    content: '';
    position: absolute;
    height: 20px;
    bottom: -20px;
    right: 0;
    background: #F80215;
    width: 33.375%; /* 267/800 */
    border-radius: 0 0 30px 0;
}

footer{
    padding: 36px 0 40px;
    background: #1D1C1C;
}

.logoTG{
    max-width: 9.915865%; /* 165/1664 */
    width: 100%;
}

.list-footer{
    display: flex;
    justify-content: space-between;
    color: white;
}

.contact-footer_icon h6{
    font-weight: 500;
}

.contact-footer_icon::before{
    content: '';
    display: block;
    width: 40px;
    height: 40px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
}

.contact-footer_icon.location::before{
    background-image: url(../img/svg/sity.svg);
}

.contact-footer_icon.call::before{
    background-image: url(../img/svg/call-footer.svg);
}


.contact-footer_icon{
    display: flex;
    align-items: center;
    column-gap: 15px;
}

.section-modal{
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: #f802162b;
    z-index: 12;
}

.wrapper-modal{
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal{
    position: relative;
    max-width: 44.010417%; /* 845/1920 */
    width: 100%;
    padding: 70px 0;
    box-sizing: border-box;
    background-image: url(../img/modal-bg.webp);
    background-color: #FFFFFF;
    border-radius: 20px;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    text-align: center;
    display: flex;
    align-items: center;
    flex-direction: column;
    row-gap: 25px;
}

.close-modal{
    position: absolute;
    top: 35px;
    right: 35px;
    max-width: 2.60355%; /* 22/845 */
    cursor: pointer;
}

.modal form{
    max-width: 61.301775%; /* 518/845 */
    width: 100%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: 15px;
}

.modal form .button{
    max-width: 57.915058%; /* 300/518 */
}

.modal h5{
    max-width: 80%; 
    font-weight: 400;
}