body {
    background-color: #f7f7f7;
    overflow-x: hidden;
}
header.mobile > .container {
    padding-left: 0;
}
header .d-none {
    display: flex !important;
}
header .main-nav .col-4 img:not(.d-none) {
    display: none;
}
header .col-9:not(.expanded-column) .hamburger .line {
    background-color: #FFFFFF;
}
header .dropdown-hq .dropdown-toggle,
header .dropdown-hq .dropdown-toggle:hover,
header .dropdown-hq .dropdown-toggle:focus {
    color: #FFFFFF;
}
header .dropdown-hq
.clients-container {
    margin-top: 150px;
}
.heading-container {
    position: absolute;
    bottom: 0;
    margin: 0 auto;
    left: 0;
    right: 0;
}
.heading-container2 {
    position: absolute;
    margin: 0 auto;
    left: 0;
    right: 0;
    top: 5%;
}
.main-heading {
    font-size: 100px;
    color: #FFFFFF;
    font-family: Poppins-Bold, sans-serif;
}
.sub-heading {
    font-size: 60px;
    color: #FFFFFF;
    font-family: Poppins-Bold, sans-serif;
    line-height: 90px;
}
.project-container {
    position: relative;
}
.small-heading {
    font-size: 18px;
    color: #FFFFFF;
    font-family: Poppins-Regular, sans-serif;
    margin-bottom: 76px;
}
.small-heading a, .small-heading a:hover, .small-heading a:focus {
    color: #FFFFFF;
}
.cta-container {
    text-align: right;
}
.cta:hover, .cta:focus {
    background-color: #ffffff;
    color: #1C1B1B;
}
.cta {
    transition: background-color 0.2s ease-in-out;
    display: inline-block;
    text-align: right;
    padding: 16px;    
    text-decoration: none;
    font-family: Poppins-SemiBold, sans-serif;
    font-size: 18px;    
    line-height: 27px;
    background-color: #1C1B1B;
    color: #FFFFFF;
}
.black-heading {
    font-size: 80px;
    font-family: Poppins-Bold, sans-serif;
    color: #1C1B1B;    
    margin-bottom: 40px;
    line-height: 90px;
}
.black-subheading {
    font-size: 30px;
    font-family: Poppins-Bold, sans-serif;
    color: #1C1B1B; 
}
.text-container {
    max-width: 650px;
    margin: 0 auto;
}
.text-details {
    font-size: 18px;
    font-family: Poppins-Regular, sans-serif;
    color: #1C1B1B;
    line-height: 35px;
    margin-bottom: 40px;
}
.hidden-heading, .hidden-heading a {
    font-family: Poppins-Regular, sans-serif;
    color: #1C1B1B;
    font-size: 18px;
    margin-top: 40px;
    margin-bottom: 40px;
}
.hidden-heading a {
    text-decoration: underline;
}
.hidden-heading a:hover, .hidden-heading a:focus {
    color: #1C1B1B;
}
.mobile .cta-container {
    text-align: left;
    
}
.mobile .cta {
    color: #ffffff;
    background-color: #1C1B1B;
}
.desktop .cta:hover, .cta:focus {
    color: #1C1B1B;
    background-color: #FFFFFF;
}
.title {
    font-family: Poppins-Bold, sans-serif;
    font-size: 30px;
    color: #1C1B1B;
    line-height: 52px;
    margin-bottom: 40px;
}
.clients-container, .services .first-row.col-lg-6 {
    margin-bottom: 150px;
}
.text-subheading {
    font-family: Poppins-Bold, sans-serif;
    font-size: 30px;
    color: #1C1B1B;
    line-height: 52px;
}
.services .col-lg-6 {
    display: flex;
    align-items: center;
    margin-bottom: 26px;
}
.white-bg {
    background-color: #FFFFFF;
    padding-top: 150px;
    padding-bottom: 150px;
}
.subheading {
    font-family: Poppins-Bold, sans-serif;
    font-size: 25px;
    color: #1C1B1B;
    margin-bottom: 40px;
}
.white-bg > .container .text-details {
    margin-bottom: 145px;
}
.overline {
    text-transform: uppercase;
    font-size: 25px;
    color: #1C1B1B;
    font-family: Poppins-Bold, sans-serif;
}
.swiper {
    padding-bottom: 79px;
}
span.swiper-pagination-bullet {
    width: 96px;
    height: 4px;
    border-radius: 4px;
}
.swiper-pagination-bullet-active {
    background: #1C1B1B;
}
.swiper-slide-container {
    max-width: 584px;
    margin: 0 auto;
}
.slide-title {
    text-transform: uppercase;
    font-size: 60px;
    line-height: 70px;
    color: #1C1B1B;
    font-family: Poppins-Bold, sans-serif;
    margin-top: 40px;
    margin-bottom: 112px;
}
.swiper-slide.swiper-slide-next,
.swiper-slide.swiper-slide-prev {
    position: relative;
}
.swiper-slide.swiper-slide-next:after,
.swiper-slide.swiper-slide-prev:after {
    content:"";
    top: 0;
    left: 0;
    display: block;
    height: 100%;
    width: 100%;
    background-color: #FFFFFF;
    opacity: 0.50;
    position: absolute;
}
.swiper-slide .col-lg-6 {
    display: flex;
    justify-content: center;
    flex-direction: column;
}
.grey-bg {
    background-color: #EDF0F2;
}
.grey-bg-title {
    font-family: Poppins-Bold, sans-serif;
    font-size: 60px;
    line-height: 70px;
    color: #000000;
    padding-top: 80px;
    margin-bottom: 40px;
}
.grey-bg-link-container {
    text-align: right;
}
.grey-bg-link-container a {
    padding: 15px;
    background-color: #FFFFFF;
    text-decoration: none;
    display: inline-block;
    color: #1C1B1B;
    font-family: Poppins-SemiBold, sans-serif;
    font-size: 18px;
}
.grey-bg-link-container a:hover, 
.grey-bg-link-container a:focus {
    text-decoration: none;
    background-color: #1C1B1B;
    color: #FFFFFF;
}
.grey-bg .text-details {
    margin-bottom: 40px;
}
@media only screen and (max-width: 576px) {    
    .heading, .main-heading {
        font-size: 40px;
    }
}
@media only screen and (max-width: 1280px) {
    .desktop:not(header) {
        display: none !important;
    }
    .signature {
        margin-top: 37px;
     }
     .clients-container {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .heading-container2 {
        top: 20%;
        margin-top: 54px;
    }
    .heading-container {
        margin-bottom: 40px;
    }
    .heading-container .sub-heading {
        font-size: 20px;
        line-height: 28px;
    }
    .services .black-heading {
        font-size: 37px; 
        line-height: 60px;       
    }
    .services .row {
        margin-bottom: 95px;
    }
    .services img {
        width: 100%;
    }
    .grey-bg-title {
        font-size: 40px;
        line-height: 60px;
    }
    .white-bg {
        padding-top: 80px;
    }
    .white-bg > .container .text-details {
        margin-bottom: 26px;
    }
    .slide-title {
        font-size: 40px;
        line-height: 60px;
        margin-bottom: 40px;
    }
    span.swiper-pagination-bullet {
        width: 71px;
        height: 2px;
    }
    .overline {
        margin-top: 40px;
    }
    .grey-bg-link-container {
        text-align: left;
    }
    .grey-bg {
        padding-bottom: 80px;
    }
}

@media only screen and (min-width: 1281px) {
    .mobile:not(header) {
        display: none !important;
    }
    .projects {
        margin-bottom: 84px;
    }
}