:root {
    --primary-color: #d22c60
}

* {
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}

html {
    font-family: 'Montserrat', sans-serif;
    scroll-behavior: smooth;
}

.grid {
    width: 1120px;
    max-width: 100%;
    /* height: 100%; */
    margin: 0 auto;
    position: relative;

}

/* HEADER */

.header {
    padding: 25px 0;
    /* height: 1200px !important; */
    
}

.header-wrap {
    width: 100%;
    display: flex;
    justify-content: space-between;
    position: absolute;
    top: 0;
    left: 0;
}

.header-logo img {
    height: 40px;
}

.header__menu {
    display: flex;
    justify-content: end;
    background-color: var(--primary-color);
    border-radius: 50px;
    transition: 0.5s;
    max-width: 50px; 
    width: 660px;
}

.menu__list {
    display: flex;
    padding-left: 15px;
    display: none;
}

.menu-item {
    list-style: none;
    text-decoration: none;
    position: relative;
    list-style: none;
    margin: 10px;
    display: flex;
    align-items: center;
    font-size: 14px;
    font-weight: 600;
    color: #FFFFFF;
    white-space: nowrap;
    cursor: pointer;
}
.menu-item:hover {
    opacity: 0.9;
}

.menu-icon {
    height: 50px;
    width: 50px;
    border-radius: 100%;
    background-color: var(--primary-color);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    padding: 15px;
    cursor: pointer;
}

.menu-icon .dash {
    height: 2px;
    width: 14px;
    background-color: #FFFFFF;
    margin: 2px;
    transition: 0.3s;
}

.menu-icon .dash:nth-child(3) {
    width: 18px;
}

.menu-icon .dash:nth-child(1) {
    width: 10px;
}

.menu-icon:hover .dash:nth-child(1) {
    width: 18px;

}

.menu-icon:hover .dash:nth-child(3) {
    width: 10px;

}

.menu-open .dash:nth-child(1){
    width: 18px;

}
.menu-open .dash:nth-child(3){
    width: 10px;

}
.header-title{
    position: absolute;
    top: 200px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 34px;
    font-weight: 600;
    font-family: 'Montserrat', sans-serif;

}
.header-img{
    position: absolute;
    top: 500px;
    left: 50%;
    transform: translateX(-50%);
    width: 900px;
}

/* About us */
.about-us{
    padding: 80px 0px;
    font-family: 'Montserrat', sans-serif;

}
.main-title{
    font-size: 36px;
    position: relative;
    display: inline-block;
    margin-bottom: 30px;
    font-weight: 600;
}
.main-title::after{
    content: "";
    position: absolute;
    /* height: 4px; */
    width: 50%;
    border-top: 4px dashed var(--primary-color);
    top: 100%;
    left: 0;
    margin-top: 10px;
}
.describe{
    font-size: 16px;
    color: #797979;
    line-height: 1.8;
}
.achievement__wrap{
    flex: 1;
    
}
.achievement{
    display: flex;
    justify-content: space-between;
    margin-top: 40px;
}
.achievement__wrap i{
    font-size: 50px;
    color: var(--primary-color);
    margin-bottom: 10px;

}
.achievement__wrap--num{
    font-size: 36px;
    font-weight: 700;
    margin-bottom: 10px;

}
.achievement__wrap--name{
    font-size: 15px;
    color: #797979;

}
/* FEATURE */
.our-feature{
    background-color: #F0F4F6;
    padding: 80px 0;
    font-family: 'Montserrat', sans-s   erif;
    /* overflow: hidden; */

}
.our-feature__wrap{
    width: 100%;
    display: flex;
    justify-content: end;
    
}
.our-feature__content{
    width: 74%;
    display: grid;
    grid-template-columns: auto  auto ;
    grid-template-rows: auto auto auto;
    gap: 20px;
}
.our-feature__wrap img{
    position: absolute;
    width: 440px;
    top: 0;
    top: -40px;
    left: -180px;
}

.feature-item{
    background-color: white;
    /* margin-bottom: 15px; */
    padding: 24px;
    border-radius: 10px;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}
.feature-item i{
    font-size: 50px;
    color: var(--primary-color);
    margin-bottom: 10px;

}
.feature-title{
    font-size: 20px;
    margin-bottom: 10px;
    font-weight: 600;
}
.feature-sub{
    font-size: 14px;
    line-height: 1.6;
    color: #797979;
}
/* Contact */
.contact{
    padding: 80px 0;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.contact::after{
    content: "";
    background: url('/assets/img/contact-left-bg.png');
    background-repeat: no-repeat;
    height: 450px;
    width: 450px;
    position: absolute;
    bottom: 0;
    left: 0;
}
.contact::before{
    content: "";
    background: url('/assets/img/contact-right-bg.png');
    background-repeat: no-repeat;
    height: 450px;
    width: 450px;
    position: absolute;
    top: 0;
    right: 0;
}
.contact i{
    font-size: 50px;
    background: -webkit-linear-gradient(50deg, #b033b0, #e12d58);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.contact h5{
    color: #262626;
    font-size: 20px;
    margin: 10px 0; 
}
.contact p{
    color: #797979;
    font-size: 16px;
}
    /* review */
.review{
    width: 100%;
    padding: 80px 0;
    position: relative;
    overflow: hidden;
    background-color: #fff3f7;
}
.review::after{
    content: "";
    height: 198px;
    width: 6400px;
    bottom: 0;
    left: 0;
    position: absolute;
    background: url(/assets/img/wave.png);
    background-size: 25% 100%;
    background-repeat:repeat;
    animation: move_wave 20s linear infinite;
}
.review::before{
    content: "";
    height: 198px;
    width: 6400px;
    bottom: 0;
    left: 0;
    position: absolute;
    background: url(/assets/img/wave.png);
    background-size: 25% 100%;
    background-repeat:repeat;
    animation: move_wave 18s linear infinite;
    transform: translateY(-20px);
    opacity: 0.5;
}
.review__wrap{
    text-align: center;
}
.review__wrap h1::after{
    left: 50%;
    transform: translateX(-50%);
}
.review__content{
    padding: 30px 0;
    margin: 60px 0 120px 0;
}
.review__list{
    margin: 0 -15px;
    text-align: left;
}
.review__item{
    position: relative;
    padding: 30px;
    background-color: white;
    border-radius: 10px;
    width: 500px;
    max-width: 600px;
    max-height: 300px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
    margin: 15px;
    overflow: hidden;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}
.review__item::after{
    content: "";
    position: absolute;
    height: 150px;
    width: 150px;
    background-color: #dcebff;
    top: -80px;
    right: -80px;
    border-radius: 100%;
    transition:  0.2s linear;

}
.review__item:hover::after{
    height: 180px;
    width: 180px;
    transition:  0.3s linear;
}
.review__comment{
    position: relative;
    font-size: 16px;
    color: #797979;
    z-index: 99;
}
.author-info{
    position: relative;
    display: flex;
    margin-top: 30px;
    align-items: center;
    z-index: 99;
}
.author-info .author-img{
    width:  55px;
    border-radius: 100%;
}
.author__info-wrap{
    margin-left: 10px;
}
.author-name{
    color: #DA2E64;
    font-size: 16px;
    font-weight: 600;
}
.author-position{
    font-size: 14px;
    color: #262626;
}
.quote{
    position: absolute;
    height: 20px ;
    bottom: 30px;
    right: 30px;
}
/* Footer */
.footer{
    background: linear-gradient(-45deg, #EE7752, #E73C7E, #23A6D5, #23D5AB);
    background-size: 400% 400%;
    padding: 120px 0px;
    animation: Gradient 15s ease infinite;
}
.footer-wrap{
    width: 100%;
    display: flex;
    align-items: center;
    bottom: 100px;

}
.footer--logo{
    width: 33.3%;

}
.footer .copy-right{
    width: 33.3%;
    display: block;
    text-align: center;
    color: white;
    font-size: 14px;

}
.footer--logo img{
    height: 40px;
}
/* HEADDER STICK */
.header-stick{
    /* display: none; */
    transform: translateY(-100%);
    width: 100%;
    position: fixed;
    z-index: 99;
    background-color: white;
    border-bottom: 1px solid #b8b6b6;
    padding: 10px 0;
    box-shadow: rgba(0, 0, 0, 0.04) 0px 3px 5px;
    transition: 0.3s ease-in;
}
.header-stick .grid{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
/* button head page */
.head-page__button{
    height: 50px;
    width: 50px;
    position: fixed;
    bottom: 30px;
    right: 30px;
    border-radius: 100%;
    background-color: var(--primary-color);
    font-size: 28px;
    transform: translateY(200px);
    /* opacity: 0; */
    /* transition: opacity 0.5s ease-in; */
    transition: transform 0.5s ease-in;

    color: white;
    z-index: 99;
    cursor: pointer;
}
.head-page__button i{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.head-page__button:hover{
    background-color: #797979;
}
@keyframes Gradient {
    0% {
         background-position: 0% 50%
    }
    50% {
         background-position: 100% 50%
    }
    100% {
         background-position: 0% 50%
    }
}
@keyframes move_wave {
    0% {
        transform: translateX(0) 
    }
    50% {
        transform: translateX(-25%) 
    }
    100% {
        transform: translateX(-50%) 
    }
}
