/* google fonts */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=Hanken+Grotesk:ital,wght@0,100..900;1,100..900&display=swap');

*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    list-style: none;
    text-decoration: none;
    font-family: var(--default-font);
}

body{
    background-color: var(--primary-color);
}
:root{
    --primary-color: #222222;
    --dark-primary-color: #ffffff;
    --secondary-color: #f5f5f5;
    --text-color: #777777;
    --divider-color: #DDDDDD;
    --dark-text-color: #AEAEAE;
    --dark-divider-color: rgba(255, 255, 255, 0.10);
    --error-color: rgba(233, 87, 87);
    --accent-font: "Hanken Grotesk", sans-serif;
    --default-font: "DM Sans", sans-serif;
    --transition: all 0.3s ease-in-out;
    --image-filter: grayscale(100%);
    --image-filter-hover: grayscale(0);
}

/* Common CSS */
section{
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 120px 16%;
    gap: 50px;
}

.section_title{
    width: 50%;
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 20px;
    color: var(--dark-primary-color);
}

.section_title h3{
    font-size: 1rem;
    font-weight: 600px;
    text-transform: uppercase;
    position: relative;
    z-index: 1;
}

.section_title h3::before{
    content: '';
    position: absolute;
    display: block;
    height: 26px;
    width: 26px;
    border-radius: 20px 20px 4px 20px;
    left: -4px;
    top: -5px;
    z-index: -1;
    background-color: #dadada;
    animation: ShapMove 2s infinite alternate;
}

@keyframes ShapMove {
    0%{
        transform: translateX(0px);
    }
    50%{
        transform: translateX(14px);
    }
    100%{
        transform: translateX(0px);
    }
}

.section_title h2{
    font-size: 2.3rem;
    font-family: var(--accent-font);
}

.section_title p{
    font-size: 1rem;
    width: 90%;
    line-height: 1.8rem;
    font-weight: 500;
    color: var(--text-color);
}

.section_image{
    width: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.section_image::after{
    content: '';
    position: absolute;
    top: 0%;
    left: -40%;
    z-index: 2;
    display: block;
    width: 20%;
    height: 100%;
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .1) 100%);
    transform: skewX(-25deg);
    transition: all .4s;
}

.section_image:hover::after{
    left: 120%;
}

.section_image img{
    width: 100%;
    height: 100%;
    border-radius: 50% 50% 50% 10%;
    /* filter: var(--image-filter); */
    transition: var(--transition);
}

.section_image img:hover{
    filter: var(--image-filter-hover);
}

.section_icon{
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--primary-color);
    min-width: 100px;
    min-height: 100px;
    padding: 16px;
    border-radius: 50px 50px 50px 10px;
    transform: scale(1.1);
    transition: var(--transition);
}

.section_icon img{
    width: 80%;
}

.section_icon:hover{
    transform: scale(1);
}

.section_content{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.section_content h2{
    font-size: 1.2rem;
    font-weight: 700;
}

.section_content p{
    color: var(--text-color);
    font-weight: 500;
    font-size: 1rem;
    line-height: 1.5rem;
    width: 80%;
    margin: 0 auto;
}

.btn{
    width: 140px;
    height: 50px;
    border: 2px solid var(--dark-primary-color);
    background-color: transparent;
    border-radius: 30px;
    cursor: pointer;
    overflow: hidden;
    position: relative;
}

.btn a{
    position: relative !important;
    color: var(--dark-primary-color) !important;
    z-index: 1 !important;
    font-weight: 600 !important;
    font-family: var(--accent-font) !important;
}

.btn::after{
    content: "";
    position: absolute;
    top: 0%;
    left: 0%;
    height: 100%;
    width: 0%;
    background-color: var(--dark-primary-color);
    border-radius: 30px;
    transition: var(--transition);
}

.btn:hover::after{
    width: 100%;
}

.btn:hover a{
    color: var(--primary-color) !important;
}

.sticky{
    background-color: rgba(0, 0, 0, 0.8);
    border-bottom: 0.2px solid var(--dark-primary-color);
}

/* ------------   navbar  -----------------*/
nav{
    width: 100%;
    height: 100px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    top: 0%;
    left: 0%;
    padding: 0 16%;
    z-index: 999;
    transition: var(--transition);
    border-bottom: 1px solid var(--dark-divider-color);
}

nav .logo{
    width: 130px;
}

.logo img{
    width: 80px;
}

nav .menu{
    display: flex;
    align-items: center;
    gap: 45px;
}

nav .menu li a{
    color: var(--dark-primary-color);
    font-size: 1rem;
    transition: var(--transition);
    font-weight: 600;
}

nav .menu li a:hover{
    color: var(--dark-text-color);
}

#toggle{
    display: none;
}


.social1{
    width: 65px; /* Ensure both buttons are the same size */
    height: 65px; 
    position: fixed;
    right: 10px;
    border-radius: 60%; /* Make it a perfect circle */
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999999;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2); /* Add subtle shadow for better visibility */
    bottom: 30px;
    background: linear-gradient(45deg, rgb(35, 205, 20));
}
.social1 a{
    font-size: 2.6rem;
    color: var(--dark-primary-color);
}

.social2{
    width: 65px; /* Ensure both buttons are the same size */
    height: 65px; 
    position: fixed;
    right: 10px;
    border-radius: 60%; /* Make it a perfect circle */
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999999;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2); /* Add subtle shadow for better visibility */
    bottom: 100px;
    background: linear-gradient(45deg, #F09433, #E6683C, #DC2743, #CC2366, #BC1888);
}

.social2 a{
    font-size: 2.6rem;
    color: var(--dark-primary-color);
}

/* HERO SECTION */
.hero{
    min-height: 90vh;
    margin-top: 45px;
    padding-bottom: 80px;
}

.hero_title h3::before{
    background-color: #595959;
}

.hero_title ul{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.hero_title ul li{
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--dark-text-color);
    padding-bottom: 10px;
}

.hero_title ul li:nth-child(1){
    border-bottom: 1px solid var(--dark-divider-color);
}

.hero_btns{
    width: 100%;
    display: flex;
    align-items: center;
    gap: 20px;
}

.hero_btns button:nth-child(2){
    width: 160px;
}

figure{
    border-radius: 400px 400px 400px 50px;
    overflow: hidden;
    width: auto;
    position: relative;
}

figure img{
    width: 100%;
}

/* -------------FEATURES------------------*/
.MySplide{
    background-color: var(--secondary-color);
    padding: 30px 0;
}

.Feature-Tricker-Splide{
    width: 250px !important;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    font-size: 1rem !important;
    font-weight: 600 !important;
}

.Feature-Tricker-Splide img{
    width: 10%;
}

/*------------- ABOUT SECTION---------*/
.About{
    background-color: var(--dark-primary-color);
    gap: 50px;
}
.About {
    display: flex;
    justify-content: space-between;
    align-items: center;
}


.About_Page{
    height: 500px;
    width: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
}

.About_img1{
    height: 100%;
    width: 80%;
    border-radius: 50px 50px 0px 50px;
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

.About_img1 img{
    width: 100%;
    border-radius: 0;
}

.About_title{
    color: var(--primary-color);
}

.About_title p{
    width: 100%;
}

.About_title ul{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.About_title ul li{
    font-size: 1rem;
    font-weight: 700;
    border-bottom: 1px solid var(--divider-color);
    padding-bottom: 10px;
    color: var(--text-color);
}

.About_title ul li span{
    color: var(--primary-color);
}

.About_title .btn{
    border: 2px solid var(--primary-color);
}

.About_title .btn a{
    color: var(--primary-color) !important;
}

.About_title .btn::after{
    background-color: var(--primary-color);
}

.About_title .btn:hover a{
    color: var(--dark-primary-color) !important;
}

/*----------------SERVICE SECTION------------------*/
.Service{
    background-color: var(--secondary-color);
    flex-direction: column;
}

.service_title{
    width: 100%;
    text-align: center;
    align-items: center;
    color: var(--primary-color);
}

.service_wrap{
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    place-content: center;
    place-items: center;
    gap: 50px;
}

.service_item{
    width: 100%;
    display: flex;
    text-align: center;
    align-items: center;
    flex-direction: column;
    gap: 30px;
}

/*----------------SERVICE SECTION------------------*/
.feature{
    background-color: var(--dark-primary-color);
}

.feature_title{
    color: var(--primary-color);
}

.feature_wrap{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 30px;
    padding-top: 30px;
}

.feature_icon{
    width: 120px;
    transform: scale(1);
    border-radius: 50px 50px 10px 50px ;
}

.feature_icon img{
    width: 70%;
}

.feature_item{
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 30px;
}

.feature_content{
    gap: 14px;
}

.feature_content p{
    width: 100%;
    margin: 0;
}

/*----------------PhotoGallery SECTION------------------*/
.photo_gallery{
    padding: 120px 0%;
    background-color: var(--secondary-color);
    flex-direction: column;
}

.photo_gallery_title{
    width: 100%;
    align-items: center;
    text-align: center;
    color: var(--primary-color);
}

.Phot_Gallery_Image{
    width: 100%;
    border-radius: 0;
}

.Phot_Gallery_Image img{
    border-radius: 50px 50px 50px 10px;
}

/*----------------BEST PRICE SECTION------------------*/

.best_price{
    flex-direction: column;
    background-color: var(--dark-primary-color);
}

.price_title{
    align-items: center;
    text-align: center;
    width: 100%;
    color: var(--primary-color);
}

.best_price_main{
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    place-content: center;
    place-items: center;
    gap: 30px;
}

.price_card{
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--secondary-color);
    padding: 40px;
    border-radius: 50px 50px 10px 50px;
    position: relative;
    transition: var(--transition);
    z-index: 1;
}

.price_card::after{
    content: '';
    position: absolute;
    height: 100%;
    width: 0%;
    top: 0%;
    left: 0%;
    border-radius: 50px 50px 10px 50px;
    background-color: var(--primary-color);
    z-index: -1;
    opacity: 1;
    transition: var(--transition);
}

.price_card:hover::after{
    opacity: 1;
    width: 100%;
}

.price_card:hover .price_content h2{
    color: var(--dark-primary-color);
}

.price_card:hover .price_icon{
    background-color: var(--dark-primary-color);
    color: var(--primary-color);
}

.price_content h2{
    font-size: 1.5rem;
    transition: var(--transition);
}

.price_content p{
    width: 100%;
    margin: 0;
}

.price_icon{
    height: 80px;
    width: 80px;
    font-family: var(--accent-font);
    color: var(--dark-primary-color);
    border-radius: 50px 50px 50px 8px;
    font-size: 1.6rem;
    font-weight: 600;
    transition: var(--transition);
}


/*----------------Contact SECTION------------------*/
.contact{
    display: grid;
    grid-template-columns: repeat(3,1fr);
    place-content: center;
    place-items: center;
    border-bottom: 1px solid var(--dark-divider-color);
    gap: 30px;
}

.contact_col{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 25px;
    align-items: center;
    text-align: center;
    color: var(--dark-primary-color);
}

.contact_icon{
    height: 70px;
    width: 70px;
    background-color: var(--dark-primary-color);
    border-radius: 50px 50px 10px 50px;
}

.contact_icon img{
    width: 80%;
}

.contact_info h2{
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 10px;
}

.contact_info ul{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.contact_info ul li{
    font-size: 1rem;
    color: var(--dark-text-color);
}

.contact_info p{
    font-size: 1rem;
    width: 70%;
    margin: 0 auto;
    color: var(--dark-text-color);
}


/*----------------Footer SECTION------------------*/
footer{
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    /* padding: 10px 2%; */
}

.footer_left{
    width: 40%;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.footer_logo{
    width: 130px;
}

.footer_logo img{
    width: 130px;
}

.social_icon{
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 20px;
}

.social_icon a{
    font-size: 1.5rem;
    color: var(--dark-primary-color);
    height: 40px;
    width: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 20px 20px 6px 20px;
    background-color: var(--dark-divider-color);
    transition: var(--transition);
}

.social_icon a:hover{
    transform: translateY(-10px);
}

.social_icon a:nth-child(1){
    background: linear-gradient(45deg, rgb(35, 205, 20));
}

.social_icon a:nth-child(2){
    background: linear-gradient(45deg, #F09433, #E6683C, #DC2743, #CC2366, #BC1888);
}

.footer_right{
    width: 60%;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 20px;
}

.footer_right ul{
    display: flex;
    justify-content: flex-end;
    align-items: start;
    gap: 30px;
    color: var(--dark-text-color);
}

.footer_right ul li a{
    font-size: 1.1rem;
    font-weight: 500;
    transition: var(--transition);
    color: var(--text-color);  
}

.footer_right ul li a:hover{
     color: var(--dark-primary-color);
}

.footer_right p{
    color: var(--dark-text-color);
}

.footer_right p span{
    color: var(--dark-primary-color);
    font-weight: 600;
    font-family: var(--accent-font);
    letter-spacing: 1px;
}




/* --------------------------- RESPONSIVE SCREENS ------------------------- */
@media screen and (max-width: 1400px) {
    section{
        padding: 70px 8%;
    }
    nav{
        padding: 0px 10%;
    }
    .MySplide{
        padding: 20px 0;
    }
    .price_card{
        padding: 30px;
    }
    footer{
        padding: 70px 8%;
    }
}

@media screen and (max-width: 1200px) {
    section{
        padding: 70px 8%;
        gap: 20px;
    }
    .section_title h2{
        font-size: 2.7rem;
    }
    nav{
        padding: 0px 8%;
    }
    .About_title ul li{
        font-size: 0.8rem;
    }
    .About_title h2{
        font-size: 2.5rem;
    }
    .feature_content h2{
        font-size: 1.2rem !important;
    }
    .photo_gallery{
        gap: 80px;
    }
    .best_price_main{
        grid-template-columns: repeat(2,1fr);
    }
    footer{
        padding: 70px 8%;
    }
}




@media screen and (max-width: 900px) {
    section{
        flex-direction: column;
        padding: 70px 2%;
    }
    .section_title{
        width: 100%;
    }
    .section_image{
        width: 100%;
    }
    .section_image img{
        width: 70%;
    }
    
    #toggle{
        display: block;
        font-size: 2.3rem;
        font-weight: 700;
        color: var(--dark-primary-color);
    }

    nav{
        padding: 0px 2%;
    }

    .menu{
        height: 0;
        position: absolute;
        flex-direction: column;
        align-items: start !important;
        top: 100%;
        left: 0%;
        width: 100%;
        background-color: var(--dark-primary-color) !important;
        padding-left: 5%;
        opacity: 0;
        overflow: hidden;
        transition: all .2s;
        z-index: 999;
        gap: 30px !important;
        padding-top: 20px;
        border-bottom: 1px solid var(--primary-color);
    }

    .menu li button{
        display: flex;
        justify-content: flex-start;
        align-items: center;
        height: 20px;
    }

    .menu li a{
        color: var(--primary-color) !important;
    }

    .show-menu{
        height: 220px;
        opacity: 1;
    }

    .hero{
        flex-direction: column-reverse;
    }

    .Feature-Tricker-Splide{
        width: 180px;
        font-size: 1rem;
    }

    .About_Page{
        width: 100%;
    }

    .About_img1{
        width: 50% !important;
    }

    .About_img1 img{
        width: 100%;
    }
    .About_Img2 img{
        width: 100%;
    }
    .service_wrap{
        grid-template-columns: repeat(2, 1fr);
    }
    .Phot_Gallery_Image img{
        width: 100% !important;
    }
    footer{
        padding: 70px 2%;
    }
}

@media (max-width: 768px) {
    .About {
        flex-direction: column;
    }

    .About_Page {
        width: 100%;
        height: auto;
        flex-direction: column;
    }

    .About_img1 {
        width: 100%;
        height: auto;
        border-radius: 20px;
        justify-content: center;
        align-items: center;
    }

    .About_img1 img {
        width: 100%;
        border-radius: 20px;
    }

    .About_title {
        width: 90%;
        padding: 20px 0;
    }
}


@media screen and (max-width: 768px) {
    .best_price_main{
        grid-template-columns: repeat(1,1fr);
    }
    .price_card{
        width: 90%;
    }
    .contact{
        grid-template-columns: repeat(2,1fr);
    }
    footer{
        flex-direction: column;
        gap: 50px;
        padding: 30px 2%;
    }
    .footer_left{
        width: 100%;
        align-items: center;
    }
    .social_icon{
        justify-content: center;
    }
    .footer_right{
        width: 100%;
        align-items: center;
    }
    .footer_right ul{
        justify-content: center;
    }
}

@media screen and (max-width: 500px) {
    .section_title h2{
        font-size: 1.9rem;
    }
    .section_title h3{
        font-size: 0.9rem;
        font-weight: 500;
    }
    .section_title p{
        width: 90%;
    }
    .hero ul li{
        font-size: 1.2rem;
    }

    .About_Year h4{
        font-size: 2.7rem;
    }
    .service_wrap{
        grid-template-columns: repeat(1, 1fr);
    }
    .feature_title{
        text-align: center;
        align-items: center;
    }
    .feature_item{
        flex-direction: column;
    }
    .feature_content{
        text-align: center;
    }
    .feature_content p{
        margin: 0 auto;
    }
    .feature_icon img{
        width: 50%;
    }
    .feature_icon{
        min-width: 90px;
    }
    .Phot_Gallery_Image img{
        width: 100% !important;
    }
    .price_card{
        width: 100%;
    }
    .contact{
        grid-template-columns: repeat(1,1fr);
    }
    .footer_right ul{
        gap: 20px;
    }
    .footer_right ul li a{
        font-size: 0.9rem;
    }
    .footer_right p{
        font-size: 0.8rem;
    }
}
