:root{
    --main-font: 'Montserrat', sans-serif;
    --black: #000000;
    --main-color: #E7C437;
    --main-color-2: #816D1F;
    /*--main-gradient-2: linear-gradient(-180deg, rgb(231, 196, 55) 8.214%,rgb(129, 109, 31) 101.071%);*/
    /* --main-gradient: #E7C437; */
    --main-gradient: linear-gradient(-180.00deg, #fcd94c,#A18929);
    --main-gradient-2: linear-gradient(-180.00deg, #f6d654, #ba9f32);
    --gray: #AEAEAE;
    --border-color: #D9D9D9;
    --white: #ffffff;
    --image-border-radius: 24px;
    --btn-border-radius: 4px;
    --items-box-shadow: 0 0 20px 0 #00000045;
    --section-distance: 120px;
    --size-1: 15px;
    --size-2: 25px;
    --size-3: 45px;
 
}

@font-face {
    font-family: "Montserrat";
    src: url("../fonts/Montserrat/Montserrat-Regular.woff2") format("woff2");
    font-weight: 400;
    font-style: normal
}
@font-face {
    font-family: "Montserrat";
    src: url("../fonts/Montserrat/Montserrat-SemiBold.woff2") format("woff2");
    font-weight: 500;
    font-style: normal
}
@font-face {
    font-family: "Montserrat";
    src: url("../fonts/Montserrat/Montserrat-Bold.woff2") format("woff2");
    font-weight: 600;
    font-style: normal
}

/* common styles */

*{
    margin: 0;
    padding: 0;
    box-sizing: border-box
}
html{
    font-size: 10px
}
body{
    font-size: 1.6rem;
    font-family: var(--main-font);
    font-weight: 400;
    line-height: normal;
    color: var(--black);
    letter-spacing: 1px
}
address{
    font-style: normal
}
.container{
    width: 100%;
    max-width: 1440px;
    padding: 0 20px;
    margin: 0 auto
}
a{
    text-decoration: none;
    transition: 0.3s
}
section a:not(.btn){
    color: var(--main-color)
}
section a:not(.btn):hover, h1 span, h2 span, h3 span{
    background: var(--main-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: 0.3s
}

h1{
    font-size: 4.5rem;
    font-weight: 600
}

h2{
    font-size: 4rem;
    font-weight: 600
}

h3{
    font-size: 2.8rem;
    font-weight: 600
}
section ul:not(:first-child){
    margin-top: var(--size-1)
}
ul li{
    list-style: none
}
ul li:not(nav ul li){
    padding-left: 20px;
    position: relative
}
ul li:not(nav ul li):before{
    content: '✧';
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 1px;
    color: var(--main-color)
}
ul li:not(nav ul li):not(:first-child), ol li:not(:first-child){
    margin-top: 10px
}
ul.advantages-list li{
    padding-left: 45px;
    position: relative
}
ul.advantages-list li:not(:first-child){
    margin-top: var(--size-1)
}
ul.advantages-list li:before{
    content: '';
    width: 30px;
    height: 30px;
    background: url('../img/icons/success-arrow-white.svg'),  var(--main-gradient);
    background-position: center center, center center;
    background-repeat: no-repeat, no-repeat;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: -1px;
    color: var(--main-color)
}
ol{
    counter-reset: item
}
ol li{
    list-style: none;
    padding-left: 27px;
    position: relative;
    counter-increment: item
}
ol li:before{
    content: counter(item)'.';
    color: var(--main-color);
    position: absolute;
    left: 0;
    font-weight: 600
}
.subtitle div{
    width: 45px;
    height: 1px;
    background: var(--main-gradient)
}
.subtitle{
    background: var(--main-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
     text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: var(--size-1);
    margin-bottom: 10px;
    font-weight: 500;
    letter-spacing: 4px
}
section p, section li{
    line-height: 1.6
}
section p:not(:first-child), h2 + div{
    margin-top: var(--size-1)
}
.play-pause {
    width: 80px;
    height: 80px;
    background-color: #ffffff65;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-40px, -40px);
    cursor: pointer;
    padding-left: 6px;
    z-index: 10;
}
.owl-carousel{
    height: auto!important
}
.testimonials .owl-carousel{
    width: 100% !important
}
.about__media .owl-carousel .img-container > video, .about__media .owl-carousel .img-container >img,
.services__media .owl-carousel .img-container > video, .services__media .owl-carousel .img-container >img,
.projects__media .owl-carousel .item >div:first-child > video, .projects__media .owl-carousel .item >div:first-child >img
{
    height: 440px
}

.owl-carousel .owl-item .play-pause img{
    width: 25px;
    height: auto
}
input{
    background-color: var(--white);
    font-size: 1.6rem;
    color: var(--black);
    padding: 16px 30px;
    border: none;
    outline: none;
    border-radius: var(--btn-border-radius)
}



/* end of common styles */



/* common class styles */

/* buttons */
.btn, .contacts__content form .wpcf7-submit{
    padding: 16px 45px;
    font-weight: 600;
    font-size: 1.8rem;
    color: var(--white);
    border-radius: var(--btn-border-radius);
    background: var(--main-gradient);
    text-decoration: none;
    text-align: center;
    display: inline-block;
    width: fit-content;
    text-wrap-mode: nowrap;
    cursor: pointer;
    /* text-transform: uppercase; */
    transition: 0.3s
}
.btn:hover, .contacts__content form .wpcf7-submit:hover{
    background: var(--main-gradient-2);
    transition: 0.3s
}
.empty-btn{
    background: transparent;
     box-shadow: inset 0 0 0 1px var(--white);
    transition: 0.3s
}
.empty-btn:hover{
    background: transparent;
    background: var(--main-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    box-shadow: inset 0 0 0 1px var(--main-color);
    transition: 0.3s
}
.btns{
    display: flex;
    align-items: center;
    gap: var(--size-1)
}

/* end of buttons */
.grid-2{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 120px
}
.grid-3{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--size-2)
}
.grid-4{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--size-2)
}


.none{
    display: none!important
}


.img-container{
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden
}
.img-container img, .img-container video{
    object-fit: cover;
    width: 100%;
    height: 100%
}
.black-bg{
    background-color: var(--black)
}
.black-bg h2:not(.owl-carousel h2), .black-bg p:not(.owl-carousel p), .black-bg li:not(.owl-carousel li){
    color: var(--white)
}
.img-b-r{
    border-radius: var(--image-border-radius);
}
.bg{
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover
}
section .overlay{
    width: 100%;
    height: 100%;
    background: #00000065;
    position: absolute;
    top: 0;
    left: 0
}

/* end of common class styles */


/* top banner */
.top-banner{
    padding-top: 12px;
    padding-bottom: 12px;
    background-color: #191B1D8C
}
.top-banner address{
    display: flex;
    align-items: center;
    gap: 45px;
    width: fit-content;
    margin: 0 auto
}
.top-banner a{
    color: var(--white)
}
.location{
    padding-left: 20px;
    position: relative;
    display: inline-flex;
    align-items: center
}
.location:before{
    content: url("../img/icons/location-main-gradient.svg");
    width: 9px;
    height: 15px;
    position: absolute;
    top: 1px;
    left: 0
}

.tel{
    padding-left: 24px;
    position: relative;
    display: inline-flex;
    align-items: center
}
.tel:before{
    content: url("../img/icons/tel-main-gradient.svg");
    width: 15px;
    height: 15px;
    position: absolute;
    top: 2px;
    left: 0
}
.social a, .social a:hover{
    transition: 0.3s;
    display: inline-block;
    width: 40px;
    height: 40px
}
.social{
    display: flex;
    align-items: center;
    gap: 10px
}
.viber{
    background: url("../img/icons/v.svg");
    background-size: contain;
    background-repeat: no-repeat
}
.tg{
    background: url("../img/icons/tg.svg");
    background-size: contain;
    background-repeat: no-repeat
}

.instagram{
    background: url("../img/icons/i.svg");
    background-size: contain;
    background-repeat: no-repeat
}
.fb{
    background: url("../img/icons/f.svg");
    background-size: contain;
    background-repeat: no-repeat
}
.email{
    background: url("../img/icons/email.svg");
    background-size: contain;
    background-repeat: no-repeat
}
.viber:hover{
    background: url("../img/icons/v-hover.svg");
    background-size: contain;
    background-repeat: no-repeat
}
.tg:hover{
    background: url("../img/icons/tg-hover.svg");
    background-size: contain;
    background-repeat: no-repeat
}

.instagram:hover{
    background: url("../img/icons/i-hover.svg");
    background-size: contain;
    background-repeat: no-repeat
}
.fb:hover{
    background: url("../img/icons/f-hover.svg");
    background-size: contain;
    background-repeat: no-repeat
}
.email:hover{
    background: url("../img/icons/email-hover.svg");
    background-size: contain;
    background-repeat: no-repeat
}
/* end of top banner */

/* header */
header{
   position: fixed;
   width: 100%;
   z-index: 2
}

.header{
    padding-top: var(--size-1);
    padding-bottom: var(--size-1);
    background-color: var(--black)
}
.header .logo img{
    height: 60px
}

.main-menu a{
    color: var(--white);
    font-weight: 500;
    text-transform: uppercase
}
.main-menu ul li{
    cursor: pointer;
    position: relative;
    display: flex
}
.main-menu >nav >ul{
    display: flex;
    align-items: center;
    gap: 35px
}
.main-menu ul li:hover a{
    background: var(--main-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent
}

.header .container{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--size-3);
    max-width: 100%
}

/* end of header */
.owl-nav{
    display: none
}
.owl-nav button{
    margin: 0px 0 0!important;
    transition: 0.3s
}
.owl-stage-outer, .owl-stage, .owl-item, .owl-item > .item{
    height: 100%
}
.owl-item > .item{
    position: relative
}
.about__media, .services__media, .projects__media{
    position: relative
}

.owl-carousel .description{
    position: absolute;
    bottom: 0;
    padding: var(--size-2);
    background: #ffffff75;
    width: 100%;
    text-align: center
}
.owl-carousel .description div{
    color: var(--black);
    margin-top: 10px
}

.slider-nav .next, .slider-nav .prev{
    width: 55px;
    height: 55px;
    background: url('../img/icons/right-white-long-arow.svg'),  var(--main-gradient);
    background-position: center center, center center;
    background-repeat: no-repeat, no-repeat;
    border-radius: 50%;
    position: absolute;
    top: calc(50% - var(--size-2));
    z-index: 1;
    cursor: pointer
}
.projects .slider-nav .next, .projects .slider-nav .prev{
    position: static
}
.projects .slider-nav{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    margin-top: var(--size-2)
}
.slider-nav .next{
    right: 20px
}
.slider-nav .prev{
    transform: scale(-1, 1);
    left: 20px
}
.owl-dots{
    display: none
}
.projects__media .slider-nav-wrap, .testimonials .slider-nav-wrap{
    position: relative;
    height: var(--size-3);
    margin-top: var(--size-2)
}
.testimonials .slider-nav-wrap{
    margin-top: 0
}
.projects__media .slider-nav-wrap .prev, .projects__media .slider-nav-wrap .next,
.testimonials .slider-nav-wrap .prev, .testimonials .slider-nav-wrap .next
{
    position: static
}
.projects__media .slider-nav, .testimonials .slider-nav{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--size-1)
}


/* footer */

.footer-top{
    padding: 60px 0;
    background-color: var(--black)
}
.footer-top .logo{
    margin-bottom: var(--size-2)
}
.footer-top .logo img{
    height: 90px
}
.footer__titles, .footer-items{
    gap: var(--size-3)
}
.footer__titles >div{
    display: flex;
    align-items: flex-end
}
.footer-description, .footer-bottom p{
    line-height: 1.6
}
.footer-description, .footer-contacts__items a, .footer-top__title{
    color: var(--white)
}
.footer-contacts__items address a:hover{
    background: var(--main-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent
}
.footer-top__title{
    margin-bottom: var(--size-2);
    text-transform: uppercase;
    font-weight: 600
}
.footer-contacts__items address{
    display: flex;
    flex-direction: column;
    gap: var(--size-1)
}

.footer-contacts__items .social{
    margin-top: var(--size-1)
}
.footer-top iframe{
    width: 100%;
    height: 250px;
    border-radius: var(--image-border-radius)
}



.footer-bottom{
    padding: 20px 0;
    background-color: var(--black)
}
.footer-bottom{
    border-top: 1px solid var(--border-color);
    color: var(--white);
    text-align: center
}
.footer-bottom a{
    color: var(--white);
    transition: 0.3s
}
.footer-bottom a:hover{
    background: var(--main-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: 0.3s
}


/* end of footer */