@import url('https://fonts.googleapis.com/css2?family=Fira+Sans:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

body *,
body *:active,
body *:focus {
    outline: none !important;
}

html {
    margin: 0;
}

html body {
    font-size: 22px;
    line-height: 135%;
    color: #000;
    background: #fff;
    font-family: "Fira Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    font-variation-settings: "wdth" 100;
}

body a:hover,
body a:active,
body a:focus {
    opacity: 1;
    text-decoration: none;
    color: inherit;
}

body a {
    color: inherit;
    text-decoration: none;
    outline: none !important;
    box-shadow: none !important;
}

ul {
    padding: 0;
    margin: 0;
    width: 100%;
    float: left;
}

ul li {
    list-style: none;
}

img {
    max-width: 100%;
    height: auto;
}

p {
    margin: 0;
}

b,
strong {
    font-weight: 600;
}

.bgCover {
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
}

body h1,
body .h1,
body h2,
body .h2,
body h3,
body .h3,
body h4,
body .h4,
body h5,
body .h5,
body h6,
body .h6 {
    margin: 0;
}

body h1,
body .h1 {
    font-size: 88px;
    line-height: 100px;
    font-weight: 700;
}

body h2,
body .h2 {
    font-size: 48px;
    line-height: 100%;
    font-weight: 900;
}

body h3,
body .h3 {
    font-size: 25px;
    line-height: 135%;
    font-weight: 600;
}


.p1,
.p1 p {
    font-size: 24px;
    line-height: 32px;
    font-weight: 400;
}

.p2,
.p2 p {
    font-size: 24px;
    line-height: 32px;
    font-weight: 700;
}

.padding_md {
    padding-top: 48px;
    padding-bottom: 48px;
}


.bgGreen {
    background: #4CAF50;
}

.bgGray {
    background: #F5F5F6;
}

.GreenText {
    color: #4CAF50;
}

.blackText {
    color: #000000;
}

.whiteText {
    color: #fff;
}

.btn {
    font-size: 17px;
    padding: 13px 70px;
    font-weight: 600;
    line-height: 1;
    color: #fff;
    background: #4CAF50;
    text-align: center;
    cursor: pointer;
    border-radius: 6px;
    transition: all 0.4s ease;
}

.formInit {
    width: 100%;
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    padding: 30px 0;
}

/*---------- Container size -----------*/

.container {
    max-width: 1400px;
}

@media(min-width:1600px) {
    .container {
        max-width: 100%;
        padding: 0 60px;
    }
}

@media(min-width:1921px) {
    .container {
        max-width: 1600px;
    }
}

@media (max-width: 1599px) {
    .container {
        max-width: 100%;
        padding: 0 60px;
    }
}

@media (max-width: 1399px) {
    .container {
        max-width: 100%;
        padding: 0 40px;
    }
}

@media (max-width: 991px) {
    .container {
        max-width: 100%;
        padding: 0 30px;
    }
}

.container .container {
    max-width: 100%;
    width: 100%;
    padding: 0;
}

/*-----------------------------------*/

.hero_banner {
    height: auto;
    width: 100%;
    padding: 38px 0;
    background-repeat: no-repeat;
    background-size: cover;
}

.hero_banner h1 span {
    color: #4CAF50;

}

.listing_content {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.listing_content ul li {
    list-style: disc;
}

.listing_content ul {
    padding-left: 50px;
}

.listing_content span {
    font-weight: 700;
}

.listing_content .btn_div {
    margin-top: 18px;
    text-align: center;
}

.service_box {
    display: flex;
    gap: 26px;
}

.service_section .row>div {
    padding-left: 20px;
    padding-right: 20px;
}

.service_section .row {
    margin-right: -20px;
    margin-left: -20px;
}

.service_box .service_Icon img {
    min-width: 49px;
    max-width: 49px;
    min-height: 49px;
    max-height: 49px;
}

.postBtn img {
    width: 20px;
    height: 20px;
}

.postBtn a {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #4CAF50;
}

.post_section .heading {
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-bottom: 32px;
}

.post_div {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.post_div .imageBlock,
.spotlight_img .imageBlock {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 194px 0 0 0;
    position: relative;
}

.post_div .imageBlock img,
.spotlight_img .imageBlock img {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover;
    object-position: center;
}

.post_div .postBtn {
    padding-top: 12px;
}

.post_section .post_row>div {
    padding-left: 22px;
    padding-right: 22px;
}

.post_section .post_row {
    margin-left: -22px;
    margin-right: -22px;
    row-gap: 30px;
}

.collection {
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 40px 0;
}

.collection ul {
    display: flex;
    color: #4CAF50;
    gap: 32px;
    flex-wrap: wrap;
}

.collection ul li a {
    text-decoration: underline;
    position: relative;
}

.collection ul li a:after {
    position: absolute;
    content: " ";
    height: 18px;
    width: 2px;
    top: 5px;
    background: #000;
    margin-left: 16px;
}

.collection ul li:last-child a:after {
    display: none;
}

.collection .postBtn {
    margin-top: 12px;
}

.spotlight_content {
    padding-left: 36px;
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.count_div span {
    background: #4CAF50;
    width: 57px;
    height: 57px;
    border-radius: 50%;
    padding: 16px;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 999;
}

.green_line {
    height: 4px;
    width: 100%;
    background: #4CAF50;
    position: relative;
    bottom: 30px;
    right: -33px;
}

.green_line:after {
    position: absolute;
    content: " ";
    width: 21px;
    height: 36px;
    background-image: url(./assets/sc_images/sc_arrow.svg);
    background-repeat: no-repeat;
    background-size: cover;
    right: 0px;
    top: -16px;
}

.green_line:before {
    position: absolute;
    content: " ";
    width: 21px;
    height: 36px;
    background-image: url(./assets/sc_images/sc_arrow.svg);
    background-repeat: no-repeat;
    background-size: cover;
    left: 50%;
    top: -16px;
}

.work_section .heading {
    padding-bottom: 20px;
}

.work_content .count_div {
    padding-bottom: 30px;
}

.review_section .heading {
    display: flex;
    flex-direction: column;
    gap: 10px;
}


@media (max-width:1440px) {
    .service_section .row,
    .post_section .post_row {
        margin-right: -15px;
        margin-left: -15px;
    }

    .service_section .row>div,
    .post_section .post_row>div {
        padding-left: 15px;
        padding-right: 15px;
    }
}

@media (max-width:1300px) {
    body h1,
    body .h1 {
        font-size: 80px;
        line-height: 100px;
    }

    .spotlight_content {
        padding-left: 0px;
    }
}

@media (max-width:1199px) {
    html body {
        font-size: 20px;
        line-height: 1.4;
    }

    body h1,
    body .h1 {
        font-size: 62px;
        line-height: 110%;
    }
    .p1,
    .p1 p,
    .p2,
    .p2 p {
        font-size: 22px;
    }

    .post_div .postBtn {
        padding-top: 0px;
    }

    .collection .postBtn {
        margin-top: 0px;
    }

    .spotlight_content {
        gap: 18px;
    }    

    .count_div span {
        font-size: 36px;
    }
}

@media (max-width:991px) {
    body h2,
    body .h2 {
        font-size: 36px;
    }

    .collection ul {
        gap: 20px;
    }

    .collection ul li a:after {
        margin-left: 10px;
    }

    .spotlight_img img {
        width: 100%;
    }

    .spotlight_content {
        padding-top: 18px;
    }

    .count_div span {
        width: 45px;
        height: 45px;
    }

    .work_content {
        display: flex;
        gap: 20px;
    }

    .green_line {
        height: 100%;
        width: 3px;
        top: 0;
        right: auto;
        left: 22px;
        bottom: auto;
    }

    .green_line:after {
        display: none;
    }

    .work_content .count_div {
        padding-bottom: 0;
    }

    .row.work_row {
        row-gap: 40px;
    }

    .green_line:before {
        width: 24px;
        height: 24px;
        background-size: contain;
        left: -10px;
        top: 35%;
        transform: rotate(90deg);
    }

    /* .work_section .row>div {
        padding-bottom: 30px;
    } */

    .service_section .row {
        gap: 30px;
    }

    .service_box .service_Icon img {
        width: 38px;
        height: 40px;
    }

    .listing_content .btn_div {
        margin-top: 0px;
        text-align: left;
    }

    .hero_banner .container {
        display: flex;
        flex-direction: column;
        align-items: flex-end;
        justify-content: flex-end;
    }

    .hero_banner .bannerContent {
        width: auto;
        max-width: unset;
    }

    .work_section .row>div:last-child {
        padding-bottom: 0;
    }

    .post_div .imageBlock, .spotlight_img .imageBlock {
        padding: 400px 0 0 0;
    }
}

@media (max-width:767px) {

    body h1,
    body .h1 {
        font-size: 40px;
        line-height: 110%;
    }

    body h2,
    body .h2 {
        font-size: 28px;
    }

    body h3,
    body .h3 {
        font-size: 22px;
    }

    .p1,
    .p1 p,
    .p2,
    .p2 p {
        font-size: 18px;
        line-height: 28px
    }

    html body {
        font-size: 18px;
        line-height: 135%;
    }

    /* .green_line {
        bottom: -42px;
        width: 200%;
        left: -22px;
    } */

    .listing_content {
        gap: 20px;
    }

    .listing_content ul {
        padding-left: 22px;
    }
    .post_div .imageBlock,
    .spotlight_img .imageBlock {
        padding: 300px 0 0 0;
    }
}

@media (max-width: 600px) {
    .hero_banner {
        position: relative;
    }
    .hero_banner::after {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgb(255, 255, 255, 0.3);
        content: "";
        z-index: 2;
    }
    .hero_banner .container {
        position: relative;
        z-index: 4;
        align-items: flex-start;
        justify-content: flex-start;
    }
    .service_box .service_Icon img {
        min-width: 35px;
        max-width: 35px;
        min-height: 35px;
        max-height: 35px;
    }
}