/* Global: show custom mobile overlay whenever body has mobile-menu-active (beats MMM / viewport) */
body.mobile-menu-active .mobile-menu-wrapper {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 200 !important;
    pointer-events: auto !important;
}

/* Medium Layout: 1280px. */
@media only screen and (min-width: 992px) and (max-width: 1600px) {
    a.client-login-btn {
        padding: 12px 10px 12px 10px;
    }

    .header-right {
        font-size: 16px;
    }

    .mainmenu li a {
        padding: 10px 15px;
    }

    button.di-search-btn {
        height: 50px;
        width: 50px;
        padding: 15px;
    }

    a.lets-talk-btn, .client-login-btn {
        padding-top: 5px;
        padding-bottom: 5px;
    }

    a.client-login-btn svg {
        width: 15px;
    }

    a.lets-talk-btn svg {
        width: 30px;
    }

    .admin-bar .is-sticky .header-area {
        margin-top: 32px;
    }

}
/* Mobile menu activate container: ≤1400px use mobile menu (hamburger + overlay) */
@media only screen and (max-width: 1400px) {
    .header-right .mainmenu {
        display: none;
    }

    .header-right {
        display: flex;
        align-items: center;
    }

    .logo {
        display: flex;
        align-items: center;
        flex: 1;
    }

    button.mobile-menu-trigger {
        background: none;
        border: none;
        margin-top: 0px;
        cursor: pointer;
        display: block;
    }

    .header-area {
        padding: 10px 0;
    }

    .logo img {
        max-width: 225px;
    }

    .mobile-menu-wrapper {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 99;
        width: 100%;
        height: 100%;
        overflow-x: hidden;
        overflow-y: auto;
        padding-top: 69px;
    }

    .mobile-menu-wrapper-inner {
        background-color: #279693;
        padding: 20px;
    }

    .single-mobile-menu-item {
        border-bottom: 1px solid #67bebb;
    }

    .single-mobile-menu-item button {
        border: none;
        background: none;
        width: 100%;
        text-align: left;
        color: #fff;
        font-size: 20px;
        padding: 15px 0;
        cursor: pointer;
    }
    .single-mobile-menu-item button {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .single-mobile-menu-item button svg {
        width: 25px;
        margin-top: 8px;
    }

    .single-mobile-menu-inner h4 {
        color: #fff;
        font-size: 22px;
        display: flex;
        justify-content: space-between;
    }

    .single-mobile-menu-inner h4 button {
        display: flex;
        justify-content: inherit;
        width: min-content;
        padding: 0;
        font-size: 16px;
        font-weight: normal;
        margin-top: -4px;
    }

    span.mobile-menu-back-btn {
        background: #3fbab6;
        height: 35px;
        width: 35px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 50%;
        margin-right: 15px;
    }

    span.mobile-menu-back-btn svg {
        width: 17px;
        margin: 0;
    }

    .single-mobile-menu-inner {border-top: 1px solid #67bebb;padding-top: 25px;padding-bottom: 10px;}
    a.single-mobile-menu-second-level {
        display: block;
        color: #fff;
        text-decoration: none;
        font-size: 18px;
        padding: 10px 0;
    }
    .active .single-mobile-menu-inner {
        border-top-width: 0px;
    }

    .single-mobile-menu-item.active {
        border-bottom-width: 0px;
    }
    /* On touch devices, keep nav items and back button white - prevent hover color from sticking after tap */
    @media (hover: none) {
        .mobile-menu-wrapper .single-mobile-menu-item button,
        .mobile-menu-wrapper .single-mobile-menu-item button:active,
        .mobile-menu-wrapper .single-mobile-menu-item button:focus,
        .mobile-menu-wrapper .single-mobile-menu-inner h4,
        .mobile-menu-wrapper .single-mobile-menu-inner h4 button,
        .mobile-menu-wrapper .single-mobile-menu-inner h4 button:active,
        .mobile-menu-wrapper .single-mobile-menu-inner h4 button:focus,
        .mobile-menu-wrapper a.single-mobile-menu-second-level,
        .mobile-menu-wrapper a.single-mobile-menu-second-level:active,
        .mobile-menu-wrapper a.single-mobile-menu-second-level:focus {
            color: #fff !important;
        }
    }
    /* Override Max Mega Menu / other plugins: custom mobile overlay must show when active */
    body.mobile-menu-active .mobile-menu-wrapper {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        z-index: 200;
        pointer-events: auto !important;
    }
    .header-area, .sticky-wrapper {
        z-index: 999;
    }

    .mobile-menu-wrapper-inner {
        height: 100%;
        padding-top: 110px;
        position: relative;
        overflow-x: hidden;
        max-width: 100%;
    }
    body.mobile-menu-active {
        overflow: hidden;
    }
    /* Match production: Client Login, Let's Talk, Search above nav; X in top right corner */
    .mobile-fixed-btns {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
    }
    .mobile-fixed-btns-wrapper {
        position: relative;
        display: flex;
        padding: 20px;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
        gap: 10px;
    }
    .mobile-fixed-btns-wrapper.search-active .di-search-popup {
        opacity: 1;
        visibility: visible;
        z-index: 10;
    }
    .mobile-fixed-btns-wrapper a.client-login-btn { order: 1; height: 38px; min-height: 38px; display: inline-flex; align-items: center; }
    .mobile-fixed-btns-wrapper a.lets-talk-btn { order: 2; height: 38px; min-height: 38px; display: inline-flex; align-items: center; }
    .mobile-fixed-btns-wrapper .di-search-btn { order: 3; height: 38px; width: 38px; min-height: 38px; padding: 0; display: flex; align-items: center; justify-content: center; }

    .mobile-fixed-btns-wrapper a.lets-talk-btn, .mobile-fixed-btns-wrapper .client-login-btn {
        padding-top: 0;
        padding-bottom: 0;
        box-sizing: border-box;
    }

    .mobile-fixed-btns-wrapper {
        font-size: 14px;
    }

    .mobile-fixed-btns-wrapper a.lets-talk-btn svg {
        width: 30px;
    }

    .mobile-fixed-btns-wrapper a.client-login-btn svg {
        width: 18px;
    }

    .mobile-fixed-btns-wrapper a.client-login-btn {
        padding-top: 0;
        padding-bottom: 0;
    }

    .mobile-fixed-btns-wrapper .di-search-popup {
        width: 100%;
        left: 20px;
        top: 20px;
    }

    .mobile-fixed-btns-wrapper .di-search-popup input, .mobile-fixed-btns-wrapper button.di-search-close, .mobile-fixed-btns-wrapper .di-search-popup button[type=submit] {
        height: 38px;
    }

    .mobile-fixed-btns-wrapper .di-search-popup button[type=submit] {
        min-width: 38px;
    }

    .mobile-fixed-btns-wrapper .di-search-popup button[type=submit] svg {
        width: 18px;
    }

    .mobile-fixed-btns-wrapper button.di-search-close {
        width: 38px;
    }
    .mobile-fixed-btns-wrapper a.client-login-btn svg {
        margin-right: 5px;
    }

    .mobile-fixed-btns-wrapper a.lets-talk-btn svg {
        margin-right: 8px;
    }

    .mobile-fixed-btns-wrapper a.client-login-btn {
        padding-left: 15px;
        padding-right: 15px;
        margin-right: 10px;
    }

    .mobile-fixed-btns-wrapper a.lets-talk-btn {
        padding-right: 15px;
    }

    .mobile-fixed-btns-wrapper .di-search-btn {
        margin-right: 0;
        margin-left: 10px;
    }
    .mobile-menu-wrapper-inner {
        padding-bottom: 40px;
        overflow-x: hidden;
        overflow-y: visible;
    }

    /* Buttons and search only under 768px */
    @media only screen and (min-width: 768px) {
        .mobile-menu-wrapper .mobile-fixed-btns {
            display: none !important;
        }
        .mobile-menu-wrapper-inner {
            padding-top: 20px;
        }
    }

}

/* form responsive fix start */
@media only screen and (max-width: 1400px) {
    .di-contact-inner {
        max-width: 670px;
    }
}

@media only screen and (max-width: 1200px) {
    .di-contact-inner {
        max-width: 565px;
    }
}
/* form responsive fix end */

/* Tablet & mobile Layout: 768px. */
@media only screen and (max-width: 991px) {
    .desktop-divider {
        display: none;
    }

    .di-table-wrapper {
        flex-direction: column;
    }

    .di-single-table-column {
        margin-bottom: 50px;
    }

    .di-single-table-column:last-child {
        margin-bottom: 0;
    }

    .right-bg {
        position: relative;
        height: 300px;
        top: 78px;
        width: 100%;
        border-radius: 0 0 50px 0;
    }

    .header-area {}

    .hero-content {
        padding-top: 100px;
        padding-bottom: 80px;
    }



    .hero-form-inner {display: block;padding: 0;}

    .hero-form {
        margin: 40px 0;
        display: block;
    }

    .hero-form-area {
    }

    .hero-form-select {width: 100%;}

    .hero-form-submit {
        margin: 30px 0 0;
        text-align: right;
    }

    .hero-desc {
        font-size: 24px;
    }
    section.basic_content h2 {
        font-size: 34px;
        line-height: 40px;
        margin-bottom: 30px;
    }

    section.basic_content {
        padding-top: 50px;
        padding-bottom: 70px;
    }

    .split_content .di-container > .flex {flex-direction: column;}

    .split_content .di-container > .flex .split-content-padding {
        order: 2;
        padding: 0;
    }

    .basic-image {
        padding-top: 30px;
        padding-bottom: 30px;
        margin-right: 30px;
        margin-left: -30px;
        margin-bottom: 30px;
        height: 340px;
        min-height: inherit;
    }

    .basic-image:after {
        right: -30px;
    }

    .basic-image {
        display: flex;
    }

    .basic-image img {
        height: 100%;
        width: 100%;
        object-fit: cover;
        object-position: top center;
    }

    section.split_content h2 {
        font-size: 34px;
        line-height: 30px;
    }

    .split-content-padding {}

    span.link-icon-wrapper {
        margin-right: 0;
    }

    /*.single-group-item h3 {*/
    /*    padding-right: 80px;*/
    /*}*/

    .group-link {
        padding-left: 20px;
    }

    .single-group-item h3 {
        font-size: 24px;
        line-height: 30px;
    }

    .image-position-left .basic-image {
        margin-left: 0;
        margin-right: -30px;
        padding-left: 20px;
        margin-top: -40px
    }

    .image-position-left .basic-image:after {
        left: 0;
        width: 93%;
    }

    .divider-image {
        padding-left: 15%;
        padding-right: 15%;
    }

    .image-shape-no_shape .basic-image {
        margin-bottom: 0;
    }

    .spilit-content-padding span.link-icon-wrapper {
        margin-right: 10px;
    }

    .group-link-individual span.link-icon-wrapper, .group-link span.link-icon-wrapper {
        margin-right: 15px;
    }

    .group-link-individual {
        font-size: 16px;
    }

    .group-content-style-column .single-group-item-inner {
        text-align: center;
    }

    .group-content-style-column .single-group-item h3 {
        padding: 0;
    }

    .group-content-style-column .group-link {
        justify-content: center;
    }

    .group-content-wrapper.group-content-style-column {
        flex-direction: column;
    }

    .group-content-wrapper.group-content-style-column.group-content-box-style-default .single-group-item {
        margin-bottom: 30px;
        border-radius: 25px;
    }
    .group-content-wrapper.group-content-style-counter > div {
        width: 100%;
    }
    .parent-group-content-style-logo-carousel .top-section-title-and-desc h2 {
        max-width: 100%;
    }

    .footer-top {
        flex-direction: column;
        padding-bottom: 20px;
        margin-bottom: 5px;
    }

    .footer-logo {
        margin-bottom: 50px;
    }

    .footer-social a {
        margin: 0 5px;
    }

    .footer-widgets .widget.widget_nav_menu {
        display: none;
    }

    .footer-widgets {
        flex-direction: column;
    }

    .di-location-item {
        padding-left: 0;
        padding-right: 0;
        padding-bottom: 20px;
    }

    .di-location-item h3 {
        width: 45%;
        flex: inherit;
    }

    .di-location-item, .di-location-item h3, .di-footer, .footer-menu ul li a {
        font-size: 14px;
    }
    .location-item-content {
        line-height: 20px;
    }

    .di-contact-bg {
        display: none;
    }

    .di-contact-form {
        padding-top: 10px;
    }

    h2 {
        font-size: 35px;
    }

    section.di-layout-contact {
        padding: 50px 0;
    }
    .group-link-individual, .mega-sub-menu .group-link-individual.shortcode-link {
        margin-top: 40px;
    }
    .slick-arrow {
        bottom: 0;
        top: auto;
        left: 50%;
        margin-left: -68px;
        height: 50px;
        width: 50px;
    }

    .resource-carousel {
        padding-bottom: 125px;
    }

    .resource-carousel ul.slick-dots {
        left: 0;
        top: auto;
        bottom: 0;
        text-align: center;
        width: 100%;
    }

    .resource-carousel .slick-arrow {
        bottom: 45px;
        margin-left: -60px;
    }

    .resource-carousel .slick-arrow.slick-next {
        margin-left: 5px;
    }

    .slick-next.slick-arrow {
        margin-left: 0;
    }
    .parent-group-content-style-overlay .top-section-title-and-desc {
        margin-left: 0;
    }

    .parent-group-content-style-overlay::before {min-width: 100%;}

    .group-content-wrapper.group-content-style-overlay {
        margin-top: 40px;
    }

    .group-content-wrapper.group-content-style-overlay {
        flex-direction: column;
    }

    .group-content-wrapper.group-content-style-overlay > div {
        padding: 20px;
    }

    .group-content-style-overlay .group-content-image {
        margin-top: 40px;
    }
    .testimonial-image {
        margin: 0;
        padding-top: 30px;
        padding-bottom: 30px;
        padding-right: 10px;
        width: 191px;
        position: absolute;
        right: 5px;
        top: 0;
        min-width: inherit;
        height: 250px;
    }

    .single-testimonial-item {
        flex-direction: column;
        overflow: hidden;
        position: relative;
        padding-top: 280px;
    }

    .testimonial-content {
        order: 2;
        text-align: left;
        padding: 0;
        font-size: 18px;
    }

    .testimonial-image img {
        margin-left: -20px;
        height: 100%;
        width: 100%;
        object-fit: cover;
        object-position: center top;
    }

    .testimonial-content {}

    .testimonial-image:after, .testimonial-image img {
        border-radius: 0 0 50px;
    }

    .di-testimonials-section {
        padding-top: 80px;
        padding-bottom: 80px;
    }

    .testimonial-carousel .slick-arrow.slick-next {
        left: 50%;
        margin-left: 10px;
    }

    .testimonial-carousel .slick-arrow {
        left: 50%;
        margin-right: 0;
        margin-left: -61px;
    }

    .testimonial-carousel {
        padding-bottom: 80px;
        margin-bottom: 20px;
    }

    .testimonial-carousel ul.slick-dots {
        left: 0;
        display: flex;
        justify-content: center;
        width: 100%;
        bottom: -40px;
    }

    .testimonial-info h4 {
        font-size: 18px;
        margin-bottom: 5px;
    }

    .testimonial-info {font-size: 18px;}
    span.link-icon-wrapper {
        width: 50px;
        height: 50px;
    }
    a.cta-video-btn {
        height: 60px;
        width: 60px;
        bottom: 50px;
        right: 30px;
    }
    .testimonial-image-inner {
        height: 100%;
        width: 100%;
    }
    .testimonial-info {
        text-align: right;
        padding-right: 40px;
    }
    .di-contact-flex {
        padding-top: 0;
        padding-bottom: 0;
    }
    .footer-menu {
        margin-top: -5px;
        padding-top: 15px;
    }
    section.hero {
        min-height: inherit;
    }
    .select2-results {
        margin-left: -26px;
        margin-right: 0;
    }
    .select2-container {
        min-width: 100%;
    }
    .group-content-wrapper.group-content-style-counter > div {
        margin-right: 0;
    }
    .responsive-divider {
        display: inline;
    }

    section.parent-group-content-style-overlay {
        background-image: none !important;
        padding-top: 0 !important;
    }

    .parent-group-content-style-overlay .top-section-title-and-desc-inner {
        position: relative;
        z-index: 2;
        margin-left: -23px;
        margin-right: -23px;
        padding: 37px 26px;
    }

    .parent-group-content-style-overlay .top-section-title-and-desc {
        max-width: inherit !important;
        padding-left: 23px;
        padding-right: 23px;
        background-size: 1000px;
        padding-top: 290px;
        margin-left: -20px !important;
        margin-right: -20px !important;
        background-repeat: no-repeat;
    }

    .parent-group-content-style-overlay .top-section-title-and-desc-inner:after {
        position: absolute;
        left: 0;
        top: 0;
        height: 100%;
        width: 100%;
        content: "";
        background: linear-gradient(180deg, rgba(39,124,120,1) 0%, rgba(15,45,50,1) 100%);
        z-index: -1;
        opacity: .9;
    }

    .mobile-menu-trigger {
        display: inline-block;
    }



    .group-content-wrapper.group-content-style-column.group-content-box-style-spaced-column .single-group-item {
        max-width: 100%;
    }

    .group-content-wrapper.group-content-style-column.group-content-box-style-spaced-column .single-group-item .single-group-item-inner {
        text-align: left;
    }

    .group-content-wrapper.group-content-style-column.group-content-box-style-spaced-column .group-link {
        justify-content: start;
    }

    .group-content-style-column .group-content {
        min-height: inherit;
        margin-bottom: 30px;
    }

    .group-content-box-style-spaced-column .single-group-item h3 {
        min-height: inherit;
        padding-bottom: 30px;
    }
    .bg-overlay {
        opacity: .95;
    }
    .single-group-item-inner-carousel {
        flex-direction: column;
    }

    .group-content-style-carousel .slick-list {
        padding-right: 0;
    }

    .group-content-bg-top {
        margin-bottom: 20px;
    }

    .group-content-style-carousel .slick-arrow.slick-next {
        left: 65px;
    }

    .group-content-style-carousel .slick-arrow {
        left: 0;
        margin: 0;
        bottom: 0;
    }

    .group-content-style-carousel.slick-initialized {
        padding-bottom: 60px;
    }

    .group-content-style-carousel ul.slick-dots {
        bottom: 12px;
        color: #859393;
        left: 145px;
    }
    .basic-image {
        height: auto;
        max-height: inherit;
    }
    .group-content-wrapper.group-content-style-column.group-content-box-style-spaced-column .single-group-item {
        padding-top: 0;
    }
    .di-basic-content-wrapper.di-basic-content-double {
        flex-direction: column;
        flex-wrap: wrap;
    }
    .single-slide-inner h3 {
        font-size: 40px;
    }

    .single-slide-inner {
        height: 500px;
        padding-bottom: 100px;
    }
    .single-related-wrap {
        width: 100%;
    }

    .group-content-style-carousel.group-carousel-style-box .slick-arrow {
        top: auto;
        bottom: -14px;
    }

    .group-content-style-carousel.group-carousel-style-box .slick-arrow.slick-prev {
        left: 0;
        right: auto;
    }

    .group-content-style-carousel.group-carousel-style-box ul.slick-dots {
        left: 145px;
        bottom: 0;
        top: auto;
    }
    .single-blog-box, .three-columns .single-blog-box {
        width: 100%;
    }
    .di-page-title {
        padding-top: 100px;
        padding-bottom: 50px;
    }

    .di-page-title h1 {
        font-size: 40px;
    }

    .single-related-wrap {
        margin-bottom: 40px;
    }
    .blog-categories a {
        width: 100%;
    }
    .single-group-item {
        max-width: inherit;
    }
    .di-contact-inner {
        max-width: inherit;
    }

    .group-carousel-style-video.group-content-style-carousel .slick-arrow {
        left: 50%;
        top: auto;
        margin-left: -57px;
    }

    .group-carousel-style-video.group-content-style-carousel .slick-arrow.slick-next {
        margin-left: 5px;
    }

    .group-carousel-style-video.group-content-style-carousel ul.slick-dots {
        top: auto;
        bottom: -45px;
        left: 0;
        width: 100%;
        text-align: center;
    }

    .group-carousel-style-video .single-group-item-inner-carousel {
        display: block;
    }

    .group-carousel-style-video.group-content-style-carousel {
        margin-top: 10px;
    }

    .group-carousel-style-video .single-group-item-inner-carousel {
        padding: 15px;
    }

    .group-carousel-style-video .single-group-item-inner {
        padding-left: 20px;
        padding-right: 20px;
    }

    .group-carousel-style-video .single-group-item h3 {
        margin-right: 0;
        margin-left: 15px;
    }

    .group-carousel-style-video span.link-icon-wrapper {
        height: 60px;
        width: 60px;
    }
    .group-carousel-style-video .group-content-bg-top {
        height: 270px;
    }
    .group-content-style-team .single-group-item {
        width: 50%;
    }

    .group-content-style-team .team-member-info {
        flex-direction: column;
        padding: 15px;
    }

    .team-member-icon {
        margin-right: 0;
        margin-bottom: 10px;
        height: 26px;
        width: 26px;
        min-width: 26px;
    }

    .group-content-style-team .group-content-image {
        height: 212px;
    }

    .team-member-name h4 {
        font-size: 16px;
    }

    .team-member-name {
        font-size: 12px;
    }

    .group-content-style-team .group-content-image img, .group-content-style-team .group-content:after {
        border-radius: 0 0 0 25px;
    }

    .group-content-style-team .group-content {
        width: 100%;
    }
    .resource-item-content {min-height: inherit;}

    .resource-basic-content {
        display: none;
    }

    .resource-item-wrapper {
        padding-bottom: 100px;
    }
    span.responsive-divider {
        display: block;
        margin: 25px 0;
    }
    .group-content-style-overlay .single-group-item h3 {
        font-size: 29px;
        line-height: 38px;
    }
    .di-basic-content-inner {
        font-size: 18px;
        line-height: 26px;
    }
    .admin-bar .header-area.sticky-active {
        margin-top: 0px;
    }

}

/* Tablet Layout: 768px. */
@media only screen and (min-width: 768px) and (max-width: 991px) {


}
/* Mobile Layout: 320px. */
@media only screen and (max-width: 767px) {
    .jquery-sticky-sticky .header-area {
        margin-top: -20px;
    }
    .mobile-fixed-btns-wrapper .di-search-popup button[type=submit] {
        margin-right: 10px;
    }

}
/* Wide Mobile Layout: 480px. */
@media only screen and (min-width: 480px) and (max-width: 767px) {

}