*{
margin: 0;
padding: 0;
box-sizing: border-box;
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}
p{
line-height: 1.7;
font-size: 18px;
}
 a{
color: inherit;
font-size: inherit;
text-decoration: none;
}
.section_caption{
text-align: center;
}
.section_caption span{
border: 1px solid;
color: #757575;
padding: 6px 14px;
text-transform: uppercase;
border-radius: 20px;
}
.section_title{
text-align: center;
margin-top: 30px;
padding: 0 100px;
}
.section_title h1{
font-size: 66px;
font-weight: 600;
}
.section_title_2{
margin-top: 25px;
font-size: 40px;
font-weight: 600;
}
.styled_word{
font-family: 'Times New Roman', Times, serif;
font-weight: 400;
font-size: inherit;
}









.hero_section{
margin-top: -65px ;
width: 100%;
padding-bottom: 30px;
color: whitesmoke;
background-image: linear-gradient(90deg, rgba(0, 0, 0, 0.75) , rgba(0, 0, 0, 0.75)), url('uploads/hero_section_bg.png'); 
}
.hero_section .column{
width: 100%;
}
.hero_section .content{
width: 100%;
}
.intro_text{
width: 100%;
height: calc(100vh + 65px);
display: flex;
flex-direction: column;
justify-content: flex-end;
align-items: center;
}
.intro_text_content{
 width: 100%;
}
.intro_heading{
text-align: center;
}
.intro_heading h1{
font-size: 135px;
font-weight: 400;
font-family: sans-serif;
}
.intro_description{
border-top: 2px solid;
margin: 0 20%;
display: flex;
align-items: center;
padding: 30px 0;
gap: 50px;
}
.intro_description .left{
width: 60%;
}
.intro_description .right{
width: 40%;
text-align: right;
}
.intro_description button{
padding: 16px 30px;
background-color: white;
text-transform: uppercase;
border: none;
border-radius: 5px;
font-size: 17px;
}
.hero_address{
padding: 0 30px;
height: 45px;
display: flex;
align-items: center;
}
.hero_address p{
    text-transform: uppercase;
    width: 160px;
    font-size: 16px;
    line-height: 1.375;
    padding-left: 10px;
    border-left: 1px solid;
}

























.about_section{
margin-top: 140px;
padding: 0 30px;
width: 100%;
}
.about_section .row{
margin-top: 90px;
width: 100%;
display: flex;
}
.about_section .column_1{
width: 34%;
}
.about_section .column_2{
width: 50%;
}
.about_section .column_3{
width: 16%;
}
.about_section .column_2 .content{
padding: 0 8%;
}
.about_section .content{
width: 100%;
padding: 0 15px;
}

.about_section .column_1 .content{
position: relative;
}
.image_frame{
width: 65%;
height: 340px;
border-radius: 5px;
overflow: hidden;
}
.image_frame_2{
position: absolute;
top:27%;
right:15px;
bottom: 0;
}
.about_section img{
width: 100%;
height: 100%;
object-fit: cover;
border-radius: 5px;
}
.about_section .column_2 h1{
font-size: 28px;
font-weight: 400;
margin-bottom: 40px;
}
.about_section .column_2 p{
margin-bottom: 40px;
}
.about_section .column_2 button{
padding: 14px 30px;
background-color: black;
color: whitesmoke;
text-transform: uppercase;
border: none;
border-radius: 5px;
}






















.ourteam_section{
margin-top: 140px;
padding: 120px 0;
background-color: rgb(248, 248, 248);
}
.ourteam_section .row{
width: 100%;
padding: 0 40px;
display: flex;
}
.ourteam_section .column{
width: 50%;
}
.ourteam_section .column_1 {
display: flex;
flex-direction: column;
justify-content: center;
}
.ourteam_section .content{
width: 100%;
padding: 0 15px;
}
.ourteam_section .column_1 .content{
position: relative;
padding-left: 78px;
}
.ourteam_section .column_2 .content{
position: relative;
}
.ourteam_section .testimonial_icon{
position: absolute;
top: 15px;
left: 0;
width: 51px;
height: 51px;
border-radius: 50%;
font-size: 20px;
background-color: white;
display: flex;
justify-content: center;
align-items: center;
}
.ourteam_section  .title_line{
margin-top: 25px;
width: 80px;
height: 1.5px;
background-color: black;
}
.ourteam_section  .team_member{
font-size: 16px;
margin-top: 10px;
}
.ourteam_section  .job_title{
color: #757575;
font-size: 15px;
}

.ourteam_section .carousel {
    width: calc(100% + 30px);
    overflow: hidden;
}

.ourteam_section .carousel-slides {
    width: 100%;
    display: flex;
    transition: transform 0.5s ease-in-out;
}

.ourteam_section .slide {
    min-width:50%;
    padding-right: 30px;
    text-align: center;
}
.ourteam_section img {
width: 100%;
}

.ourteam_section .slides_nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color:white;
    border-radius: 50%;
    border: none;
    width: 48px;
    height: 48px;
    cursor: pointer;
}
.ourteam_section .slides_nav i{
font-size: 18px;
}
.ourteam_section .prev-btn { left: -10px; }
.ourteam_section .next-btn { right: -10px; }

.ourteam_section .pagination {
    position: absolute;
    bottom: 10px;
    width: 100%;
    text-align: center;
}

.ourteam_section .dot {
    height: 15px;
    width: 15px;
    margin: 0 5px;
    background-color: #bbb;
    border-radius: 50%;
    display: inline-block;
    cursor: pointer;
}
.ourteam_section .active {
    background-color: #717171;
}























.services_section{
margin-top: 140px;
padding: 0 30px;
width: 100%;
}
.services_section .row{
margin-top: 75px;
width: 100%;
display: flex;
}
.services_section .column{
width: 100%;
}
.services_section .content{
width: 100%;
}
.services_section .service_container{
width: 100%;
display: flex;
flex-wrap: wrap;
}
.service_container .service{
padding: 40px 35px;
margin-top: 50px;
width: calc(33.33% - 30px);
margin: 15px;
text-align: left;
border: 1px solid  #d5d5d5;
background-color: white;
border-radius: 5px;
text-align: center;
}
.services_section .item_icon{
margin: auto;
width: 86px;
height: 86px;
border-radius: 50% ;
display: flex;
justify-content: center;
align-items: center;
background-color: rgb(248, 248, 248);
}
.services_section .item_icon i{
font-size: 60px;
font-weight: 400;
}
.service h2{
margin-top: 25px;
font-size: 22px;
font-weight: 600;
}
.service a{
color: inherit;
text-decoration: none;
}
.service p{
margin-top: 15px;
color: #757575;
}
















.start_project_section{
margin-top: 140px;
width: 100%;
display: flex;
}
.start_project_section .column_1{
width: 50%;
margin-top: 20px;
color: whitesmoke;
background-color: black;
padding:140px 70px 140px 8px ;
border-radius: 0 0 5px 0;
}
.start_project_section .column_2{
width: 50%;
margin-bottom: 30px;
border-radius: 5px 0 0 0;
overflow: hidden;
}
.start_project_section .content{
width: 100%;
height: 100%;
}
.start_project_section button{
padding: 16px 30px;
background-color: white;
text-transform: uppercase;
border: none;
border-radius: 5px;
}
.start_project_section .column_1 h1{
font-size: 50px;
font-weight: 600;
}
.start_project_section .column_1 p{
margin-top: 30px;
}
.start_project_section .column_1 button{
margin-top: 50px;
padding: 16px 30px;
background-color: white;
text-transform: uppercase;
border: none;
border-radius: 5px;
font-size: 17px;
}
.start_project_section .column_2 img{
width: 100%;
height: 100%;
object-fit: cover;
}










.pricing_section{
margin-top: 140px;
padding: 30px;
width: 100%;
background-color: rgb(248, 248, 248);
}
.pricing_section .row{
margin-top: 75px;
width: 100%;
}
.pricing_section .column{
width: 100%;
}
.pricing_section .content{
width: 100%;
}
.pricing_section .tab_list{
margin-top: 20px ;
display: flex;
justify-content: center;
gap: 20px;
}
.pricing_tab{
padding: 4px 10px;
border-radius: 18px;
font-size: 14px;
transition: color 0.2s;
cursor: pointer;
}
.pricing_tab.active {
border: 1px solid;
}
.tab_content {
width: 100%;
display: none;
}
.tab_content.active {
display: block;
}
.pricing_section .price_container{
width: 100%;
display: flex;
flex-wrap: wrap;
padding: 0 8%;
}
.pricing_section .price_table{
padding: 30px;
margin-top: 50px;
width: calc(33.33% - 30px);
margin: 15px;
text-align: left;
border: 1px solid white ;
background-color: white;
border-radius: 5px;
text-align: center;
}
.pricing_section .item_icon{
margin: auto;
display: flex;
justify-content: center;
align-items: center;
}
.pricing_section .item_icon i{
font-size: 72px;
font-weight: 400;
}
.price_table .plan_name{
font-size: 28px;
font-weight: 600;
}
.price_table p{
color: #757575;
margin-bottom: 20px;
}
.plan_price{
font-size: 60px;
font-weight: 500;
}
.plan_price sup{
font-size: 22px;
font-weight: 400;
}
.plan_features{
list-style: none;
text-align: left;
width: 180px;
margin: auto;
}
.plan_features li{
color: #757575;
font-size: 17px;
margin-top: 12px;
}
.price_table button{
margin-top: 40px;
background-color: black;
color: whitesmoke;
width: 100%;
border: none;
padding: 13px 20px;
text-transform: uppercase;
border-radius: 4px;
}


















.how_wework_section{
margin-top: 140px;
padding: 0 30px;
width: 100%;
display: flex;
}
.how_wework_section .column_1{
width: 58%;
}
.how_wework_section .column_2{
width: 42%;
}
.how_wework_section .content{
width: 100%;
padding: 0 15px;
}
.how_wework_section .column_1 .content{
padding-right: 33px;
padding-top: 30px;
}
.how_wework_section .images{
width: 100%;
position: relative;
}
.how_wework_section .image_1{
    position: absolute;
    top: 0;
    left: 0;
    width: 37%;
}
.how_wework_section .image_2{
    position: relative;
    width: 77.145%;
    margin: 0 auto;
    padding: 120px 0;
}
.how_wework_section .image_3{
    width: 37%;
    position: absolute;
    bottom: 0;
    right: 0;
}
.how_wework_section  img{
    width: 100%;
}
.how_wework_section h1{
font-size: 44px;
font-weight: 600;
}
.faq-container{
margin-top: 50px;
}
.faq-item {
    border-bottom: 1px solid #ddd;
    padding: 20px 0;
}

.faq-question {
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
}
.faq-question h3{
    font-weight: 600;
    font-size: 20px;
    }
.faq-question i{
font-size: 16px;
}

.faq-answer {
    overflow: hidden;
    height: 0;
    transition: height 0.4s ease; 
}

.faq-item.active .faq-answer {
    height: 80px;
    padding-top: 10px;
}



















.why_choose_section{
margin-top: 140px;
padding: 0 30px;
width: 100%;
}
.why_choose_section .column_1{
width: 100%;
}
.why_choose_section .column_2{
width: 100%;
}
.why_choose_section .content{
width: 100%;
}
.why_choose_section .features_container{
width: 100%;
display: flex;
flex-wrap: wrap;
}
.why_choose_section .feature{
padding-left: 30px;
margin-top: 50px;
width: calc(25% - 30px);
margin: 15px;
text-align: left;
border: 1px solid white ;
background-color: white;
border-radius: 5px;
text-align: left;
border-left: 1px solid #e5e5e5;
}
.why_choose_section  .item_icon i{
font-size: 50px;
font-weight: 400;
}
.why_choose_section .feature h2{
margin-top: 22px;
font-size: 19px;
font-weight: 600;
}
.why_choose_section .feature p{
margin-top: 11px;
color: #757575;
}
.why_choose_section .section_caption {
text-align: left;
}
.why_choose_section  .title_line{
margin-top: 40px;
width: 80px;
height: 1.5px;
background-color: black;
}


























.blog_section{
margin-top: 140px;
padding: 0 30px;
width: 100%;
}
.blog_section .row{
margin-top: 75px;
width: 100%;
display: flex;
}
.blog_section .column{
width: 100%;
}
.blog_section .content{
width: 100%;
}
.blog_section .blog_container{
width: 100%;
display: flex;
flex-wrap: wrap;
}
.blog_container .blog{
margin-top: 50px;
width: calc(33.33% - 30px);
margin: 15px;
text-align: left;
background-color: white;
border-radius: 5px;
text-align: center;
padding-bottom: 32px;
overflow: hidden;
border: 1px solid #d5d5d5 ;
}
.blog_thumbnail {
width:100% ;
height: min-content;
}
.blog_thumbnail img{
width:100% ;
height: auto;
overflow: hidden;
}
.blog .text_content{
text-align: left;
padding: 0 30px;
}
.blog h2{
margin-top: 32px;
font-size: 21px;
font-weight: 600;
}
.blog a{
color: inherit;
text-decoration: none;
}
.blog p{
margin-top: 12px;
color: #757575;
}
.blog .author{
margin-top: 54px;
display: flex;
justify-content: space-between;
align-items: center;
color: #757575;
}
.blog .author .left{
display: flex;
gap: 6px;
align-items: center;
}
.author .avator{
width: 30px;
height: 30px;
border: 1px solid;
border-radius: 50%;
overflow: hidden;
}
.avator img{
width:100% ;
}






















.email_subscribe_section{
width: 100%;
margin-top: 140px;
background-image: linear-gradient(90deg, rgba(0, 0, 0, 0.75) , rgba(0, 0, 0, 0.75)), url('uploads/email_subscribe_bg.png'); 
color: whitesmoke;
padding: 0 45px;
background-attachment: fixed;
background-position: center;
background-repeat: no-repeat;
background-size: cover;
}
.email_subscribe_section .row{
width: 100%;
display: flex;
}
.email_subscribe_section .column_1{
width: 100%;
}
.email_subscribe_section .content{
width: 100%;
padding: 100px 25%;
}
.email_subscribe_section .section_title_2{
text-align: center;
}
.email_subscribe_section .input{
margin-top: 40px;
display: flex;
justify-content: space-between;
gap: 10px;
}
.email_subscribe_section input{
height: 50px;
font-size: 16px;
background-color: black;
border: 1px solid #FFFFFFB2;
border-radius: 5px;
flex-grow: 1;
padding: 0 10px;
}
.email_subscribe_section button{
height: 50px;
padding: 0 30px;
background-color: white;
text-transform: uppercase;
border: none;
border-radius: 5px;
}

.email_subscribe_section p{
margin-top: 20px;
color: #FFFFFFB2;
}












.contact_section{
margin-top: 140px;
width: 100%;
padding: 0 30px;
}
.contact_section .row{
width: 100%;
display: flex;
gap: 30px;
}
.contact_section .row_2{
margin-top: 20px;
}
.contact_section .column{
width: 50%;
}
.contact_section .content{
width: 100%;
height: 100%;
padding: 0 15px;
}
.contact_section .column_1 .content{
padding-right: 48px;
}
.contact_section .section_caption{
text-align: left;
}
.contact_section .form{
    width: 100%;
}
.contact_section .input{
    margin-top: 30px; 
    width: 100%;
}
.contact_section .multiple_inputs{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    width: 100%;
}
.multiple_inputs>*{
flex: 1;
}
.contact_section input{
margin-top: 8px ;
font-size: 16px;
height: 50px;
width: 100%;
padding: 10px;
outline: none;
border: 1px solid rgba(0, 0, 0, .183);
border-radius: 4px;
}
.contact_section textarea{
    margin-top: 8px ;
    border: 1px solid rgba(0, 0, 0, .183);
    height: 130px;
    width: 100%;
    padding: 10px;
    outline: none;
    font-size: 16px;
 }
 .input_error{
color: red;
font-size: 14px;
}
 .contact_section .submit_input{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 80px;
}
.submit_input>*{
flex: 1;
}
 .contact_section .submit_btn{
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: black;
    color: whitesmoke;
    text-transform: uppercase;
    cursor: pointer;
    border: none;
    border-radius: 5px;
    height: 50px;
    padding: 0 1px;
}

.submit_btn:disabled {
    cursor: not-allowed;
}

.submit_btn .buttonText{
display: inline-block;
color: whitesmoke;
}
.submit_btn .spinner {
    display: none;
    border: 3px solid whitesmoke;
    border-left-color: #000;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    animation: spin 1s linear infinite;
    vertical-align: middle;
}
@keyframes spin {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
.submit_input span{
color: #757575;
font-size: 14px;
}
.contact_section .features_container{
width: 100%;
display: flex;
flex-wrap: wrap;
}
.contact_section .feature{
padding-left: 30px;
width: calc(50% - 30px);
margin: 0 15px;
text-align: left;
border: 1px solid white ;
background-color: white;
border-radius: 5px;
text-align: left;
border-left: 1px solid #e5e5e5;
}
.contact_section  .item_icon i{
font-size: 50px;
line-height: 50px;
}
.contact_section .feature h2{
margin-top: 22px;
font-size: 19px;
font-weight: 600;
}
.contact_section .feature .list{
margin-top: 11px;
color: #757575;
}
.feature p{
font-size: 16px;
}
.contact_section  .google_map{
padding: 0 15px;
margin-top: 30px;
width: 100%;
height: 100%;
}
.google_map iframe{
width: 100%;
height: 100%;
min-height: 360px;
}













@media only screen and (max-width: 768px) {

    /* all sections common responsiveness*/

    html, body {
        width: 100%;
        max-width: 100%;
        overflow-x: hidden; /* Prevents horizontal scrolling */
    }
    p{
    font-size: 16px;
     }
    .first_section {
    margin-top: 165px ;
    padding-left: 15px;
    padding-right: 15px;
    }
    .section  {
    flex-wrap: wrap ;
    gap:30px;
    padding-left: 15px;
    padding-right: 15px;
    }
    .section .row{
        flex-wrap: wrap ;
        gap:30px;
    }
    .section .column  {
        width: 100% ;
    }
    .section .flex_container{
        flex-wrap: wrap ;
        gap: 30px;
    }
    .section .flex_item{
        width: 100% ;
        margin: 0;
    }
.section_title {
padding: 0;
}
.section_title_2 {
    font-size: 30px;
}
.section_title h1{
font-size: 40px;
}

/* section wise separate responsiveness*/
.intro_text{
justify-content: center;
margin-top:65px;
height: calc(100vh - 15px);
}
.intro_heading h1{
font-size: 65px;
}
.intro_description{
margin: 0 ;
gap:10px;
}
.intro_description button {
font-size: 16px;
padding: 8px 15px;
}
.hero_address{
padding: 0 ;
}
.about_section .column .content {
    padding: 0 15px;
}
.about_section .column_2 .content{
margin-top: 80px;
}
.about_section .column_3 .content{
height: 200px;
}
.ourteam_section {
    margin-top: 140px;
    padding: 80px 0;
}
.ourteam_section .row{
    padding: 0 15px;
}
.service_container .service {
padding: 40px 25px;
}
.start_project_section {
padding: 0;
gap:0;
}
.start_project_section .column{
border-radius: 0;
}
.start_project_section .column_1 {
    padding: 140px 15px;
}
.start_project_section .column_1 h1 {
    font-size: 40px;
}

.pricing_section .price_container {
    padding: 0;
}
.how_wework_section .column_1 .content {
    padding: 0;
}
.blog_container .blog {
padding-bottom: 25px;
}
.blog .text_content {
padding: 0 25px;
}
.blog .author {
margin-top: 25px;
}
.email_subscribe_section .content {
    padding-left: 0px;
    padding-right: 0px;
}
.email_subscribe_section input {
width:65%;
}
.email_subscribe_section button {
    padding: 0 15px;
    width:35%;
}
.contact_section .content {
    padding: 0;
}
.contact_section .features_container {
    flex-wrap: nowrap;
    justify-content:space-between;
    max-width:100%;
    gap:10px;
}
.contact_section .feature {
padding-left: 15px;
width:50%;
word-wrap: break-word;   /* forces long words to wrap */
overflow-wrap: break-word; /* modern equivalent */
}
.contact_section .row_2 .content {
    padding: 0;
}
.contact_section .google_map {
    padding: 0 ;
    margin: 0;
}
.contact_section .submit_input {
flex-wrap: wrap;
gap: 30px;
}
.contact_section .submit_input>* {
    flex: auto;
}

}








@media only screen and (min-width: 769px) and (max-width: 1024px) {

    /* all sections common responsiveness*/

    html, body {
        width: 100%;
        max-width: 100%;
        overflow-x: hidden; /* Prevents horizontal scrolling */
    }
    p{
    font-size: 16px;
     }
    .first_section {
    margin-top: 165px ;
    padding-left: 30px;
    padding-right: 30px;
    }
    .section  {
    flex-wrap: wrap ;
    gap:30px;
    padding-left: 30px;
    padding-right: 30px;
    }
    .section .row{
        flex-wrap: wrap ;
        gap:30px;
    }
    .section .column  {
        width: 100% ;
    }
    .section .flex_container{
        flex-wrap: wrap ;
    }
    .section .flex_item{
    width: calc(50% - 30px);
    margin: 15px;
    }
.section_title {
padding: 0;
}
.section_title_2 {
    font-size: 30px;
}
.section_title h1{
font-size: 58px;
}

/* section wise separate responsiveness*/
.hero_section {
    padding-bottom: 30px;
}
.intro_text{
justify-content: center;
height: calc(100vh - 75px);
}
.intro_heading h1{
font-size: 100px;
font-weight: 400;
}
.intro_description{
margin: 0  83px;
}
.hero_address {
    padding: 0;
    align-items: center;
}
.about_section .row {
flex-wrap: nowrap;
}
.about_section .column_1 {
width: 40%;
}
.about_section .column_2 {
width: 60%;
}
.about_section .column_3 {
display: none;
}
.about_section .column .content {
    padding: 0;
}
.about_section .column_3 .content{
height: 200px;
}
.ourteam_section .row{
flex-wrap: nowrap;
padding: 0;
}
.services_section{
padding-left: 15px;
padding-right: 15px;
}
.service_container .service {
padding: 40px 25px;
}
.start_project_section {
padding: 0;
gap:0;
}
.start_project_section .column{
border-radius: 0;
}
.start_project_section .column_1 {
    padding: 140px 30px;
}
.start_project_section .column_1 h1 {
    font-size: 40px;
}
.pricing_section {
    padding-left: 15px;
    padding-right: 15px;
}
.pricing_section .price_container {
    padding: 0;
}
.how_wework_section .column_1 .content {
    padding: 0;
}
.faq-container .faq-item {
width: 100%;
margin: 0;
}
.why_choose_section {
padding-left: 15px;
padding-right: 15px;
}
.blog_section {
padding-left: 15px;
padding-right: 15px;
}
.blog_container .blog {
padding-bottom: 25px;
}
.blog .text_content {
padding: 0 25px;
}
.blog .author {
margin-top: 25px;
}
.email_subscribe_section .content {
    padding-left: 0;
    padding-right: 0;
}
.contact_section .content {
    padding: 0;
}
.contact_section .features_container {
    flex-wrap: nowrap;
}
.contact_section .row_2  {
flex-wrap: nowrap;
}
.contact_section .row_2 .content {
    padding: 0;
}
.contact_section .google_map {
    padding: 0 ;
    margin-top: 30px;
}
.contact_section .submit_input {
flex-wrap: wrap;
gap: 30px;
}
.contact_section .submit_input>* {
    flex: auto;
}

}




















