﻿@keyframes spin {

    0%,
    to {
        box-shadow: .2em 0 0 0#fff
    }

    12% {
        box-shadow: .2em .2em 0 0#fff
    }

    25% {
        box-shadow: 0 .2em 0 0#fff
    }

    37% {
        box-shadow: -.2em .2em 0 0#fff
    }

    50% {
        box-shadow: -.2em 0 0 0#fff
    }

    62% {
        box-shadow: -.2em -.2em 0 0#fff
    }

    75% {
        box-shadow: 0-.2em 0 0#fff
    }

    87% {
        box-shadow: .2em -.2em 0 0#fff
    }
}

@keyframes scroll {
    0% {
        transform: translateX(0)
    }

    to {
        transform: translateX(calc(-100% - 2px))
    }
}

@keyframes rotation {
    0% {
        transform: rotate(0deg)
    }

    to {
        transform: rotate(360deg)
    }
}

@keyframes slide-up {
    0% {
        transform: translateY(-150px)
    }

    to {
        transform: translateY(0)
    }
}

@keyframes rotateSliderLines {
    0% {
        opacity: 0;
        right: 100%;
        transform: skewX(-20deg) translateX(0)
    }

    1% {
        opacity: 1;
        right: 100%;
        transform: skewX(-20deg) translateX(0)
    }

    70% {
        opacity: 1;
        right: 35%;
        transform: skewX(-20deg) translateX(0)
    }

    99%,
    to {
        opacity: 0;
        right: 35%;
        transform: skewX(-20deg) translateX(0)
    }
}

@keyframes rotateSliderLinesLong {
    0% {
        opacity: 0;
        right: 100%;
        transform: skewX(-20deg) translateX(0)
    }

    1% {
        opacity: 1;
        right: 100%;
        transform: skewX(-20deg) translateX(0)
    }

    70%,
    99% {
        opacity: 1;
        right: 29.03%;
        transform: skewX(-20deg) translateX(0)
    }

    to {
        opacity: 0;
        right: 29.03%;
        transform: skewX(-20deg) translateX(0)
    }
}

@keyframes slide-down {
    0% {
        opacity: 0;
        transform: translateY(100%)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@-webkit-keyframes mouseanim {

    0%,
    to {
        transform: translateX(0)
    }

    50% {
        transform: translateX(-5px)
    }
}

@keyframes mouseanim {

    0%,
    to {
        transform: translateX(0)
    }

    50% {
        transform: translateX(-5px)
    }
}

@-webkit-keyframes arrowsanim {

    0%,
    to {
        opacity: 0
    }

    50% {
        opacity: 1
    }
}

@keyframes arrowsanim {

    0%,
    to {
        opacity: 0
    }

    50% {
        opacity: 1
    }
}

@keyframes lds-heart {

    0%,
    60% {
        transform: scale(.95)
    }

    5% {
        transform: scale(1.1)
    }

    39% {
        transform: scale(.85)
    }

    45% {
        transform: scale(1)
    }

    to {
        transform: scale(.9)
    }
}

@-webkit-keyframes tada {

    0%,
    to {
        -webkit-transform: scaleX(1);
        transform: scaleX(1)
    }

    10%,
    20% {
        -webkit-transform: scale3d(.9, .9, .9) rotate(-3deg);
        transform: scale3d(.9, .9, .9) rotate(-3deg)
    }

    30%,
    50%,
    70%,
    90% {
        -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
        transform: scale3d(1.1, 1.1, 1.1) rotate(3deg)
    }

    40%,
    60%,
    80% {
        -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
        transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg)
    }
}

@keyframes tada {

    0%,
    to {
        -webkit-transform: scaleX(1);
        transform: scaleX(1)
    }

    10%,
    20% {
        -webkit-transform: scale3d(.9, .9, .9) rotate(-3deg);
        transform: scale3d(.9, .9, .9) rotate(-3deg)
    }

    30%,
    50%,
    70%,
    90% {
        -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
        transform: scale3d(1.1, 1.1, 1.1) rotate(3deg)
    }

    40%,
    60%,
    80% {
        -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
        transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg)
    }
}

body {
    font-family: "Roboto", sans-serif;
    font-weight: 400;
    color: #2c3e50;
    width: 100%;
    overflow-x: hidden;
    line-height: 1.6
}

html {
    scroll-behavior: auto !important
}

main.main-content {
    padding-top: 125px;
    max-width: 1920px;
    min-height: 800px;
    margin: 0 auto
}

html.adminbar-on header.main-header {
    top: 49px
}

html.adminbar-on main.main-content {
    padding-top: 174px
}

html.adminbar-on .main-wrapper {
    position: relative
}

body .adminbar.adminbar--sticky {
    position: fixed
}

.mw-xl {
    max-width: 1350px
}

.mw-lg {
    max-width: 1200px
}

.mw-md {
    max-width: 700px
}

.mw-sm {
    max-width: 500px
}

.project-single .button-like-form {
    position: fixed;
    width: 60px;
    height: 60px;
    top: inherit;
    bottom: 40px;
    left: 30px
}

.project-single .button-like-form .button-like {
    background: #fff;
    background: #00c4cc;
    color: #fff
}

.project-single .button-like-form .button-like i {
    display: block
}

.project-single .button-like-form .button-like .entry-like {
    display: block;
    padding-left: 0
}

.button-like-form {
    position: absolute;
    z-index: 30;
    top: 20px;
    left: 30px
}

.button-like {
    font-size: 24px;
    height: 60px;
    border-radius: 50%;
    z-index: 9999;
    padding: 12px 5px;
    bottom: 20px;
    left: 20px;
    text-align: center;
    display: block
}

.button-like.invert {
    color: #fff
}

.button-like.invert .entry-like,
.button-like.invert i,
.button-menu {
    display: inline-block
}

.button-like.active i:before {
    content: ""
}

.button-like.heart-beat i {
    animation: lds-heart 1s 1 cubic-bezier(.215, .61, .355, 1)
}

.button-like i {
    font-size: 25px;
    vertical-align: middle
}

.button-like .entry-like {
    position: relative;
    vertical-align: middle;
    font-size: 13px;
    font-weight: 500;
    line-height: 20px
}

.button-menu {
    position: absolute;
    top: 12px;
    right: 0;
    border: 0;
    height: 70px;
    width: 70px;
    margin: 0;
    z-index: 999;
    background: 0 0;
    transition: all ease .5s;
    overflow: hidden
}

.button-menu .hamburger {
    padding: 0;
    width: 100%;
    height: 100%;
    text-align: center
}

.button-menu .hamburger svg {
    height: 70px;
    width: 70px;
    cursor: pointer;
    transform: translate3d(0, 0, 0)
}

.button-menu .hamburger svg path {
    fill: none;
    transition: stroke-dashoffset .5s cubic-bezier(.25, -.25, .75, 1.25), stroke-dasharray .5s cubic-bezier(.25, -.25, .75, 1.25);
    stroke-width: 24px;
    stroke-linecap: round;
    stroke: #2c3e50;
    stroke-dashoffset: 0
}

.button-menu .hamburger svg path#bottom,
.button-menu .hamburger svg path#top {
    stroke-dasharray: 240px 950px
}

.button-menu .hamburger svg path#middle {
    transition: all .3s ease;
    stroke-dasharray: 240px 240px
}

body.menu-open .hamburger svg path#bottom,
body.menu-open .hamburger svg path#top {
    stroke-dashoffset: -650px
}

body.menu-open .hamburger svg path#middle {
    stroke: transparent;
    stroke-dashoffset: -115px;
    stroke-dasharray: 1px 220px
}

.h1,
h1 {
    font-family: "Khand", sans-serif;
    font-size: 60px;
    font-weight: 500;
    line-height: 1;
    color: #2c3e50
}

.h1 a,
h1 a {
    line-height: 1 !important
}

.h1 big,
.h1.h1-xl,
.h2.h2-xl,
h1 big,
h1.h1-xl,
h2.h2-xl {
    font-size: 70px
}

.h2,
.h3,
.h4,
.h5,
h2,
h3,
h4,
h5 {
    font-family: "Khand", sans-serif;
    font-size: 50px;
    font-weight: 400;
    line-height: 1.15
}

.h2.h2-md,
h2.h2-md {
    line-height: 1.2;
    font-size: 35px
}

.h2 strong,
h2 strong,
strong {
    font-weight: 700
}

.h3,
.h4,
.h5,
h3,
h4,
h5 {
    font-size: 32px;
    line-height: 1.2
}

.h3 strong,
.h4 strong,
article strong,
h3 strong,
h4 strong,
section.banner-infrastructure .title span {
    font-weight: 500
}

.h4,
.h5,
h4,
h5 {
    font-size: 24px;
    line-height: 1.3
}

.h5,
h5 {
    font-size: 22px;
    font-weight: 500;
    line-height: 1.6
}

.h6,
h6 {
    font-size: 18px;
    color: #2c3e50;
    font-family: "Roboto", sans-serif
}

.h6,
h6,
ol,
p,
ul {
    font-weight: 400
}

.h6,
h6,
p {
    line-height: 1.8
}

p {
    margin-bottom: 1rem
}

p a {
    text-decoration: underline
}

a {
    text-decoration-skip-ink: none
}

a,
a:hover {
    text-decoration: none;
    color: #00c4cc
}

ol,
ul {
    padding-left: 23px;
    line-height: 1.6
}

figcaption {
    font-size: 12px;
    padding: 5px 0;
    font-style: italic;
    font-weight: 300;
    text-align: left;
    color: #444
}

pre {
    background: #ff0
}

hr {
    border-color: #bed0d2
}

blockquote {
    font-size: 20px;
    padding: 10px 10px 10px 25px;
    border-left: 2px solid #00c4cc
}

blockquote li,
blockquote p,
body {
    font-size: 16px
}

blockquote p:last-of-type {
    margin-bottom: 0
}

article figure video {
    width: 100%;
    height: 540px
}

article img {
    max-width: 100%;
    height: auto;
    border-radius: 6px
}

article p.p1 br,
body.entry-type-infrastructure footer.main-footer {
    display: none
}

.fw-light * {
    font-weight: 300
}

.list-style-custom ol {
    padding-left: 16px;
    line-height: 1.8
}

.list-style-custom ul {
    padding: 0;
    list-style: none
}

.list-style-custom ul ul {
    margin-top: 10px
}

.list-style-custom ul li {
    list-style: none;
    position: relative;
    padding-left: 16px;
    margin-bottom: 5px
}

.list-style-custom ul li a {
    transition: all ease .3s
}

.list-style-custom ul li a:hover {
    text-decoration: none
}

.list-style-custom ul li:before {
    position: absolute;
    left: 0;
    top: 11px;
    content: "";
    height: 5px;
    width: 5px;
    border-radius: 50%;
    background: #00c4cc;
    display: block
}

.bg-main .button-custom.button-custom-main,
.content-columns a:hover,
.content-columns h4 {
    color: #00c4cc
}

.content-columns p {
    margin-bottom: 5px
}

.content-columns a,
.list-style-custom ul li a {
    color: #2c3e50;
    text-decoration: underline
}

.hidden {
    display: none !important
}

section.banner-infrastructure {
    height: calc(100vh - 125px);
    overflow: hidden;
    position: relative;
    background: #f9f9fb
}

section.banner-infrastructure.animate .form-infrastructure {
    height: 30vh
}

section.banner-infrastructure.animate .pattern-line.line-01 {
    opacity: 1;
    right: 12%;
    transform: rotate(-20deg) translateX(0)
}

section.banner-infrastructure.animate .pattern-line.line-02 {
    opacity: 1;
    right: 5%;
    transform: rotate(-20deg) translateX(0)
}

section.banner-infrastructure.wide .pattern-line.line-01 {
    right: 15%
}

section.banner-infrastructure.wide .pattern-line.line-02 {
    right: 8%
}

section.banner-infrastructure.invert .image:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background: rgba(0, 0, 0, .4)
}

section.banner-infrastructure .image {
    background-position: center
}

section.banner-infrastructure .content-holder {
    padding: 120px 0
}

section.banner-infrastructure .description-sec {
    letter-spacing: 1px
}

.invert .title a,
section.banner-infrastructure .description-sec span {
    border-bottom: 1px solid #fff
}

section.banner-infrastructure .icon-holder {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 2
}

.social-links a i,
section.banner-infrastructure .image-holder {
    position: relative;
    z-index: 2
}

section.banner-infrastructure .pattern-line {
    top: -10%;
    position: absolute;
    height: 250%
}

section.banner-infrastructure .pattern-line.line-01 {
    right: 0;
    transform: rotate(-20deg);
    background: rgba(255, 255, 255, .6);
    width: 1px
}

section.banner-infrastructure .pattern-line.line-02 {
    right: 0;
    transform: rotate(-20deg);
    background: #00c4cc;
    width: 4px
}

section.banner-infrastructure .pattern-line.line-01,
section.banner-infrastructure .pattern-line.line-02 {
    opacity: 0;
    transform: rotate(-20deg) translateX(600px);
    transition: all ease .8s;
    transition-delay: 0s
}

section.banner-infrastructure .pattern-line.line-02 {
    transition: all ease 1s;
    transition-delay: .2s
}

section.banner-infrastructure .form-infrastructure {
    background: #fff;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 0;
    transition: all ease .5s;
    transition-delay: 1s;
    z-index: 30
}

section.banner-infrastructure .form-infrastructure .form {
    padding: 100px 0;
    max-width: 650px
}

.flex-graphic,
figure.image,
section.banner-infrastructure .form-infrastructure .form .form-field {
    position: relative
}

section.banner-infrastructure .form-infrastructure .form .form-field.active .button-submit {
    opacity: 1;
    visibility: visible
}

section.banner-infrastructure .form-infrastructure .form .form-field label {
    margin-top: 10px;
    margin-right: 10px;
    color: #2c3e50;
    font-weight: 400;
    font-size: 30px
}

section.banner-infrastructure .form-infrastructure .form .form-field label.error {
    color: red;
    font-size: 16px;
    width: 300px;
    position: relative
}

section.banner-infrastructure .form-infrastructure .form .form-field .form-control {
    background: 0 0;
    padding: 5px 0;
    border: 0;
    height: 46px;
    font-size: 30px;
    color: #00c4cc;
    margin-top: 8px;
    border-bottom: 2px solid transparent;
    transition: all ease .2s
}

section.banner-infrastructure .form-infrastructure .form .form-field .form-control.active {
    border-bottom: 2px solid #cdcdcd
}

section.banner-infrastructure .form-infrastructure .form .form-field .button-submit {
    opacity: 0;
    visibility: hidden;
    transition: all ease .1s;
    height: 46px;
    width: 46px;
    background: #00c4cc;
    color: #fff;
    font-size: 24px;
    border: 0;
    text-align: center;
    line-height: 46px;
    outline: 0;
    position: absolute;
    top: 7px;
    right: -12px
}

.flex-graphic {
    margin-top: 20px;
    height: 600px;
    width: 100%;
    background: #fff;
    margin-bottom: 30px;
    padding: 30px
}

.flex-quote {
    max-width: 890px;
    font-size: 22px;
    font-weight: 300;
    margin-bottom: 30px
}

.flex-quote .quote-icon {
    margin-bottom: 10px
}

.flex-quote .quote-text {
    margin-bottom: 30px;
    line-height: 1.6
}

.flex-quote .quote-line svg,
div.image {
    width: 100%
}

div.image {
    position: absolute;
    height: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    left: 0;
    right: 0;
    top: 0;
    overflow: hidden;
    margin: 0 auto
}

.invert .content,
.invert .content-holder *,
.invert .date,
.invert .description,
.invert .info,
.invert .preview,
.invert .table *,
.invert .title {
    color: #fff
}

.invert .title a {
    line-height: 1.6;
    text-decoration: none;
    color: #fff
}

.invert .info a {
    text-decoration: underline;
    color: #fff
}

.pre-title {
    color: #00c4cc;
    font-weight: 300;
    line-height: 1.2;
    font-family: "Khand", sans-serif;
    font-size: 24px;
    position: relative
}

.date {
    line-height: 1;
    margin-top: 4px;
    color: #2c3e50;
    font-size: 12px
}

.bg-main .button-custom.button-custom-main:focus,
.bg-main .button-custom.button-custom-main:hover {
    color: #fff
}

.bg-main .button-custom.button-custom-main:before {
    border-top-color: #fff;
    border-bottom-color: #fff
}

.bg-main .button-custom.button-custom-main:after {
    background-color: #fff
}

.theme-color {
    color: #2c3e50 !important
}

.theme-color-main {
    color: #00c4cc !important
}

.theme-color-sec {
    color: #132055 !important
}

.social-links {
    position: relative
}

.social-links a {
    color: #fff;
    height: 28px;
    width: 28px;
    text-align: center;
    display: inline-block;
    font-size: 20px;
    padding: 0;
    line-height: 28px;
    transition: all ease .5s;
    border-radius: 50%
}

.social-links a:hover,
nav.menu.main-menu>ul>li.active>a>span,
nav.menu.main-menu>ul>li.has-children:hover>a,
nav.menu.main-menu>ul>li>a:hover,
nav.menu.main-menu>ul>li>a:hover>span,
nav.menu.main-menu>ul>li>a>strong {
    color: #00c4cc
}

.description {
    font-size: 22px;
    line-height: 1.6
}

.description,
.light {
    font-weight: 400
}

.preview {
    line-height: 1.8
}

.except {
    line-height: 1.2;
    font-size: 18px
}

.info {
    font-size: 16px
}

.info p,
.table h1,
.table h2,
.table h3,
.table h4,
.table h5,
.table h6,
.table p,
.table ul,
.text p {
    margin-bottom: 0
}

.info a,
nav.menu ul li a {
    color: #2c3e50;
    text-decoration: underline
}

.text {
    font-size: 14px;
    line-height: 1.8
}

.skip-button {
    position: absolute;
    top: -1000em
}

.skip-button:focus {
    left: 6px;
    top: 7px;
    height: auto;
    width: auto;
    display: block;
    font-size: 14px;
    font-weight: 600;
    padding: 15px 23px 14px;
    background: #f1f1f1;
    color: #0073aa;
    z-index: 100000;
    line-height: normal;
    text-decoration: none;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, .6)
}

.skip-button:hover {
    font-weight: 800
}

.custom-link {
    text-decoration: none;
    font-weight: 600;
    position: relative
}

.custom-link .button-text {
    border-bottom: 1px solid #2c3e50
}

.custom-link:hover .button-text {
    border-color: #132055
}

.custom-link .button-info {
    font-size: 14px;
    color: #000;
    font-weight: 300
}

.button-custom,
.button-link {
    display: inline-block;
    position: relative
}

.button-link {
    color: #00c4cc;
    transition: all ease .3s;
    text-decoration: underline;
    line-height: 1
}

.button-logo-medium svg {
    display: inline-block;
    margin: -5px 0
}

.button-logo-medium:hover svg g rect,
.form .button-search:hover svg path {
    fill: #00c4cc
}

.button-custom {
    text-decoration: none;
    border-radius: 50px;
    min-width: 180px;
    text-align: center;
    font-size: 18px;
    padding: 21px 40px;
    vertical-align: top;
    font-weight: 500;
    line-height: 18px;
    overflow: hidden;
    border: 0;
    transition: all ease .5s;
    background: 0 0
}

.button-custom.button-custom-main-static {
    color: #fff;
    background: #00c4cc;
    text-decoration: none
}

.button-custom.button-custom-main-static:hover {
    color: #00c4cc;
    background: #fff;
    text-decoration: none
}

.button-custom.button-custom-main {
    color: #fff;
    background: #00c4cc;
    overflow: hidden
}

.button-custom.button-custom-main:hover {
    color: #fff;
    text-decoration: none;
    background: #2c3e50
}

.button-custom.button-custom-sec {
    background: #132055;
    color: #fff;
    overflow: hidden
}

.button-custom.button-custom-light:hover,
.button-custom.button-custom-sec:hover,
.button-custom.button-custom-white:hover {
    background: #00c4cc;
    color: #fff
}

.button-custom.button-custom-white {
    background: #fff;
    color: #00c4cc;
    overflow: hidden
}

.button-custom.button-custom-light {
    background: 0 0;
    border: 1px solid #00c4cc;
    color: #00c4cc;
    overflow: hidden
}

.button-custom.button-lg {
    font-size: 18px;
    min-width: 230px;
    padding: 21px 40px
}

.button-custom.button-wide {
    min-width: 250px
}

.button-custom.button-xl {
    font-size: 18px;
    padding: 24px 30px;
    min-width: 200px
}

.button-holder {
    position: relative;
    z-index: 1
}

.button-holder .button-custom {
    margin-right: 10px
}

.button-holder .button-custom:last-child {
    margin-right: 0 !important
}

.testimonials-module .holder {
    max-width: 1000px;
    margin: 0 auto
}

.testimonial .testimonial-arrow {
    overflow: hidden;
    width: 100%
}

.testimonial .testimonial-details h4 {
    font-size: 22px
}

.testimonials-invert .testimonial-arrow {
    display: none
}

.testimonials-invert .carousel-testimonials .slick-dots {
    text-align: center;
    width: 100%;
    left: 0;
    bottom: -40px
}

.testimonials-invert .slider .cursor {
    opacity: .8;
    mix-blend-mode: normal
}

.slick-dots {
    bottom: 30px
}

.slick-dots li {
    margin: 0 2px;
    padding: 10px 2px;
    color: #fff
}

.slick-dots li button {
    text-indent: -9999999px;
    color: #fff;
    font-size: 14px;
    border-radius: 50%;
    padding: 0;
    width: 6px;
    margin: 0 auto;
    height: 6px;
    border: 1px solid #e1e1e1;
    background-color: #e1e1e1
}

.slick-arrow:before,
.slick-dots li button:before,
section.banner .slick-dots li button:before {
    content: none
}

.slick-dots li.slick-active {
    color: #000
}

.slick-dots li.slick-active button {
    background-color: #00c4cc;
    border-color: #00c4cc
}

.summary .button-custom.button-custom-main:hover {
    background-color: #fff;
    color: #00c4cc;
    transition: all ease .2s;
    border-color: #fff
}

.carousel-featured-posts .slick-dots {
    bottom: inherit;
    top: 0;
    width: 50%;
    padding-right: 20px;
    text-align: right
}

.carousel-featured-posts .slick-arrow {
    z-index: 40;
    background-color: #00c4cc;
    transform: none;
    top: 0;
    padding: 3px 19px;
    font-size: 25px;
    line-height: 44px;
    width: 50px;
    height: 50px;
    text-align: center;
    color: #fff;
    border: 0
}

.carousel-featured-posts .slick-arrow svg,
section.tabs-module .tab-navigation .tab-btn svg {
    position: relative;
    top: -2px;
    width: 8px;
    height: 14px
}

.carousel-featured-posts .slick-arrow svg path,
section.tabs-module .tab-navigation .tab-btn svg path {
    stroke-width: 3px;
    stroke: #fff
}

.carousel-featured-posts .slick-arrow:hover {
    transform: scale(.95)
}

.carousel-featured-posts .slick-arrow.slick-prev {
    background-color: #41d2d5;
    border-radius: 5px 0 0 5px;
    left: 0
}

.carousel-featured-posts .slick-arrow.slick-next {
    border-radius: 0 5px 5px 0;
    left: 50px;
    right: inherit
}

.carousel-testimonials .slick-dots {
    width: 150px;
    left: inherit;
    right: 0;
    bottom: 35px;
    text-align: right
}

.team-module .slider .slick-slide {
    cursor: none
}

.carousel-posts {
    position: relative;
    height: 400px;
    overflow: hidden
}

.carousel-posts .slick-list {
    padding: 0 !important;
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
    overflow: visible
}

.carousel {
    width: 100%;
    position: relative;
    display: block
}

.slider {
    height: 0;
    overflow: hidden
}

.slider.initialized {
    height: auto;
    overflow: visible
}

.scroll-top {
    bottom: 50%;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    margin-left: -15px;
    position: fixed;
    right: 30px;
    transform: rotate(90deg) translateX(100px);
    transition: all .3s ease;
    z-index: 100
}

.scroll-top:hover .scroll-mouse {
    border-color: #2c3e50;
    background: #2c3e50
}

.scroll-top:hover .scroll-arrows:after,
.scroll-top:hover .scroll-arrows:before {
    border-left: 1px solid #2c3e50;
    border-top: 1px solid #2c3e50
}

.scroll-top .scroll-mouse {
    border-radius: 10px;
    border: 1px solid #fff;
    background: #00c4cc;
    height: 20px;
    margin-bottom: 0;
    width: 30px
}

.scroll-top .scroll-mouse:after {
    -webkit-animation: mouseanim 2s ease-in-out infinite;
    animation: mouseanim 2s ease-in-out infinite;
    background-color: #fff;
    content: "";
    height: 2px;
    margin-top: -1px;
    position: absolute;
    left: 10px;
    top: 50%;
    width: 5px
}

.scroll-top .scroll-arrows {
    bottom: 0;
    left: 0;
    margin: 0 0 13px -14px;
    position: absolute
}

.scroll-top .scroll-arrows:after,
.scroll-top .scroll-arrows:before {
    -webkit-animation: arrowsanim 1s infinite ease-in-out;
    animation: arrowsanim 1s infinite ease-in-out;
    border-left: 1px solid #00c4cc;
    border-top: 1px solid #00c4cc;
    box-shadow: 0 0 0 1px #fff;
    content: "";
    height: 6px;
    opacity: .38;
    position: absolute;
    transform: rotate(-45deg);
    width: 6px
}

.scroll-top .scroll-arrows:after {
    -webkit-animation-delay: .2s;
    animation-delay: .2s;
    left: -10px
}

.scroll-top.active {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
    transform: rotate(90deg) translateX(0)
}

.alert {
    font-size: 14px;
    padding: 8px 10px
}

.cta-module {
    position: relative;
    background: #000128
}

.cta-module .container {
    position: relative;
    z-index: 3
}

.cta-module .image {
    position: absolute;
    max-width: 850px;
    right: 0;
    top: 0;
    z-index: 2;
    pointer-events: none;
    left: inherit
}

.cta-module .image:before {
    content: "";
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    right: 0;
    background: linear-gradient(to right, #000128 0, rgba(0, 1, 40, 0) 100%)
}

.calculator-loader {
    z-index: 99;
    position: absolute;
    top: 35%;
    margin: 0 auto;
    right: 0;
    left: 0;
    width: 70px;
    transition: all ease 1s;
    transform: scale(1)
}

.calculator-loader .loader {
    transform: rotateZ(45deg);
    perspective: 1000px;
    border-radius: 50%;
    display: inline-block;
    width: 1em;
    height: 1em;
    font-size: 70px;
    line-height: 200px;
    color: inherit;
    vertical-align: middle;
    pointer-events: none
}

.calculator-loader .loader:after,
.calculator-loader .loader:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: inherit;
    height: inherit;
    border-radius: 50%;
    animation: 1s spin linear infinite
}

.calculator-loader .loader:before {
    transform: rotateX(70deg)
}

.calculator-loader .loader:after {
    transform: rotateY(70deg);
    animation-delay: .4s
}

.calculator-loader.off {
    opacity: 0;
    visibility: hidden;
    pointer-events: none
}

.bg-light .table-hover>tbody>tr:hover>* {
    --bs-table-accent-bg: #fff !important;
    color: #2c3e50
}

.bg-dark .table-hover>tbody>tr:hover>*,
.table.table-invert tbody tr td,
.table.table-invert thead tr th,
nav.mobile-menu ul li.active .button-custom {
    color: #fff
}

.table,
.table-hover>tbody>tr:hover>*,
nav.menu.main-menu>ul>li.active>a {
    color: #2c3e50
}

.table {
    font-size: 16px;
    margin-bottom: 20px
}

.table h1 strong,
.table h2 strong,
.table h3 strong,
.table h4 strong,
.table h5 strong,
.table h6 strong,
.table p strong,
.table ul strong {
    font-weight: 900
}

.table.table-invert tbody tr,
.table.table-invert thead {
    border-bottom: 1px solid rgba(255, 255, 255, .2)
}

.table tbody,
.table.table-invert tbody {
    border: 0
}

.table thead {
    border: 0;
    border-bottom: 1px solid #ddd
}

.table,
.table thead tr {
    border: 0;
    background: 0 0
}

.table thead tr th {
    padding: 15px 0;
    border: 0;
    font-size: 14px;
    color: #2c3e50;
    font-weight: 500;
    text-transform: uppercase
}

.table thead tr th:last-child {
    border-right: none
}

.table tbody tr {
    border-bottom: 1px solid rgba(221, 221, 221, .8)
}

.table tbody tr td {
    color: #2c3e50;
    padding: 15px 0;
    border-bottom: none
}

.table tbody tr:last-child {
    border-bottom: none
}

.accordion-tiles .accordion-button[aria-expanded=false] .image-holder svg,
.accordion-tiles .accordion-button[aria-expanded=true] .image-holder svg,
.accordion-tiles .image-holder svg,
.text-center .g-recaptcha {
    display: inline-block
}

.page-link {
    margin-right: 5px;
    border-radius: 3px
}

.page-link,
.page-link:hover {
    color: #2c3e50;
    border-color: #ddd;
    background: #fff
}

.page-link.current {
    color: #fff;
    border-color: #132055;
    background: #132055
}

.page-item:first-child .page-link {
    border-radius: 3px
}

.page-item:last-child .page-link {
    border-radius: 3px
}

.row-eq-height>[class^=col] {
    display: flex;
    flex-direction: column
}

.row-eq-height>[class^=col]>[class^=col]:last-of-type div {
    margin: 10px
}

.row-eq-height>[class^=col]>[class^=col]:last-of-type div:first-of-type {
    margin-top: 0
}

.row-eq-height>[class^=col]>[class^=col]:last-of-type div:last-of-type {
    margin-bottom: 0
}

.footer-bottom {
    position: relative;
    z-index: 2
}

.footer-bottom .h4 {
    font-size: 20px;
    line-height: 20px !important
}

.footer-image,
header.main-header {
    position: absolute;
    width: 100%;
    left: 0
}

.footer-image {
    background-size: cover;
    background-position: bottom;
    height: 100%;
    top: 0;
    pointer-events: none;
    opacity: .5;
    filter: blur(5px)
}

.footer-logo {
    max-width: 120px;
    margin-bottom: 10px
}

.footer-logo svg {
    height: 50px;
    width: 120px
}

.logo-boxes .logo-box .d-flex {
    height: 60px
}

.logo-boxes .logo-box img {
    max-width: 170px;
    max-height: 60px
}

header.main-header {
    max-width: 1950px;
    padding: 20px 0 0;
    right: 0;
    margin: 0 auto;
    background: #fff;
    border-bottom: 1px solid #f9f9fb;
    z-index: 99;
    backface-visibility: hidden;
    -webkit-transition: all .8s ease-in-out;
    transition: all .8s ease-in-out
}

header.main-header.sticky {
    position: fixed;
    animation: slide-up .7s
}

header.main-header .logo {
    display: inline-block;
    margin: 20px 0
}

header.main-header .logo svg {
    width: 170px;
    height: 50px
}

header.main-header nav.menu {
    margin: 33px 0 0
}

header.main-header .button-holder {
    position: absolute;
    right: 20px;
    top: 26px
}

header.main-header .partners-logo {
    margin-top: 15px
}

.bg-white {
    background-color: #fff
}

.bg-light {
    background-color: #f9f9fb !important
}

.bg-dark {
    background-color: #132055 !important
}

.bg-darker {
    background-color: #0b2946 !important
}

.bg-main {
    background-color: #00c4cc !important
}

.bg-secondary {
    background-color: #132055 !important
}

.bg-py {
    padding: 60px 0
}

section.remove-space {
    margin-top: -120px
}

section.add-space {
    padding-top: 120px
}

.content figure,
section iframe {
    max-width: 100%
}

footer.main-footer {
    padding: 70px 0 0;
    background: #082d51
}

.news-module {
    overflow: hidden
}

nav.menu.main-menu>ul>li {
    display: inline-block;
    vertical-align: top;
    padding: 0 25px 0 20px
}

nav.menu.main-menu>ul>li>a {
    font-weight: 500;
    padding-bottom: 50px;
    text-decoration: none;
    text-align: left;
    display: inline-block;
    line-height: 1.2;
    text-transform: uppercase;
    position: relative
}

nav.menu.main-menu>ul>li.active>a:before,
nav.menu.main-menu>ul>li>a.active:before {
    content: "";
    height: 2px;
    width: 100%;
    position: absolute;
    bottom: 40px;
    left: 0;
    background: #00c4cc
}

nav.menu.main-menu>ul>li>a>span {
    font-size: 12px;
    text-transform: uppercase;
    font-weight: 300;
    transition: all ease .5s
}

nav.menu.main-menu>ul>li.active>a:before {
    bottom: -1px;
    height: 3px
}

nav.menu.main-menu>ul>li.has-children:hover>ul {
    visibility: visible;
    pointer-events: all;
    opacity: 1;
    z-index: 1;
    transform: translateY(0);
    transition-delay: 0s, 0s, .3s
}

nav.menu.main-menu>ul>li.has-children.row-menu.industries>ul:before {
    content: "Digital Transformation for Key Industries"
}

nav.menu.main-menu>ul>li.has-children.row-menu:hover>ul li,
nav.menu.main-menu>ul>li.has-children.row-menu:hover>ul:before,
nav.menu.main-menu>ul>li.has-children:hover>ul li {
    opacity: 1;
    transform: translateX(0)
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul {
    padding-top: 160px
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul:before {
    position: absolute;
    top: 95px;
    font-family: "Khand", sans-serif;
    text-decoration: none;
    font-size: 32px;
    font-weight: 400;
    line-height: 1.3;
    color: #00c4cc;
    opacity: 0;
    transition: all ease .5s;
    transform: translateX(20px)
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul>li {
    display: block;
    width: 30%;
    padding-right: 100px;
    float: left;
    opacity: 0;
    transition: all ease .5s;
    transform: translateX(20px)
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(1),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(2),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(3),
nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul li:nth-child(1) {
    transition-delay: .1s
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(4),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(5),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(6),
nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul li:nth-child(2) {
    transition-delay: .15s
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(7),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(8),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(9),
nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul li:nth-child(3) {
    transition-delay: .2s
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(10),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(11),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(12),
nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul li:nth-child(4) {
    transition-delay: .25s
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(13),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(14),
nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:nth-child(15),
nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul li:nth-child(5) {
    transition-delay: .3s
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul>li:hover a,
nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul li:hover a {
    transform: translateX(10px)
}

nav.menu.main-menu>ul>li.has-children.row-menu>ul>li a {
    display: inline-block;
    transition: all ease .3s;
    max-width: 500px
}

nav.menu.main-menu>ul>li.has-children>ul {
    background: #fff;
    box-shadow: 20px 20px 20px rgba(0, 0, 0, .15);
    flex-wrap: wrap;
    width: 100%;
    height: 550px;
    overflow: hidden;
    padding-top: 100px;
    padding-bottom: 100px;
    padding-left: calc((100% - 1500px)/2);
    padding-right: calc((100% - 1500px)/2);
    margin: 0 auto;
    text-align: left;
    list-style: none;
    position: absolute;
    left: 0;
    right: 0;
    top: 95%;
    z-index: 10;
    border: 0;
    visibility: hidden;
    pointer-events: none;
    opacity: 0;
    transition: all ease .2s
}

nav.menu.main-menu>ul>li.has-children>ul li {
    margin-bottom: 15px;
    opacity: 0;
    transition: all ease .5s;
    transform: translateX(20px)
}

nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>a {
    font-family: "Khand", sans-serif;
    text-decoration: none;
    font-size: 32px;
    font-weight: 400;
    line-height: 1.3;
    color: #00c4cc
}

nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul {
    margin-top: 20px
}

nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul li {
    padding-right: 15px
}

nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul li a {
    display: inline-block;
    transition: all ease .3s
}

nav.menu.main-menu>ul>li.has-children>ul li a {
    font-size: 17px
}

nav.menu.main-menu>ul>li.has-children>a:after {
    content: "";
    display: inline-block;
    font-family: "fontAwesome", sans-serif;
    margin-left: 10px
}

nav.menu.main-menu>ul>li.has-children:hover>a:after {
    content: ""
}

nav.menu h5 {
    font-family: "Open Sans", sans-serif;
    font-weight: 700
}

nav.menu ul {
    margin: 0;
    padding: 0
}

nav.menu ul,
nav.menu ul li {
    list-style: none
}

nav.menu ul li a:hover,
nav.menu ul li.active a,
section.tabs-module.tabs-module-compact .tabs-content h4,
section.we-are-module .content h4 {
    color: #00c4cc
}

nav.mobile-menu {
    display: block;
    height: 100%;
    overflow: auto;
    position: fixed;
    padding: 0 15px;
    right: 0;
    margin: 0;
    max-width: 100%;
    width: 280px;
    transform: translate3d(111%, 0, 0);
    transition: all ease 250ms;
    background-color: #fff;
    box-shadow: 0 0 30px 0 rgba(255, 255, 255, .2);
    z-index: 99
}

nav.mobile-menu ul li {
    padding: 0;
    margin: 15px 0
}

nav.mobile-menu ul li a {
    font-family: "Khand", sans-serif;
    font-weight: 600;
    font-size: 22px;
    text-decoration: none
}

nav.mobile-menu ul li .button-custom {
    font-size: 16px;
    padding: 16px 25px
}

.clear {
    clear: both
}

.form-radio {
    position: relative;
    margin-right: 30px;
    cursor: pointer;
    font-weight: 400;
    line-height: 28px;
    padding-left: 40px;
    font-size: 17px
}

.form-radio.form-radio-invert {
    padding-left: 0;
    display: block;
    margin-right: 0;
    margin-bottom: 15px;
    font-size: 18px
}

.form-radio.form-radio-invert:hover .radio-label {
    background: rgba(255, 255, 255, .2);
    border-color: #00c4cc
}

.form-radio.form-radio-invert strong,
.planner .downtime-summary .money strong {
    font-weight: 600
}

.form-radio.form-radio-invert .checkmark {
    top: 24px;
    left: 20px
}

.form-radio.form-radio-invert input[type=radio]:checked~.checkmark~.radio-label {
    background: #fff;
    border-color: #00c4cc
}

.form-radio.form-radio-invert .radio-label {
    transition: all ease .3s;
    display: block;
    padding: 25px 40px 25px 60px;
    border-radius: 10px;
    border: 1px solid #bed0d2
}

.form-radio input {
    opacity: 0;
    width: 100%;
    height: 100%;
    z-index: 3;
    cursor: pointer;
    position: absolute
}

.form-checkbox input[type=checkbox]:checked~.checkmark:before,
.form-radio input:checked~.checkmark:after {
    opacity: 1
}

.form-radio .checkmark {
    position: absolute;
    left: 0
}

.form-radio .checkmark:after,
.form-radio .checkmark:before {
    content: "";
    border-radius: 50%;
    width: 30px;
    height: 30px;
    position: absolute;
    left: 0;
    top: 0
}

.form-radio .checkmark:before {
    display: block;
    margin-right: 10px;
    background: #fff;
    border: 1px solid #c4d3d5
}

.form-radio .checkmark:after {
    opacity: 0;
    border: 8px solid #00c4cc;
    font-size: 18px
}

.form-checkbox {
    display: inline-block;
    padding: 0 0 0 40px;
    margin-right: 30px;
    position: relative;
    cursor: pointer;
    line-height: 24px;
    font-weight: 400;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.form-checkbox.orm-checkbox-sm {
    font-size: 14px
}

.form-checkbox.form-checkbox-invert {
    padding-left: 0;
    display: block;
    margin-right: 0;
    margin-bottom: 15px
}

.form-checkbox.form-checkbox-invert .checkmark {
    top: 24px;
    left: 20px
}

.form-checkbox.form-checkbox-invert input[type=checkbox]:checked~.checkmark~.checkbox-label {
    background: #fff
}

.form-checkbox.form-checkbox-invert .checkbox-label {
    display: block;
    padding: 25px 40px 25px 60px;
    border-radius: 10px;
    border: 1px solid #bed0d2
}

.form-checkbox:last-child {
    margin-right: 0
}

.form-checkbox .checkmark {
    position: absolute;
    top: -2px;
    left: 0;
    height: 30px;
    width: 30px;
    border-radius: 5px;
    background-color: #fff;
    border: 1px solid #c4d3d5
}

.form-checkbox .checkmark:after {
    content: "";
    position: absolute;
    display: block;
    visibility: hidden;
    top: 5px;
    left: 10px;
    width: 8px;
    height: 14px;
    opacity: 0;
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: scale(0) rotate(45deg)
}

.form-checkbox label {
    cursor: pointer
}

.form-checkbox input[type=checkbox] {
    height: 30px;
    width: 30px;
    opacity: 0;
    z-index: 2;
    left: 0;
    top: 0;
    margin: 0;
    position: absolute;
    cursor: pointer
}

.form-checkbox input[type=checkbox]:checked~.checkmark {
    background-color: #00c4cc;
    border-color: #00c4cc
}

.form-checkbox input[type=checkbox]:checked~.checkmark:after {
    visibility: visible;
    opacity: 1;
    -webkit-transform: scale(1) rotate(45deg);
    -ms-transform: scale(1) rotate(45deg);
    transform: scale(1) rotate(45deg)
}

img.object-fit {
    object-position: top;
    width: 100%;
    height: 100%;
    object-fit: cover
}

.form {
    position: relative;
    z-index: 2
}

.form.form-contact {
    max-width: 650px
}

.form label.error {
    font-size: 14px;
    font-weight: 300;
    position: absolute;
    color: red
}

.form hr {
    border-top: 1px solid #234a58
}

.form .form-label {
    margin-bottom: 3px;
    font-size: 14px;
    color: #2c3e50;
    font-weight: 600;
    text-transform: uppercase
}

.form .button-search {
    position: absolute;
    background: 0 0;
    border: 0;
    box-shadow: none;
    top: 0;
    right: 0;
    padding: 15px
}

.form .form-field,
article a>img {
    margin-bottom: 30px
}

.form textarea.form-control {
    height: 100px
}

.form input[type=file].form-control {
    line-height: 48px;
    padding-left: 12px
}

.form .form-control {
    position: relative;
    background-color: #fff;
    border-color: #c4d3d5;
    border-radius: 3px;
    height: 60px
}

.form .form-control.form-control-light,
section.banner .bg-light .pattern {
    background-color: #f9f9fb
}

.form .form-control::placeholder {
    font-weight: 300
}

.form .form-control.error {
    border-color: red;
    font-weight: 300
}

.form .form-control:focus {
    outline: 0;
    box-shadow: none
}

section.banner {
    position: relative;
    background-color: #f9f9fb;
    padding: 0;
    overflow: hidden
}

section.banner .container {
    position: relative;
    z-index: 20
}

section.banner .content-holder {
    padding: 15px 0
}

section.banner .bg-light .pattern.pattern-end {
    background-image: radial-gradient(#e0e0e2 2%, transparent 3%), radial-gradient(#e0e0e2 2%, transparent 3%)
}

section.banner .bg-dark .pattern {
    background-color: #132055
}

section.banner .bg-dark .pattern.pattern-end,
section.banner .bg-darker .pattern.pattern-end {
    background-image: radial-gradient(rgba(224, 224, 226, .5) 2%, transparent 3%), radial-gradient(rgba(224, 224, 226, .5) 2%, transparent 3%)
}

section.banner .bg-darker .pattern {
    background-color: #2c3e50
}

section.banner.banner-slider .line-svg {
    position: absolute;
    top: 0;
    left: -300px
}

section.banner.banner-slider .cursor {
    background: rgba(0, 196, 204, .8);
    mix-blend-mode: normal !important
}

section.banner.banner-slider .decor-line.decor-line-start {
    border-left: 1px solid rgba(255, 255, 255, .8)
}

section.banner.banner-slider .slick-arrow {
    height: 50px;
    width: 50px;
    background: 0 0;
    border-radius: 2px;
    z-index: 30
}

section.banner.banner-slider .slick-arrow:hover svg path {
    stroke: #00c4cc
}

section.banner.banner-slider .slick-arrow.slick-prev {
    top: 100px;
    left: calc((100% - 1540px)/2)
}

section.banner.banner-slider .slick-arrow.slick-next {
    top: 100px;
    left: calc((100% - 1540px)/2 + 50px);
    right: inherit
}

section.banner.banner-slider .banner-holder {
    height: 700px
}

section.banner.banner-slider .d-table-cell {
    height: 700px;
    vertical-align: middle
}

section.banner.banner-home .d-table-cell {
    height: 740px;
    vertical-align: middle
}

section.banner.banner-page,
section.banner.banner-post {
    pointer-events: none
}

section.banner.banner-page .front-image {
    right: 15%;
    width: 500px
}

section.banner.banner-page .banner-holder,
section.banner.banner-page.animate .banner-holder,
section.banner.banner-page.animate .banner-holder .decor-line.decor-line-start,
section.banner.banner-page.animate .banner-holder .parallax-holder {
    opacity: 1
}

section.banner.banner-page .content-holder {
    opacity: 1;
    transform: translateY(0)
}

section.banner.banner-page.animate,
section.banner.banner-post.animate {
    pointer-events: all
}

section.banner.banner-page.animate .banner-holder .back-image {
    right: -10%;
    opacity: 1;
    transition: 0s
}

section.banner.banner-page.animate .container,
section.banner.banner-page.animate .content-holder {
    opacity: 1;
    transform: translateY(0)
}

section.banner.banner-page.animate .decor-line {
    transform: skewX(20deg) translateX(0) rotate(0deg)
}

section.banner.banner-page.animate .decor-line-extra span {
    right: 29.02%
}

section.banner.banner-page .d-table-cell {
    height: 500px;
    vertical-align: middle
}

section.banner.banner-page .banner-holder {
    transition: all ease .5s;
    height: 500px
}

section.banner.banner-page .banner-holder .parallax-holder {
    opacity: 0;
    transition: all ease .5s
}

section.banner.banner-page .banner-holder .container {
    transition: all ease .5s;
    transform: translateY(0);
    opacity: 1
}

section.banner.banner-page .banner-holder .pattern {
    right: 29%;
    transition-delay: 1s;
    width: 100%
}

section.banner.banner-page .banner-holder .decor-line.decor-line-start {
    right: 28.95%;
    opacity: 0;
    transition-delay: 1.3s
}

section.banner.banner-page .banner-holder .decor-line.decor-line-end {
    right: 23%;
    transition-delay: 1.3s
}

section.banner.banner-post.animate .banner-holder,
section.banner.banner-post.animate .banner-holder .decor-line.decor-line-start,
section.banner.banner-slider .banner-holder.animate .slick-active.slick-current .back-image {
    opacity: 1
}

section.banner.banner-post.animate .back-image {
    opacity: 1;
    transition: 0s;
    max-width: 1560px;
    right: inherit;
    left: 0
}

section.banner.banner-post.animate .container,
section.banner.banner-post.animate .content-holder {
    opacity: 1;
    transform: translateY(0)
}

section.banner.banner-post.animate .decor-line {
    transform: skewX(20deg) translateX(0) rotate(0deg)
}

section.banner.banner-post.animate .decor-line.decor-line-start {
    background: #fff;
    border-right: 1px solid #ddd
}

section.banner.banner-post.animate .decor-line-extra span {
    background: #fff;
    right: 29.02%
}

section.banner.banner-post .d-table-cell {
    height: 654px;
    vertical-align: middle
}

section.banner.banner-post .banner-holder {
    opacity: 0;
    transition: all ease .5s;
    height: 654px
}

section.banner.banner-post .banner-holder .container {
    transition: all ease .5s;
    transform: translateY(0);
    opacity: 1
}

section.banner.banner-post .banner-holder .pattern {
    right: -10%;
    width: 39%;
    transition-delay: 1s
}

section.banner.banner-post .banner-holder .decor-line.decor-line-start {
    right: 28.95%;
    opacity: 0;
    transition-delay: 1.3s
}

section.banner.banner-post .banner-holder .decor-line.decor-line-end {
    right: 23%;
    transition-delay: 1.3s
}

section.banner.banner-slider {
    margin-bottom: 0
}

section.banner.banner-slider .banner-holder {
    overflow: hidden;
    opacity: 0;
    transition: all ease .5s
}

section.banner.banner-slider .banner-holder.animate .slick-active.slick-current .container .button-holder {
    transition-delay: 1s
}

.rollover-boxes .box.box-lg .image,
section.banner.banner-slider .banner-holder.initialized {
    opacity: 1
}

section.banner.banner-slider .banner-holder.initialized .back-image {
    opacity: 1;
    transition: 0s
}

section.banner.banner-slider .banner-holder.initialized .pattern {
    transition-delay: 1s;
    width: 135%;
    right: 35%
}

section.banner.banner-slider .banner-holder.initialized .container,
section.banner.banner-slider .banner-holder.initialized .content-holder {
    transform: translateY(0);
    opacity: 1
}

section.banner.banner-slider .banner-holder.initialized .decor-line.decor-line-start {
    opacity: 1;
    transition-delay: 1.5s
}

section.banner.banner-slider .banner-holder.initialized .decor-line.decor-line-end {
    transition-delay: 1.5s
}

section.banner.banner-slider .banner-holder.initialized .decor-line {
    transform: skewX(20deg) translateX(0) rotate(0deg)
}

section.banner.banner-slider .banner-holder.initialized .decor-line-extra span {
    right: 35%
}

section.banner.banner-slider .banner-holder .container {
    opacity: 0;
    transition: all ease 1s;
    transition-delay: .2s
}

section.banner.banner-slider .back-image {
    opacity: 0;
    transition: all ease .5s
}

section.banner.banner-slider .slide.slick-active .button-holder,
section.banner.banner-slider .slide.slick-active .content-holder {
    opacity: 1;
    transform: translateY(0)
}

section.banner .button-holder {
    z-index: 5;
    position: relative;
    transition: all ease 1s
}

section.banner .content-holder {
    z-index: 5;
    position: relative;
    transition: all ease 1.5s
}

section.banner .parallax {
    position: absolute;
    overflow: hidden;
    z-index: 10;
    width: 100%;
    height: 100%;
    top: 0
}

section.banner .back-image {
    opacity: 0;
    position: absolute;
    transition: all ease 1s;
    height: 100%;
    width: 100%;
    background-size: auto;
    max-width: 1100px;
    right: 0;
    top: 0
}

section.banner .front-image {
    position: absolute;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center bottom;
    width: 700px;
    height: 100%;
    right: 18%;
    top: 0;
    z-index: 9
}

section.banner .decor-line-extra {
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 21;
    pointer-events: none
}

section.banner .decor-line-extra.long span {
    animation: rotateSliderLinesLong 1.35s normal ease
}

section.banner .decor-line-extra span {
    position: absolute;
    display: block;
    top: 0;
    z-index: 2;
    height: 100%;
    width: 1px;
    right: 100%;
    opacity: 0;
    background: rgba(44, 62, 80, .25);
    transform: skewX(-20deg) translateX(0);
    animation: rotateSliderLines 1.7s normal ease
}

section.banner .decor-line-extra span:nth-child(2) {
    animation-delay: .2s
}

section.banner .decor-line-extra span:nth-child(3) {
    animation-delay: .4s
}

section.banner .decor-line-extra span:nth-child(4) {
    animation-delay: .6s
}

section.banner .decor-line-holder {
    position: absolute;
    height: 100%;
    width: 100%;
    pointer-events: none;
    top: 0;
    left: 0;
    right: 0
}

section.banner .decor-line-holder.decor-line-holder-start {
    z-index: 2
}

section.banner .decor-line-holder.decor-line-holder-end {
    z-index: 10
}

section.banner .pattern {
    position: absolute;
    top: 0;
    z-index: 2;
    width: calc(100% - 500px);
    background-size: 60px 60px;
    transition: all ease 1s;
    background-position: 0 0, 30px 30px;
    background-repeat: repeat;
    pointer-events: none;
    right: 35%;
    background-color: #f9f9fb;
    height: 100%;
    transform: skewX(-20deg)
}

section.banner .pattern.pattern-end.bg-light {
    background-image: radial-gradient(#e0e0e2 2%, transparent 3%), radial-gradient(#e0e0e2 2%, transparent 3%)
}

section.banner .pattern.pattern-end.bg-dark,
section.banner .pattern.pattern-end.bg-darker {
    background-image: radial-gradient(rgba(224, 224, 226, .5) 2%, transparent 3%), radial-gradient(rgba(224, 224, 226, .5) 2%, transparent 3%)
}

section.banner .slick-dots {
    bottom: 0;
    z-index: 15;
    padding-left: calc((100% - 1520px)/2);
    text-align: left
}

section.banner .slick-dots li {
    margin-right: 10px;
    width: 60px;
    transition: all ease .5s
}

section.banner .slick-dots li.slick-active {
    width: 120px
}

section.banner .slick-dots li.slick-active button {
    background: #00c4cc
}

section.banner .slick-dots li button {
    width: 100%;
    background: #e1e1e1;
    border-radius: 10px;
    height: 4px;
    padding: 0
}

section.custom-tabs .card {
    padding: 0;
    border: 0
}

section.services-tabs-module .boxes {
    margin-right: -50px;
    margin-left: -30px
}

section.services-tabs-module .rollover-boxes .box {
    background: #f9f9fb
}

section.services-tabs-module .rollover-boxes .box.box-lg .box-title,
section.services-tabs-module .rollover-boxes .box:hover .box-title {
    color: #fff
}

section.services-tabs-module .rollover-boxes .box .box-title {
    color: #2c3e50
}

.rollover-boxes {
    margin-bottom: -30px
}

.rollover-boxes.rollover-boxes-inline .box {
    width: 360px;
    float: left;
    margin-right: 30px
}

.rollover-boxes .box {
    display: block;
    height: 250px;
    margin-bottom: 30px;
    border-radius: 5px;
    background: #2c3e50
}

.rollover-boxes .box .image {
    border-radius: 5px;
    overflow: hidden;
    position: relative;
    transition: all ease .5s;
    opacity: 0
}

.rollover-boxes .box .image:after {
    content: "";
    pointer-events: none;
    background: rgba(0, 0, 0, .3);
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    display: block;
    position: absolute
}

.rollover-boxes .box.box-lg {
    height: 530px
}

.rollover-boxes .box .box-pre-title {
    font-size: 200px;
    color: #fff;
    position: absolute;
    top: 80px;
    left: 20px;
    z-index: 5;
    font-weight: 900;
    line-height: 65px
}

.rollover-boxes .box .box-pre-title span {
    font-size: 55px
}

.rollover-boxes .box .box-title {
    position: absolute;
    padding-right: 20px;
    bottom: 20px;
    left: 30px;
    color: #fff;
    text-decoration: none;
    font-size: 24px;
    z-index: 10
}

.rollover-boxes .box:hover .image {
    opacity: .7
}

.preview-projects .preview-project figure,
.rollover-boxes .box,
.rollover-holder {
    position: relative;
    overflow: hidden
}

.rollover-holder:hover .rollover {
    width: 100%;
    opacity: 1;
    visibility: visible
}

.rollover-holder:hover .rollover span:nth-child(1),
.rollover-holder:hover .rollover span:nth-child(2) {
    transform: skewX(20deg) translateX(0) rotate(0deg)
}

.rollover-holder .rollover {
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    display: block;
    position: absolute;
    overflow: hidden;
    opacity: 0;
    z-index: 3;
    visibility: hidden;
    transition: all .4s ease;
    background: #00c4cc
}

.rollover-holder .rollover span {
    position: absolute
}

.rollover-holder .rollover span:nth-child(1),
.rollover-holder .rollover span:nth-child(2) {
    position: absolute;
    background: rgba(255, 255, 255, .25);
    top: 0;
    z-index: 2;
    width: 1px;
    right: 65%;
    height: 100%;
    pointer-events: none;
    transition: all ease .4s;
    transform: skewX(20deg) translateX(150px) rotate(0deg)
}

.rollover-holder .rollover span:nth-child(2) {
    width: 4px;
    right: 27%;
    transition-delay: .1s
}

.rollover-holder .rollover span:nth-child(3) {
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    opacity: .9;
    display: block;
    position: absolute;
    transition: all .2s ease;
    background: #00c4cc
}

section.tabs-module .tabs-content.tabs-content-classic .content-holder {
    margin-top: 0;
    padding-top: 0;
    padding-left: 0
}

.nav-pills {
    margin-top: 50px
}

.nav-pills .nav-item {
    margin-bottom: 25px
}

.nav-pills .nav-item .nav-link {
    font-family: "Khand", sans-serif;
    border: 0;
    background: 0 0;
    padding: 0;
    color: #2c3e50;
    font-size: 24px;
    line-height: 1.2
}

.nav-pills .nav-item .nav-link:hover {
    color: #2c3e50
}

.nav-pills .nav-item .nav-link.active {
    color: #00c4cc;
    opacity: 1
}

.nav-pills.nav-pills-classic {
    margin-top: 0
}

.nav-pills.nav-pills-classic .nav-item {
    position: relative;
    margin-bottom: 10px
}

.nav-pills.nav-pills-classic .nav-item .nav-link {
    background: #fff;
    padding: 15px 25px;
    border-radius: 10px;
    border: 1px solid #ddd;
    font-size: 22px
}

.nav-pills.nav-pills-classic .nav-item .nav-link.active {
    background: #fff
}

.nav-pills.nav-pills-circle {
    text-align: right
}

.nav-pills.nav-pills-circle .nav-item {
    margin-bottom: 20px;
    padding-right: 40px;
    position: relative
}

.nav-pills.nav-pills-circle .nav-item .nav-link {
    font-size: 16px;
    font-family: "Roboto", sans-serif
}

.nav-pills.nav-pills-circle .nav-item .nav-link.active:before {
    height: 22px;
    width: 22px;
    top: -4px;
    right: -4px;
    border: 6px solid #00c4cc
}

.nav-pills.nav-pills-circle .nav-item .nav-link:before {
    z-index: 3;
    content: "";
    height: 18px;
    width: 18px;
    border: 3px solid #e1e1e1;
    background-color: #fff;
    border-radius: 50%;
    display: block;
    position: absolute;
    top: 1px;
    right: -2px
}

.nav-pills.nav-pills-circle .nav-item .nav-link:after {
    position: absolute;
    display: block;
    top: -50px;
    right: -3px;
    content: "";
    height: 150px;
    width: 11px;
    border-left: 1px solid #e1e1e1
}

section.tabs-module.tabs-module-full .card-body {
    padding: 0
}

section.tabs-module.tabs-module-full .tab-content .content-holder {
    margin-top: 50px;
    padding: 40px 80px 30px
}

section.tabs-module.tabs-module-compact .title-holder {
    margin-right: -50px
}

section.tabs-module.tabs-module-compact .nav-pills {
    margin-top: 10px;
    margin-right: -30px
}

section.tabs-module.tabs-module-compact .tab-content .button-holder {
    margin-left: 0
}

section.tabs-module.tabs-module-compact .scroll-content {
    max-height: 450px;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 20px
}

section.tabs-module.tabs-module-compact .scroll-content::-webkit-scrollbar {
    width: 5px
}

section.tabs-module.tabs-module-compact .scroll-content::-webkit-scrollbar-track {
    background: #ddd;
    box-shadow: inset 0 0 0 1px #f3f7ff;
    border-radius: 10px
}

section.tabs-module.tabs-module-compact .scroll-content::-webkit-scrollbar-thumb {
    background: #00c4cc;
    border-radius: 10px
}

section.tabs-module.tabs-module-compact .scroll-content::-webkit-scrollbar-thumb:hover {
    background: #00c4cc
}

section.tabs-module.tabs-module-compact .tabs-content {
    padding-top: 10px;
    padding-left: 100px
}

section.tabs-module.tabs-module-compact .tab-content .image-holder {
    margin-right: 0
}

section.tabs-module.tabs-module-compact .tab-content .content-holder {
    margin-top: 0;
    padding: 0;
    background: 0 0
}

section.tabs-module.tabs-module-compact .tab-navigation {
    position: relative;
    top: 15px;
    right: inherit;
    left: 0;
    z-index: 40
}

section.tabs-module.tabs-module-compact .card-body {
    padding: 0
}

section.tabs-module .tabs-content {
    position: relative;
    padding-left: 40px
}

section.tabs-module .tabs-content.tabs-content-classic {
    margin-bottom: 0
}

section.tabs-module .tabs-content.tabs-content-classic .tab-content .content-holder {
    min-height: auto;
    background: 0 0
}

section.tabs-module .tab-content .image-holder {
    margin-right: -220px
}

section.tabs-module .tab-content .content-holder {
    width: 100%;
    background: #fff;
    padding: 25px 50px 15px 100px;
    z-index: 2;
    position: relative
}

section.tabs-module .tab-content .button-holder {
    position: absolute;
    top: 30px;
    margin-left: 80px
}

section.tabs-module .tab-content .button-holder.button-holder-image {
    left: 30px
}

section.tabs-module .tab-content .button-holder .button-link {
    font-size: 24px;
    font-weight: 400;
    font-family: "Khand", sans-serif
}

section.tabs-module .tab-navigation {
    position: absolute;
    top: 15px;
    right: 18px;
    z-index: 40
}

section.tabs-module .tab-navigation .tab-btn {
    background-color: #00c4cc;
    padding: 3px 19px;
    font-size: 25px;
    line-height: 44px;
    width: 50px;
    height: 50px;
    text-align: center;
    color: #fff;
    border: 0;
    border-radius: 3px
}

section.tabs-module .tab-navigation .tab-btn:hover {
    transform: scale(.95)
}

section.tabs-module .tab-navigation .tab-btn.prev-tab {
    border-radius: 5px 0 0 5px;
    margin-right: -4px;
    background-color: #41d2d5
}

section.tabs-module .tab-navigation .tab-btn.next-tab {
    border-radius: 0 5px 5px 0;
    margin-right: -4px
}

.card {
    background: 0 0
}

.projects {
    position: relative;
    padding: 0 16px
}

.projects .project {
    overflow: hidden;
    border-radius: 5px;
    display: block;
    position: relative;
    height: 570px;
    width: calc(100% - 16px);
    margin: 8px
}

.projects .project-a{
    height: 100%;
    width: 100%;
    display: block
}

.projects .project:hover .image:not(.not-scale) {
    transform: scale(1.05)
}

.projects .project:hover .title {
    background-size: 100% 2px;
    color: #fff
}

.projects .project:hover .project-info {
    opacity: 1;
    transform: rotate(0deg)
}

.projects .project:hover .project-name {
    opacity: 1;
    transform: translateX(0)
}

.projects .project .image {
    position: absolute;
    transition: all ease .7s;
    background-position: left
}

.projects .project .image:after {
    content: "";
    pointer-events: none;
    background: linear-gradient(180deg, transparent 0, #000 100%);
    height: 50%;
    width: 100%;
    bottom: 0;
    left: 0;
    z-index: 2;
    display: block;
    position: absolute
}

.projects .project .project-content {
    position: absolute;
    z-index: 10;
    max-width: calc(100% - 80px);
    bottom: 30px;
    left: 30px
}

.projects .project .project-name,
.projects .project .project-title {
    color: #fff;
    text-decoration: none;
    z-index: 10
}

.projects .project .project-info span,
.projects .project .project-name span,
.projects .project .project-title span {
    line-height: 1.3
}

.projects .project .project-name {
    opacity: 0;
    transform: translateX(100%);
    transition: all ease .5s;
    position: absolute;
    max-width: calc(100% - 80px);
    bottom: 30px;
    left: 30px
}

.projects .project .project-info {
    display: none;
    position: relative;
    color: #fff;
    font-weight: 300;
    font-size: 18px;
    transition: all ease .5s;
    text-decoration: none;
    z-index: 10
}

.marquee,
.marquee-scroll {
    overflow: hidden;
    display: flex;
    user-select: none
}

.marquee .marquee-group,
.marquee-scroll .marquee-group {
    flex-shrink: 0;
    gap: 2px;
    min-width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-around
}

@media (prefers-reduced-motion:reduce) {
    .marquee-group {
        animation-play-state: paused
    }
}

.logos-holder {
    margin-top: -30px
}

.logos-holder .logo {
    margin-bottom: 15px;
    display: block;
    transition: all ease .3s
}

.logos-holder .logo:hover {
    background: #fff
}

.logos-holder .d-table-cell {
    height: 100px
}

.cw-100 {
    max-width: 900px;
    margin: 0 auto
}

.pages {
    margin-bottom: -30px
}

.pages .page-holder-xl .page .content-holder {
    min-height: 220px
}

.pages .page {
    display: block;
    margin-bottom: 30px;
    color: #2c3e50
}

.pages .page:hover .title {
    background-size: 100% 1px;
    color: #2c3e50
}

.pages .page:hover .image-holder img {
    transform: scale(1.2) rotate(5deg)
}

.pages .page:hover .content-holder:before {
    height: 0
}

.pages .page:hover .content-holder:after {
    height: 100%
}

.pages .page .page-title {
    font-size: 22px
}

.pages .page .content-holder {
    padding: 20px 30px;
    position: relative;
    min-height: 190px
}

.pages .page .content-holder:after,
.pages .page .content-holder:before {
    display: block;
    position: absolute;
    content: "";
    left: 0;
    transition: all ease .3s
}

.pages .page .content-holder:before {
    height: 100%;
    bottom: 0;
    width: 1px;
    background: #e1e1e1
}

.pages .page .content-holder:after {
    height: 0;
    top: 0;
    width: 3px;
    background: #00c4cc
}

.pages .page .image-holder {
    position: relative;
    border-radius: 0 0 5px 5px;
    overflow: hidden
}

.pages .page .image-holder img {
    transition: all ease .5s
}

.featured-boxes .featured-box {
    display: block;
    padding: 35px 20px;
    background: #fff;
    border-radius: 5px;
    box-shadow: 10px 10px 15px transparent;
    transition: all ease .3s
}

.featured-boxes .featured-box .image-holder img {
    max-height: 56px
}

.featured-boxes .featured-box:hover {
    box-shadow: 10px 10px 15px rgba(0, 0, 0, .04)
}

.featured-boxes .featured-box .title {
    line-height: 24px;
    font-size: 14px
}

.featured-boxes .featured-box .title span,
section.project-single h4 a {
    text-decoration: underline
}

.stats .col:first-child .stat {
    padding-left: 0
}

.stats .col:last-child .stat {
    border-right: none
}

.stats .stat {
    border-right: 1px solid #e1e1e1;
    padding-left: 5px
}

.stats .stat .number {
    font-weight: 500;
    font-size: 50px;
    line-height: 1
}

.stats .stat .info,
article h1 {
    font-weight: 400
}

.txt-rotate {
    position: relative;
    vertical-align: middle;
    min-width: 450px;
    line-height: 1;
    z-index: -1
}

.txt-rotate .wrap {
    line-height: 1;
    padding: 0 5px;
    min-width: 1px;
    color: #fff;
    border-radius: 0;
    display: inline-block;
    background: #00c4cc
}

.pause-video {
    position: absolute;
    right: 0;
    bottom: 0
}

.slider .cursor-wrapper {
    cursor: none
}

.slider .cursor {
    pointer-events: none;
    -webkit-transition: -webkit-transform .4s ease-in-out;
    transition: transform .4s ease-in-out;
    transition: transform .4s ease-in-out, -webkit-transform .4s ease-in-out;
    transform: scale(0);
    font-size: 24px;
    font-family: "Khand", sans-serif;
    font-weight: 400;
    padding: 1.25rem;
    position: fixed;
    width: 100px;
    height: 100px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border-radius: 50%;
    color: #fff;
    opacity: .65;
    background: #00c4cc;
    mix-blend-mode: multiply;
    user-select: none;
    z-index: 1
}

.slider .cursor.hidden {
    opacity: 0
}

.news-banner {
    height: 450px;
    width: 360px;
    position: relative
}

.news-banner .decor {
    z-index: 5;
    pointer-events: none;
    position: absolute;
    left: -150px;
    width: 300px;
    top: -200px;
    transition: all ease .5s
}

.news-banner,
.news-banner .image {
    overflow: hidden
}

.news-banner .image:after {
    content: "";
    height: 100%;
    width: 100%;
    position: absolute;
    left: 0;
    top: 0;
    pointer-events: none;
    background: rgba(0, 0, 0, .2)
}

.news-banner .content-holder {
    z-index: 2;
    padding: 0 20px 50px;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto
}

.news-banner .content-holder .title {
    font-size: 26px
}

.news-banner .content-holder .title big {
    font-size: 60px;
    font-weight: 600
}

.bg-light .posts .post.post-featured .pattern {
    background-color: #fff
}

.preloader-post {
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    color: #b5b1b1;
    font-weight: 300;
    bottom: -60px
}

.posts .sticky-column,
.sticky-sidebar {
    top: 100px;
    position: -webkit-sticky;
    position: sticky;
    margin-bottom: 23px
}

.sticky-sidebar {
    top: 150px
}

.posts.slider.slider-1 .carousel-posts .slick-list {
    margin-left: 0
}

.posts .post:hover .title-gradient a,
.title-gradient a:hover {
    background-size: 100% 2px;
    color: #2c3e50
}

.posts .post:hover .image-holder a {
    opacity: .7
}

.posts .post .image-holder {
    min-width: 180px
}

.posts .post .image-holder a {
    transition: all ease .3s
}

.posts .post .content-holder {
    max-width: 400px
}

.posts .post.post-featured {
    display: block;
    width: 750px;
    margin: 0 auto;
    max-width: 100%;
    position: relative;
    height: 400px;
    overflow: hidden;
    text-align: left
}

.posts .post.post-featured.post-featured-xl {
    height: 470px;
    width: 880px;
    margin: 0
}

.posts .post.post-featured.post-featured-xl .image-holder {
    width: 350px
}

.posts .post.post-featured.post-featured-xl .content-holder {
    max-width: 650px
}

.posts .post.post-featured .image-holder {
    right: 0;
    top: 0;
    height: 100%;
    width: 300px;
    position: absolute
}

.posts .post.post-featured .content-holder {
    position: relative;
    z-index: 3;
    padding: 15px 60px;
    max-width: 550px
}

.posts .post.post-featured .pattern {
    position: absolute;
    top: 0;
    z-index: 2;
    width: 130%;
    background-image: radial-gradient(#f9f9fb 2%, transparent 3%), radial-gradient(#f9f9fb 2%, transparent 3%);
    background-size: 60px 60px;
    transition: all ease 1s;
    background-position: 0 0, 30px 30px;
    background-repeat: repeat;
    pointer-events: none;
    right: 28%;
    background-color: #f9f9fb;
    height: 100%;
    transform: skewX(20deg)
}

.title-gradient a,
.title-gradient-dark a,
.title-gradient-main a,
.title-gradient-md .title,
.title-gradient-white .title {
    position: relative;
    line-height: 1.2;
    z-index: 2;
    text-decoration: none;
    background-repeat: no-repeat;
    background-image: linear-gradient(to right, #2c3e50 0, #2c3e50 100%);
    background-size: 0 2px;
    background-position: 0 80%;
    transition: background-size .25s cubic-bezier(.785, .135, .15, .86) 0s;
    color: #2c3e50
}

.title-gradient-dark a,
.title-gradient-main a,
.title-gradient-md .title,
.title-gradient-white .title {
    background-size: 0 1px;
    background-position: 0 100%
}

.title-gradient-md .title:hover {
    background-size: 100% 1px;
    color: #2c3e50
}

.title-gradient-dark a,
.title-gradient-main a,
.title-gradient-white .title {
    background-image: linear-gradient(to right, #fff 0, #fff 100%);
    background-size: 0 2px;
    background-position: 0 80%;
    color: #fff
}

.title-gradient-white .title:hover {
    background-size: 100% 2px;
    color: #fff
}

.title-gradient-dark a,
.title-gradient-main a {
    background-image: linear-gradient(to right, #00c4cc 0, #00c4cc 100%);
    background-size: 100% 2px;
    color: #00c4cc
}

.title-gradient-main a:hover {
    background-size: 0 2px;
    color: #00c4cc
}

.title-gradient-dark a {
    background-image: linear-gradient(to right, #2c3e50 0, #2c3e50 100%);
    color: #2c3e50
}

.title-gradient-dark a:hover {
    background-size: 0 2px;
    color: #2c3e50
}

.tags .tag {
    font-size: 13px;
    color: #2c3e50
}

.tags .tag.tag-lg,
nav.social-share-links .social-share-icon a i {
    font-size: 15px
}

.breadcrumb li a:hover,
.content h4 strong,
.tags .tag.active,
.tags .tag:hover,
article .list-style-custom ul li a,
section.boxes-module .content ul li a:hover {
    color: #00c4cc
}

.categories,
.custom-table .custom-table-head .price-cell h3,
.custom-table .custom-table-head .price-cell h4 {
    line-height: 1
}

.categories .category {
    display: inline-block;
    font-size: 12px;
    font-weight: 500
}

.categories .category.active {
    background-color: #f1f1f1;
    color: #002947;
    padding: 1px 12px 0
}

.categories .category.category-lg {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 10px
}

.categories .category.category-xl {
    font-weight: 400;
    font-family: "Khand", sans-serif;
    font-size: 26px;
    margin-bottom: 10px;
    color: #2c3e50
}

.categories .category.category-xxl {
    font-weight: 400;
    font-family: "Khand", sans-serif;
    font-size: 32px;
    color: #2c3e50
}

.categories .category:hover {
    text-decoration: underline;
    color: #2c3e50
}

.button-simple {
    font-size: 15px;
    display: inline-block;
    padding: 5px 10px;
    border-radius: 5px;
    background: #ffe52a;
    margin-bottom: 5px;
    color: #000
}

.button-simple:hover {
    background: #000;
    color: #ffe52a
}

.useful-pages {
    border-top: 1px solid #e1e1e1;
    border-bottom: 1px solid #e1e1e1
}

.useful-pages .useful-page {
    color: #2c3e50;
    text-decoration: underline;
    position: relative;
    line-height: 1.2
}

.useful-pages .useful-page .title {
    font-size: 18px
}

.useful-pages .useful-page .info {
    font-size: 14px
}

.useful-pages .useful-page:not(:last-child):after {
    content: "";
    height: 100%;
    width: 1px;
    position: absolute;
    top: 0;
    right: -15%;
    background: #e1e1e1
}

.breadcrumb {
    position: relative;
    margin-bottom: 0;
    padding: 20px 0
}

.breadcrumb li {
    font-size: 14px;
    color: #00c4cc
}

.breadcrumb li a {
    font-size: 14px;
    color: #2c3e50;
    text-decoration: underline
}

:root {
    --duration: 0.5s;
    --easing: linear
}

section.sticky-image svg:not(:root) {
    overflow-clip-margin: content-box;
    overflow: hidden
}

section.sticky-image .content-column .box {
    height: 540px;
    margin-bottom: 100px
}

section.sticky-image .content-column .box:last-child {
    margin-bottom: 0
}

section.sticky-image .content-column .content-holder {
    max-width: 750px
}

section.sticky-image .sticky-column {
    top: 200px;
    margin-bottom: 50px;
    position: -webkit-sticky;
    position: sticky;
    height: 540px;
    overflow: hidden
}

section.sticky-image .sticky-column .box {
    height: 540px
}

section.sticky-image .sticky-column .box.is-active .image-holder {
    opacity: 1;
    z-index: 2;
    -webkit-mask-size: 1200px 1200px;
    mask-size: 1200px 1200px;
    transition-delay: 0s
}

section.sticky-image .sticky-column .box.is-active .image-holder img {
    transform: scale(1);
    transition-delay: 0s
}

section.sticky-image .sticky-column .box .image-holder {
    background-color: #fff;
    z-index: 0;
    top: 0;
    height: 100%;
    position: absolute;
    overflow: hidden;
    border-radius: 10px;
    -webkit-mask-image: radial-gradient(#000 70%, #000 70.1%);
    mask-image: radial-gradient(#000 70%, #000 70.1%);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: 0 0;
    mask-size: 0 0;
    transition: mask-size var(--duration) var(--easing);
    transition: mask-size var(--duration) var(--easing), -webkit-mask-size var(--duration) var(--easing);
    transition-delay: .25s
}

.tiles-collapse {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: nowrap;
    width: 100%;
    height: 316px;
    margin: 4px auto;
    padding: 0;
    gap: 4px
}

.tiles-collapse .tile-holder {
    position: relative;
    padding: 15px;
    min-height: 100%;
    overflow: hidden;
    flex-grow: 1;
    gap: 4px;
    border-radius: 5px;
    transition: .65s cubic-bezier(.4, 0, .2, 1)
}

.tiles-collapse .tile-holder:hover {
    flex-grow: 3.255
}

.tiles-collapse .tile-holder:hover a {
    background: #132055
}

.tiles-collapse .tile-holder:hover .tile-tab {
    width: 300px
}

.tiles-collapse .tile-holder:hover .tile-tab .image-holder svg {
    transition: none
}

.tiles-collapse .tile-holder:hover .tile-tab .image-holder svg * {
    transition: none;
    fill: #fff
}

.tiles-collapse .tile-holder:hover .tile-tab .title {
    color: #fff
}

.tiles-collapse .tile-holder:hover .tile-collapse {
    width: calc(100% - 300px);
    opacity: 1
}

.tiles-collapse .tile-holder:hover .tile-collapse .content {
    opacity: 1;
    transform: translateX(0)
}

.tiles-collapse .tile-holder a {
    color: #2c3e50;
    background: #f9f9fb;
    transition: all ease .3s;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    align-items: center;
    width: 100%;
    height: 100%
}

.tiles-collapse .tile-holder .tile-tab {
    width: 100%;
    transition: all ease .5s
}

.tiles-collapse .tile-holder .tile-collapse {
    width: 0;
    opacity: 0;
    overflow: hidden;
    transition: all ease .8s
}

.tiles-collapse .tile-holder .tile-collapse .content {
    width: 630px;
    opacity: 0;
    transform: translateX(150px);
    transition: all ease .65s;
    padding: 0 40px 0 0;
    color: #fff
}

.tiles-collapse .tile-holder .tile-collapse .content *,
section.project-tags-module .project-tags .project-tag:hover .title {
    color: #fff
}

section.project-tags-module {
    padding: 60px 0
}

section.project-tags-module .project-tags .project-tag {
    min-width: 140px;
    text-align: center;
    display: inline-block;
    padding: 20px 35px;
    border-radius: 50px;
    background: #fff;
    margin: 25px auto;
    transition: all ease .3s
}

section.project-tags-module .project-tags .project-tag:hover {
    background: #00c4cc;
    color: #fff;
    transform: scale(1.3)
}

section.project-tags-module .project-tags .project-tag .title {
    transition: all ease .2s;
    font-weight: 400;
    font-size: 17px
}

section.content-image-module {
    padding: 100px 0
}

section.content-image-module .content-holder {
    max-width: 750px
}

.content figure img {
    height: auto;
    max-width: 100%
}

section.content-module .text-center .content,
section.content-module .text-center .title {
    margin-left: auto;
    margin-right: auto
}

section.boxes-module.boxes-module-large .content-holder {
    max-width: 650px;
    padding: 0 30px;
    margin: 0 auto
}

section.boxes-module .content ul li a {
    color: #2c3e50;
    text-decoration: underline
}

section.article-module {
    position: relative;
    z-index: 50
}

section.article-module article.content-holder {
    position: relative;
    background: #fff
}

section.article-module .content figure {
    margin-bottom: 20px
}

.adminbar-on .progress {
    top: 49px
}

.progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background: rgba(255, 255, 255, .75);
    z-index: 99
}

.progress .bar {
    height: 100%;
    width: 0%;
    background: #00c4cc;
    transition: background .15s ease
}

article .h2,
article .h3,
article h2,
article h3 {
    font-weight: 400;
    font-size: 40px;
    margin-top: 30px
}

article .h3,
article h3 {
    font-size: 35px
}

article .h4,
article h4 {
    margin-top: 26px;
    color: #00c4cc;
    font-weight: 400;
    font-size: 26px
}

nav.social-share-links {
    position: relative;
    margin: 0 0 0-15px
}

nav.social-share-links .social-rollover {
    position: absolute;
    pointer-events: none
}

nav.social-share-links .social-share-icon {
    position: relative;
    top: -20px;
    left: 0;
    transform: translate(0, 0);
    -webkit-filter: none;
    filter: url(#goo);
    height: 60px;
    padding: 10px
}

nav.social-share-links .social-share-icon a {
    text-decoration: none;
    color: #fff;
    height: 45px;
    width: 45px;
    border-radius: 100px;
    display: inline-block;
    background-color: #00c4cc;
    line-height: 44px;
    text-align: center
}

nav.social-share-links .social-share-icon a.a {
    z-index: 123
}

nav.social-share-links .social-share-icon a:hover {
    background-color: #132055;
    color: #fff
}

nav.social-share-links .social-share-icon a.a1 {
    transform: translateX(-245px);
    transition: all ease-in-out 200ms;
    opacity: 0
}

nav.social-share-links .social-share-icon a.a2 {
    transform: translateX(-196px);
    transition: all ease-in-out 300ms;
    opacity: 0
}

nav.social-share-links .social-share-icon:hover a.a1 {
    transform: translateX(0);
    transition: all ease-in-out 600ms;
    opacity: 1
}

nav.social-share-links .social-share-icon:hover a.a2 {
    transform: translateX(0);
    transition: all ease-in-out 500ms;
    opacity: 1
}

nav.menu-anchors {
    margin-left: -20px;
    margin-right: -20px
}

.custom-table,
nav.menu-anchors,
nav.menu-anchors>.nav.nav-pills {
    position: relative
}

nav.menu-anchors>.nav.nav-pills>.nav-item {
    position: relative;
    padding-left: 40px;
    padding-bottom: 10px;
    margin-bottom: 0
}

nav.menu-anchors>.nav.nav-pills>.nav-item>.nav-link {
    padding-left: 0
}

nav.menu-anchors>.nav.nav-pills>.nav-item>.nav-link.active~.nav {
    display: block;
    opacity: 1
}

nav.menu-anchors>.nav.nav-pills>.nav-item>.nav-link.active:before {
    height: 22px;
    width: 22px;
    top: 3px;
    left: -4px;
    border: 6px solid #00c4cc
}

nav.menu-anchors>.nav.nav-pills>.nav-item>.nav-link:before {
    z-index: 3;
    content: "";
    height: 18px;
    width: 18px;
    border: 3px solid #e1e1e1;
    background-color: #fff;
    border-radius: 50%;
    display: block;
    position: absolute;
    top: 4px;
    left: -2px
}

nav.menu-anchors>.nav.nav-pills>.nav-item>.nav-link:after {
    position: absolute;
    display: block;
    top: -50px;
    left: 6px;
    content: "";
    height: calc(100% + 50px);
    width: 11px;
    border-left: 1px solid #e1e1e1
}

nav.menu-anchors .nav.nav-pills {
    margin-top: 0;
    display: block
}

nav.menu-anchors .nav .nav-item {
    margin-bottom: 4px;
    margin-top: 0;
    padding-left: 0
}

nav.menu-anchors .nav .nav-item .nav {
    display: none;
    margin-bottom: 0;
    padding-left: 20px;
    list-style-type: none;
    transition: all ease 1s;
    opacity: 0
}

nav.menu-anchors .nav .nav-item .nav .nav-link {
    font-family: "Roboto", sans-serif;
    display: block;
    padding: 5px 0;
    border: 0;
    color: #999;
    font-size: 16px;
    line-height: 1.4;
    text-decoration: none
}

nav.menu-anchors .nav .nav-item:hover {
    background: 0 0
}

nav.menu-anchors .nav .nav-item:hover>.nav-link {
    color: #00c4cc;
    background: 0 0
}

nav.menu-anchors .nav .nav-item:focus,
nav.menu-anchors .nav .nav-item:focus>.nav-link {
    background: 0 0
}

nav.menu-anchors .nav .nav-item>.active.nav-link,
section.project-single h2 {
    color: #00c4cc
}

nav.menu-anchors .nav .nav-item>.active.nav-link:focus,
nav.menu-anchors .nav .nav-item>.active.nav-link:hover {
    background: 0 0;
    color: #00c4cc
}

nav.menu-anchors .nav .nav-item>.active.nav-link~.nav {
    display: block;
    opacity: 1
}

nav.menu-anchors .nav .nav-item>.nav-link:hover {
    border-left-color: #00c4cc;
    color: #00c4cc;
    background: 0 0
}

nav.menu-anchors .nav .nav-item>.nav-link:focus {
    background: 0 0
}

nav.menu-anchors .nav .nav-item .nav {
    padding-top: 10px;
    max-height: 500px;
    overflow: auto
}

nav.menu-anchors .nav .nav-item .nav::-webkit-scrollbar {
    width: 5px
}

nav.menu-anchors .nav .nav-item .nav::-webkit-scrollbar-track {
    background: #ddd;
    box-shadow: inset 0 0 0 1px #f3f7ff;
    border-radius: 10px
}

nav.menu-anchors .nav .nav-item .nav::-webkit-scrollbar-thumb {
    background: #00c4cc;
    border-radius: 10px
}

nav.menu-anchors .nav .nav-item .nav::-webkit-scrollbar-thumb:hover {
    background: #00c4cc
}

nav.menu-anchors .nav .nav-item .nav-link {
    display: block;
    margin-bottom: 0;
    padding: 3px 0 3px 20px;
    border: 0;
    color: #2c3e50;
    font-size: 20px;
    font-weight: 400;
    line-height: 1.2;
    text-decoration: none
}

nav.menu-anchors .nav .nav-item .nav-link:focus,
nav.menu-anchors .nav .nav-item .nav-link:hover {
    color: #00c4cc;
    background: 0 0
}

.planner .planner-section {
    margin-top: 80px
}

.planner .form-planner {
    max-width: 620px
}

.planner #slider-impact,
.planner #slider-productivity {
    top: 20px
}

.planner .slider-cont {
    height: 55px
}

.planner #downtime-summary {
    display: none
}

.planner .table {
    max-width: 700px;
    margin: 0 auto
}

.planner .downtime-summary {
    margin-top: 50px;
    margin-right: -200px;
    border-radius: 4px 0 0 4px;
    background: #00c4cc;
    color: #fff;
    padding: 20px 40px 50px
}

.planner .downtime-summary.load .table-holder {
    opacity: 1
}

.planner .downtime-summary .table-holder {
    opacity: 0;
    transition: all ease 1s;
    transition-delay: .8s
}

.planner .downtime-summary .slider-loader {
    top: 40%
}

.planner .downtime-summary .button-holder {
    position: absolute;
    left: 0;
    right: 0;
    bottom: -65px
}

.planner .downtime-summary .button-holder .button-custom {
    line-height: 1.2;
    font-size: 22px;
    padding-left: 5px;
    padding-right: 5px;
    text-transform: none
}

.planner .d-inline {
    display: inline
}

.planner .downtime-icon {
    left: -326px;
    bottom: -10px;
    position: absolute
}

.planner .button-custom-calculate {
    cursor: pointer
}

section.plans-module .holder {
    background: #f9f9fb;
    padding: 65px;
    border-radius: 5px
}

.custom-table .custom-table-head .custom-table-row {
    border-bottom: 1px solid #bed0d2
}

.custom-table .custom-table-head .custom-table-row .custom-table-col {
    border-right: 1px solid #bed0d2
}

.custom-table .custom-table-body .custom-table-row .custom-table-col:last-child,
.custom-table .custom-table-head .custom-table-row .custom-table-col:last-child {
    border-right: none
}

.custom-table .custom-table-head .custom-table-row .custom-table-cell {
    padding: 15px
}

.custom-table .custom-table-footer {
    margin-top: 50px
}

.custom-table .custom-table-footer .button-custom {
    margin-bottom: -43px
}

.custom-table .custom-table-body .custom-table-row {
    border-bottom: 1px solid #bed0d2;
    transition: all ease .5s;
    background: 0 0;
    position: relative
}

.custom-table .custom-table-body .custom-table-row:last-child {
    border-bottom: none;
    z-index: 2
}

.custom-table .custom-table-body .custom-table-row:hover {
    background: -moz-linear-gradient(left, rgba(255, 255, 255, 0)0, rgba(255, 255, 255, 0) 1%, rgba(255, 255, 255, .3) 6%, rgba(255, 255, 255, .7) 51%, rgba(255, 255, 255, .3) 93%, rgba(255, 255, 255, 0) 100%);
    background: -webkit-linear-gradient(left, rgba(255, 255, 255, 0)0, rgba(255, 255, 255, 0) 1%, rgba(255, 255, 255, .3) 6%, rgba(255, 255, 255, .7) 51%, rgba(255, 255, 255, .3) 93%, rgba(255, 255, 255, 0) 100%);
    background: linear-gradient(to right, rgba(255, 255, 255, 0)0, rgba(255, 255, 255, 0) 1%, rgba(255, 255, 255, .3) 6%, rgba(255, 255, 255, .7) 51%, rgba(255, 255, 255, .3) 93%, rgba(255, 255, 255, 0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#00ffffff", endColorstr="#00ffffff", GradientType=1)
}

.custom-table .custom-table-body .custom-table-row:hover .status svg circle {
    fill: #f5f7f9
}

.custom-table .custom-table-body .custom-table-row .custom-table-col {
    border-right: 1px solid #bed0d2
}

.custom-table .custom-table-body .custom-table-row .custom-table-cell {
    padding: 15px 20px 15px 15px
}

.preview-projects {
    max-width: 460px
}

.preview-projects .row {
    margin-left: -.5rem !important;
    margin-right: -.5rem !important
}

.preview-projects .preview-project {
    overflow: hidden;
    position: relative
}

.preview-projects .preview-project:hover .project-title {
    opacity: 1
}

.preview-projects .preview-project figure:after {
    content: "";
    pointer-events: none;
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    margin: 0;
    background: rgba(0, 0, 0, .1)
}

.preview-projects .preview-project .project-title {
    opacity: 0;
    transition: all ease .5s;
    position: absolute;
    line-height: 1.3;
    font-size: 20px;
    max-width: calc(100% - 15px);
    bottom: 5px;
    left: 10px;
    color: #fff;
    font-weight: 300;
    text-decoration: none;
    z-index: 10
}

section.project-single {
    overflow: hidden
}

section.project-single .pre-title {
    font-size: 32px
}

section.project-single .content:not(.content-full-width) {
    max-width: 1100px
}

section.project-single .title {
    max-width: 1100px
}

section.project-single .summary {
    margin: 60px 0 0;
    padding: 80px 0;
    position: relative
}

section.project-single .summary .content-holder {
    position: relative;
    z-index: 2
}

section.project-single .summary .content {
    line-height: 1.4
}

section.project-single .summary .bg {
    position: absolute;
    width: calc(100% + 1000px);
    height: 100%;
    top: 0;
    left: -500px;
    right: 0;
    margin: 0 auto
}

.accordion .accordion-button {
    font-family: "Khand", sans-serif;
    font-size: 24px
}

.accordion-tiles .accordion-item {
    margin-bottom: 3px;
    border-radius: 6px;
    overflow: hidden;
    border: 0;
    background: #f9f9fb
}

.accordion-tiles .accordion-collapse.collapsing,
.accordion-tiles .accordion-collapse.show {
    background: #132055;
    color: #fff
}

.accordion-tiles .accordion-button:not(.collapsed) {
    box-shadow: none
}

.accordion-tiles .accordion-button {
    transition: none;
    border: 0;
    background-color: transparent
}

.accordion-tiles .accordion-button[aria-expanded=false],
.accordion-tiles .accordion-button[aria-expanded=false] .image-holder svg * {
    transition: all ease .5s;
    transition-delay: .28s
}

.accordion-tiles .accordion-button[aria-expanded=true] {
    transition: all ease 0s;
    background: #132055;
    color: #fff
}

.accordion-invert .accordion-button:after,
.accordion-tiles .accordion-button[aria-expanded=true]:after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e")
}

.accordion-tiles .accordion-button[aria-expanded=true] .image-holder svg * {
    fill: #fff
}

.accordion-tiles .accordion-button:focus {
    outline: 0;
    border-color: inherit;
    box-shadow: none
}

.accordion-tiles .image-holder {
    width: 50px;
    text-align: center
}

.accordion-invert .accordion-button,
.accordion-invert .accordion-item {
    background: #132055;
    color: #fff
}

.accordion-invert .accordion-button:focus {
    outline: 0;
    border-color: #132055;
    box-shadow: none
}

section.bubble-module {
    position: relative;
    min-height: 820px
}

section.bubble-module .image-holder {
    height: 540px;
    position: absolute;
    margin: 0 auto;
    top: 20px;
    left: 0;
    right: 0;
    text-align: center;
    background-position: center;
    background-repeat: no-repeat;
    -webkit-background-size: auto;
    background-size: auto;
    display: table;
    width: 100%
}

section.bubble-module .image-holder img {
    position: absolute;
    bottom: -25px;
    left: 0;
    right: 0;
    margin: 0 auto
}

section.bubble-module .bubble-holder {
    max-width: 1250px;
    position: relative;
    padding-top: 0;
    margin-top: 30px;
    margin-bottom: 50px
}

section.bubble-module .bubble-holder .title {
    text-align: center;
    margin-top: 100px
}

section.bubble-module .bubble-holder .boxes {
    margin-top: -100px
}

section.bubble-module .bubble-holder .boxes .box {
    width: 50%;
    display: block;
    position: relative;
    margin-bottom: 30px;
    min-height: 150px
}

section.bubble-module .bubble-holder .boxes .box:nth-child(odd) {
    text-align: left;
    float: left
}

section.bubble-module .bubble-holder .boxes .box:nth-child(odd) .dot {
    right: -52px;
    transform: rotate(-45deg)
}

section.bubble-module .bubble-holder .boxes .box:nth-child(even) {
    text-align: right;
    float: right
}

section.bubble-module .bubble-holder .boxes .box:nth-child(even) .dot {
    left: -52px;
    transform: rotate(45deg)
}

section.bubble-module .bubble-holder .boxes .box:nth-child(5) {
    text-align: center;
    float: none;
    width: 100%
}

section.bubble-module .bubble-holder .boxes .box:nth-child(5) .text {
    padding-top: 5px;
    top: 120px;
    border-top: 1px solid #fff;
    border-bottom: none
}

section.bubble-module .bubble-holder .boxes .box:nth-child(5) .text .dot {
    right: 0;
    width: 1px;
    height: 30px;
    top: -30px;
    left: 0;
    margin: 0 auto;
    transform: rotate(0deg)
}

section.bubble-module .bubble-holder .boxes .box:nth-child(5) .text .dot:after {
    bottom: 30px;
    left: -4px
}

section.bubble-module .bubble-holder .boxes .box .text {
    position: relative;
    padding-bottom: 10px;
    border-bottom: 1px solid #fff;
    line-height: 1.6;
    max-width: 344px;
    width: 100%;
    display: inline-block;
    color: #fff;
    font-weight: 300;
    font-family: "Roboto", sans-serif;
    font-size: 18px
}

section.bubble-module .bubble-holder .boxes .box .text .dot {
    top: calc(100% - 22px);
    position: absolute;
    height: 150px;
    border-left: 1px solid #fff
}

section.bubble-module .bubble-holder .boxes .box .text .dot:after {
    box-shadow: 0 0 50px 30px #24dad2;
    content: "";
    display: block;
    position: absolute;
    left: -5px;
    bottom: 0;
    height: 8px;
    width: 8px;
    border-radius: 50%;
    background-color: #fff
}

.approach-boxes .approach-box,
a.chat-button {
    position: relative;
    text-align: center
}

.approach-boxes .approach-box .box-title {
    font-size: 18px;
    font-family: "Roboto", sans-serif;
    font-weight: 500;
    position: relative;
    border-bottom: 1px solid #e1e1e1;
    padding-bottom: 20px
}

.approach-boxes .approach-box .box-title:before {
    content: "";
    height: 8px;
    width: 8px;
    display: inline-block;
    margin-right: 15px;
    border-radius: 50%
}

.approach-boxes .approach-box .box-content {
    height: 144px;
    width: 144px;
    font-weight: 400;
    border-radius: 50%;
    margin: 25px auto;
    font-size: 16px;
    color: #2c3e50;
    position: relative;
    z-index: 2
}

.approach-boxes .approach-box .box-circle {
    position: absolute;
    left: 0;
    right: 0;
    height: 79%;
    width: 1px;
    top: 100%;
    border-left: 1px solid #e1e1e1;
    margin: 0 auto
}

.approach-boxes .approach-box .box-circle:before {
    content: "";
    height: 22px;
    width: 22px;
    border-width: 7px;
    border-radius: 50%;
    background: #fff;
    position: absolute;
    border-style: solid;
    left: 0;
    right: 0;
    top: 30%;
    margin: 0 auto 0-11px
}

.approach-boxes .approach-box .box-circle:after {
    content: "";
    height: 18px;
    width: 18px;
    border-width: 5px;
    border-style: solid;
    border-color: #e1e1e1;
    border-radius: 50%;
    background: #fff;
    position: absolute;
    left: 0;
    right: 0;
    margin-left: -9px;
    bottom: 10%
}

.approach-boxes .approach-box.approach-box-blue .box-content,
.approach-boxes .approach-box.approach-box-blue .box-title:before {
    background: rgba(0, 185, 195, .5);
    border: 2px solid #00b9c3
}

.approach-boxes .approach-box.approach-box-blue .box-circle:before {
    border-color: #00c4cc
}

.approach-boxes .approach-box.approach-box-yellow .box-content,
.approach-boxes .approach-box.approach-box-yellow .box-title:before {
    background: rgba(247, 210, 90, .5);
    border: 2px solid #f7d25a
}

.approach-boxes .approach-box.approach-box-yellow .box-circle:before {
    border-color: #f7d25a
}

.code video {
    max-width: 100%;
    height: auto
}

aside.chat-container header {
    position: relative;
    box-shadow: none;
    left: inherit;
    right: inherit;
    height: auto;
    background: 0 0;
    z-index: 1
}

aside.chat-container .chat-header h6 {
    margin: 0;
    font-size: 16px;
    color: #000
}

.chat-loader,
aside.chat-container .chat-header .icon {
    width: 30px;
    display: block;
    position: absolute;
    top: 19px
}

aside.chat-container .chat-header .icon svg {
    width: 20px;
    height: 20px
}

aside.chat-container .chat-header .icon.icon-chat {
    left: 18px;
    top: 12px;
    width: 30px;
    height: 30px;
    font-size: 25px
}

aside.chat-container .chat-header .icon.icon-chat svg {
    width: 25px;
    height: 25px
}

aside.chat-container .chat-header .icon.icon-minimize {
    right: 60px
}

aside.chat-container .chat-header .icon.icon-close {
    right: 20px
}

aside.chat-container .chat-holder {
    font-size: 15px
}

aside.chat-container .chat-holder>div {
    max-height: 600px;
    height: 100%;
    overflow: auto
}

aside.chat-container .chat-body {
    background-color: #2c3e50;
    padding: 20px
}

aside.chat-container svg {
    max-width: 100%;
    max-height: 100%
}

aside.chat-container .chat-header {
    height: 60px;
    position: relative;
    text-align: center;
    background: #ffe52a;
    font-weight: 700;
    padding: 20px
}

.chat-loader {
    opacity: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    transform: rotate(45deg);
    box-sizing: border-box;
    z-index: 2;
    top: 0;
    right: 0;
    border: 3px dotted transparent;
    border-bottom-color: #000;
    display: inline-block;
    animation: rotation 1s linear infinite
}

a.chat-button.loading:hover .icon-main {
    opacity: 1 !important;
    visibility: visible
}

a.chat-button.loading .icon-rollover,
a.chat-button.loading:hover .icon-rollover {
    opacity: 0 !important;
    visibility: hidden !important
}

a.chat-button.loading .chat-loader {
    opacity: 1
}

a.chat-button {
    z-index: 999;
    height: 70px;
    width: 70px;
    display: block;
    border-radius: 50%;
    background: #ffe52a;
    position: fixed;
    padding: 11px;
    right: 20px;
    font-size: 30px;
    bottom: 30px;
    transition: all ease .5s;
    visibility: visible;
    box-shadow: 0 13px 13px rgba(255, 255, 255, .2);
    opacity: 1
}

a.chat-button:hover .icon-rollover {
    opacity: 1;
    pointer-events: all;
    visibility: visible
}

a.chat-button .icon-rollover,
a.chat-button:hover .icon-main {
    opacity: 0;
    pointer-events: none;
    visibility: hidden
}

a.chat-button .icon-rollover {
    transition: all ease .1s;
    right: 0;
    top: 0;
    position: absolute;
    font-size: 16px;
    color: #000;
    border-radius: 35px;
    background: #ffe52a;
    height: 70px;
    line-height: 50px;
    padding: 11px 25px;
    width: 310px
}

a.chat-button .icon-rollover svg {
    position: relative;
    top: 0;
    margin-right: 6px
}

a.chat-button svg {
    -webkit-animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-duration: 1s;
    animation-fill-mode: both;
    -webkit-animation-name: tada;
    animation-name: tada
}

a.chat-button.active,
aside.chat-container {
    right: -400px;
    opacity: 0;
    visibility: hidden
}

aside.chat-container {
    z-index: 1001;
    right: 0;
    position: fixed;
    width: 480px;
    max-width: 100%;
    bottom: -750px;
    border-radius: 10px;
    transition: all ease .5s;
    margin: .75em;
    overflow: hidden
}

aside.chat-container.active {
    bottom: 0;
    opacity: 1;
    visibility: visible
}

.chat-loader,
.modal .image {
    pointer-events: none
}

.modal .image:after {
    content: "";
    height: 100%;
    width: 100%;
    background: #000;
    opacity: .7;
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none
}

.modal .modal-body .form .form-control {
    background: 0 0
}

.modal .modal-body .form .form-control::placeholder {
    color: #fff
}

.modal .modal-body .form.form-contact {
    margin-top: 30px;
    margin-bottom: 15px !important;
    background: 0 0 !important;
    padding: 0 !important;
    border: 0 !important
}

.modal .modal-body .form.form-contact .form-control {
    height: 48px;
    font-size: 16px
}

.modal .modal-body .form.form-contact .button-custom {
    width: 100%
}

.modal .button-close {
    position: absolute;
    background: 0 0;
    color: #fff;
    border: 0;
    font-size: 24px;
    top: 5px;
    right: 5px
}

section.pages-module .pages .page-holder,
section.related-pages-module .boxes .box-holder {
    opacity: 0;
    transition: all ease .5s;
    transform: translateX(100px)
}

section.related-pages-module .boxes .box-holder:nth-child(2) {
    transition-delay: .05s
}

section.related-pages-module .boxes .box-holder:nth-child(3) {
    transition-delay: .1s
}

section.related-pages-module .boxes .box-holder:nth-child(4) {
    transition-delay: .15s
}

.tiles-collapse .tile .tile-holder:nth-child(2),
section.related-pages-module .boxes .box-holder:nth-child(5) {
    transition-delay: .2s
}

section.related-pages-module .boxes .box-holder:nth-child(6) {
    transition-delay: .25s
}

section.related-pages-module .boxes .box-holder.animate {
    opacity: 1;
    transform: translateX(0)
}

section.pages-module .pages .page-holder:nth-child(2) {
    transition-delay: .05s
}

section.pages-module .pages .page-holder:nth-child(3) {
    transition-delay: .1s
}

section.pages-module .pages .page-holder:nth-child(4) {
    transition-delay: .25s
}

.tiles-collapse .tile .tile-holder:nth-child(3),
section.pages-module .pages .page-holder:nth-child(5) {
    transition-delay: .3s
}

section.pages-module .pages .page-holder:nth-child(6) {
    transition-delay: .35s
}

.tiles-collapse .tile .tile-holder:nth-child(4),
section.pages-module .pages .page-holder:nth-child(7) {
    transition-delay: .4s
}

section.pages-module .pages .page-holder.animate {
    opacity: 1;
    transform: translateX(0)
}

.tiles-collapse .tile {
    transform: translateY(50px)
}

.tiles-collapse .tile .tile-holder:nth-child(5) {
    transition-delay: .5s
}

.tiles-collapse .tile .tile-holder:nth-child(6) {
    transition-delay: .6s
}

.tiles-collapse .tile .tile-holder:nth-child(7) {
    transition-delay: .7s
}

.tiles-collapse .tile.animate {
    transform: translateY(0)
}

.posts .sticky-column.animate .post.post-featured .pattern {
    right: 28%
}

.posts .sticky-column.animate .post.post-featured img.object-fit {
    opacity: 1;
    transform: scale(1)
}

.posts .sticky-column .post.post-featured .pattern {
    right: -10%
}

.posts .sticky-column .post.post-featured img.object-fit {
    opacity: 0;
    transition: all ease 1s;
    transform: scale(1.3)
}

.posts .sticky-posts .post-holder {
    opacity: 0;
    transition: all ease 1s;
    transform: translateX(30px)
}

.posts .sticky-posts .post-holder.animate {
    opacity: 1;
    transform: translateX(0)
}

.posts .list-posts .post-holder,
section.project-single .content,
section.project-single .image-holder,
section.project-single .pre-title,
section.project-single .tags,
section.project-single .title {
    opacity: 0;
    transition: all ease 1s;
    transform: translateY(30px)
}

.posts .list-posts .post-holder.animate,
section.project-single .content.visible,
section.project-single .image-holder.visible,
section.project-single .pre-title.visible,
section.project-single .tags.visible,
section.project-single .title.visible {
    opacity: 1;
    transform: translateY(0)
}

.projects .animate-ajax-project:nth-child(1),
.projects .animate-ajax-project:nth-child(2),
.projects .animate-ajax-project:nth-child(3) {
    opacity: 1
}

.projects .animate-ajax-project {
    opacity: 0;
    transition: all ease .5s
}

.projects .animate-ajax-project.animate,
.projects .animate-ajax-project.visible,
section.project-single .summary.visible .bg-main {
    opacity: 1
}

.animate-ajax,
section.project-single .summary .bg-main {
    opacity: 0;
    transition: all ease 1s
}

.animate-ajax {
    transform: translateY(50px)
}

.animate-ajax.animate {
    opacity: 1;
    transform: translateY(0)
}

nav.menu.footer-menu>ul {
    display: flex;
    justify-content: space-between
}

nav.menu.footer-menu>ul>li>a {
    font-family: "Khand", sans-serif;
    font-size: 20px;
    text-transform: uppercase;
    font-weight: 500;
    display: inline-block;
    margin-bottom: 15px;
    border: 0 !important;
    color: #00c4cc
}

nav.menu.footer-menu>ul>li>a:hover {
    color: #00c4cc;
    text-decoration: none
}

nav.menu.footer-menu>ul li {
    line-height: 1;
    margin-bottom: 15px
}

nav.menu.footer-menu>ul li.has-children ul li a:hover {
    color: #00c4cc;
    border-color: #00c4cc;
    text-decoration: none
}

nav.menu.footer-menu>ul a {
    display: inline;
    font-size: 15px;
    line-height: 1.2;
    font-weight: 300;
    color: #fff;
    text-decoration: none;
    transition: all ease .2s;
    border-bottom: 1px solid #fff
}

@media (min-width:1600px) {
    .description-xl {
        font-size: 30px;
        line-height: 1.4
    }

    .description-xxl {
        font-size: 42px
    }

    section.boxes-module.boxes-module-medium .box-right .content-holder {
        padding-left: calc((100vw - 1530px)/2);
        padding-right: 50px
    }

    section.boxes-module.boxes-module-medium .box-left .content-holder {
        padding-right: calc((100vw - 1530px)/2);
        padding-left: 100px
    }

    section.banner .slick-dots {
        bottom: -10px
    }

    .container {
        max-width: 1560px
    }

    header.main-header nav.menu {
        margin-right: -100px
    }

    .button-menu {
        display: none
    }

    section.bubble-module .wrapper {
        content: "";
        width: calc((100% - 1530px)/2);
        right: 0;
        top: 0;
        height: 100%;
        position: absolute;
        pointer-events: none;
        background: #f9f9fb;
        z-index: 5
    }

    .custom-table .ribbon {
        right: 15px
    }

    .scroll-top.active {
        transform: rotate(90deg) scale(1.3) translateX(0) translateY(10px)
    }
}

@media (min-width:1200px) and (max-width:1600px) {
    section.boxes-module.boxes-module-medium .box-right .content-holder {
        padding-left: calc((100vw - 1140px)/2);
        padding-right: 30px
    }

    section.boxes-module.boxes-module-medium .box-left .content-holder {
        padding-right: calc((100vw - 1140px)/2);
        padding-left: 50px
    }

    .useful-pages .useful-page .title {
        font-size: 16px
    }

    .button-menu {
        display: none
    }

    .custom-table .ribbon {
        top: -20px;
        right: 2px
    }

    header.main-header .partners-logo img {
        max-height: 55px
    }

    nav.menu.main-menu>ul>li>a {
        padding-bottom: 30px
    }

    nav.menu.main-menu>ul>li.active>a:before,
    nav.menu.main-menu>ul>li>a.active:before {
        bottom: 23px
    }

    .button-custom.button-xl {
        font-size: 17px;
        padding: 15px 25px;
        min-width: 135px
    }

    main.main-content {
        padding-top: 100px
    }

    .mt-5 {
        margin-top: 2rem !important
    }

    .mb-xl-5 {
        margin-bottom: 2rem !important
    }

    .posts.mt-4 {
        margin-top: 20px !important
    }
}

@media (max-width:1600px) {
    body {
        font-size: 15px
    }

    p {
        line-height: 1.6
    }

    .bg-py {
        padding: 60px 0
    }

    .h1 big,
    .h1.h1-xl,
    .h2.h2-xl,
    h1 big,
    h1.h1-xl,
    h2.h2-xl {
        font-size: 50px
    }

    .h1,
    h1 {
        font-size: 38px
    }

    .h2,
    h2 {
        font-size: 43px
    }

    .h3,
    .h4,
    h3,
    h4 {
        font-size: 24px
    }

    .planner .table thead tr th {
        font-size: 12px
    }

    .planner .downtime-summary .info,
    .planner .table tbody tr td,
    section.project-tags-module .project-tags .project-tag .title {
        font-size: 14px
    }

    .planner .downtime-summary .button-holder {
        bottom: -45px
    }

    .planner .downtime-summary .button-holder .button-custom {
        font-size: 16px
    }

    .description,
    .pre-title {
        font-size: 18px
    }

    blockquote {
        font-size: 17px
    }

    section.banner-infrastructure .form-infrastructure .form {
        padding: 50px 0;
        max-width: 520px
    }

    section.banner-infrastructure .form-infrastructure .form .form-field .form-control {
        font-size: 25px
    }

    section.banner-infrastructure .form-infrastructure .form .form-field label {
        margin-top: 7px;
        font-size: 25px
    }

    section.banner-infrastructure.animate .form-infrastructure {
        height: 25vh
    }

    nav.menu-anchors .nav .nav-item {
        margin-bottom: 0
    }

    nav.menu-anchors .nav .nav-item .nav .nav-link {
        font-size: 15px
    }

    .tiles-collapse .tile-holder .tile-collapse .content {
        width: 470px
    }

    .tiles-collapse .tile-holder:hover .tile-collapse {
        width: calc(100% - 200px)
    }

    .tiles-collapse .tile-holder:hover .tile-tab {
        width: 200px
    }

    .carousel-testimonials .slick-dots {
        bottom: inherit;
        top: -25px
    }

    html.adminbar-on main.main-content {
        padding-top: 149px
    }

    section.tabs-module .tab-content .content-holder h3.title {
        font-size: 30px
    }

    section.banner .decor-line.decor-line-end {
        width: 4px
    }

    .projects {
        overflow: hidden;
        width: 100%
    }

    .button-custom {
        min-width: 160px;
        font-size: 16px;
        padding: 18px 35px
    }

    section.banner.banner-slider .banner-holder,
    section.banner.banner-slider .d-table-cell {
        height: 500px
    }

    section.banner .back-image {
        max-width: 870px;
        background-position: center center
    }

    section.banner .front-image {
        width: 500px
    }

    section.banner.banner-slider .slick-arrow.slick-next,
    section.banner.banner-slider .slick-arrow.slick-prev {
        top: 50px
    }

    section.banner .slick-dots {
        padding-left: calc((100% - 1130px)/2)
    }

    section.banner.banner-slider .content-holder,
    section.content-image-module .content-holder,
    section.sticky-image .content-column .content-holder {
        max-width: 650px
    }

    section.project-tags-module .project-tags .project-tag {
        min-width: 70px;
        margin: 15px auto;
        padding: 15px 25px
    }

    .slider .cursor {
        width: 80px;
        height: 80px;
        font-size: 20px
    }

    .posts.mt-4 {
        margin-top: 15px !important
    }

    .rollover-boxes .box {
        height: 225px;
        margin-bottom: 20px
    }

    .rollover-boxes-inline .box {
        width: calc(100% - 20px);
        margin-right: 20px
    }

    .rollover-boxes .box .box-title {
        left: 20px;
        bottom: 10px
    }

    .rollover-boxes .box.box-lg {
        height: 470px
    }

    .rollover-boxes .box .image:before {
        bottom: -40px;
        transform: skew(0deg, 7deg)
    }

    .rollover-boxes .box .box-pre-title {
        font-size: 120px;
        line-height: 75px;
        top: 60px
    }

    .rollover-boxes .box .box-pre-title span {
        font-size: 50px;
        display: block
    }

    .nav-pills .nav-item {
        margin-bottom: 15px
    }

    .projects .project {
        height: 450px
    }

    .pages .page .page-title {
        font-size: 18px
    }

    .pages .page .content-holder {
        min-height: 170px
    }

    .stats .stat {
        padding-left: 0;
        padding-right: 5px
    }

    .stats .stat .info {
        font-size: 14px
    }

    .stats .stat .number {
        font-size: 45px
    }

    .preview {
        font-size: 17px
    }

    .news-banner {
        height: 400px;
        width: 100%
    }

    .news-banner .content-holder .title big {
        font-size: 50px;
        font-weight: 600
    }

    .useful-pages .useful-page:after {
        display: none
    }

    .nav-pills .nav-item .nav-link.active {
        font-size: 24px
    }

    .posts .post.post-featured {
        height: 350px;
        width: 700px
    }

    .categories .category.category-xl {
        font-size: 22px
    }

    .form .form-control {
        height: 50px;
        font-size: 16px
    }

    .form input[type=file].form-control {
        line-height: 38px
    }

    .form .button-search {
        padding: 13px
    }

    .form .button-search svg {
        height: 22px;
        width: 22px
    }

    section.tabs-module .tab-content .image-holder {
        margin-right: -65px
    }

    section.tabs-module:not(.tabs-module-compact) .tab-content .content-holder {
        min-height: 250px
    }

    section.tabs-module .tab-content .button-holder {
        margin-left: 80px;
        top: 20px
    }

    section.tabs-module .tab-navigation {
        top: 0
    }

    section.tabs-module .tab-content .button-holder .button-link {
        font-size: 20px
    }

    section.banner.banner-slider .slick-arrow svg {
        width: 12px;
        height: 20px
    }

    .carousel-testimonials.slick-dotted {
        margin-bottom: 0
    }

    .posts .post .image-holder {
        height: 160px;
        width: 160px;
        min-width: 160px
    }

    .planner .downtime-summary {
        margin-right: -150px;
        max-width: 550px
    }
}

@media (min-width:1600px) and (max-width:1800px) {
    header.main-header .button-custom.button-xl {
        font-size: 20px;
        padding: 25px 30px;
        min-width: 200px
    }

    header.main-header .partners-logo {
        margin-left: 30px !important
    }

    header.main-header .partners-logos {
        left: -80px;
        position: relative
    }

    .tiles-collapse .tile-holder .tile-collapse .content {
        width: 500px
    }
}

@media (min-width:1400px) and (max-width:1600px) {
    header.main-header {
        padding-top: 10px
    }

    header.main-header .logo {
        max-width: 150px
    }

    header.main-header .partners-logos {
        margin-left: -30px
    }

    header.main-header .partners-logo {
        margin-left: .5rem !important;
        margin-top: 15px
    }

    header.main-header .partners-logo img {
        max-height: 47px
    }

    header.main-header nav.menu {
        margin: 30px 0 0
    }

    header.main-header .button-holder {
        position: relative;
        right: inherit;
        margin-left: 30px;
        top: 0;
        margin-top: 15px
    }

    nav.menu.main-menu>ul>li.has-children.row-menu>ul:before {
        top: 80px;
        font-size: 26px
    }

    nav.menu.main-menu>ul>li.has-children.row-menu>ul {
        padding-top: 130px;
        padding-bottom: 80px
    }

    nav.menu.main-menu>ul>li.has-children>ul {
        padding-top: 80px;
        padding-bottom: 80px;
        padding-left: calc((100% - 1300px)/2);
        padding-right: calc((100% - 1300px)/2);
        height: 450px
    }

    nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>a {
        font-size: 26px
    }

    nav.menu.main-menu>ul>li.has-children>ul li a {
        font-size: 15px
    }

    nav.menu.main-menu {
        margin-right: -50px
    }

    nav.menu.main-menu>ul>li {
        padding: 0 15px
    }

    header.main-header .column-menu {
        width: 45%
    }

    header.main-header .column-partners {
        width: 38%
    }

    section.banner.banner-post .banner-holder,
    section.banner.banner-post .d-table-cell {
        height: 500px
    }

    section.banner.banner-page .banner-holder,
    section.banner.banner-page .d-table-cell {
        height: 400px
    }

    section.banner.banner-slider .slick-arrow.slick-prev {
        left: calc((100% - 1330px)/2)
    }

    section.banner.banner-slider .slick-arrow.slick-next {
        left: calc((100% - 1330px)/2 + 50px)
    }

    section.banner .slick-dots {
        padding-left: calc((100% - 1300px)/2)
    }

    section.banner .slick-dots li.slick-active {
        width: 100px
    }

    section.sticky-image .content-column .box,
    section.sticky-image .sticky-column .box {
        height: 465px
    }

    section.sticky-image .content-column .box:last-child {
        margin-bottom: 150px
    }

    .news-banner {
        height: 370px
    }

    .posts .post.post-featured.post-featured-xl .h2 {
        font-size: 35px
    }

    .posts .post.post-featured .h3 {
        font-size: 28px
    }

    .posts .post.post-featured .content-holder {
        max-width: 450px
    }

    .posts .post.post-featured.post-featured-xl {
        height: 370px
    }

    .posts .post.post-featured.post-featured-xl .content-holder {
        max-width: 540px;
        padding: 15px 40px
    }

    .posts .sticky-column {
        margin-bottom: 31px
    }

    section.content-image-module .content-holder {
        max-width: 550px
    }

    .carousel-featured-posts .slick-arrow {
        top: -45px
    }

    .projects .project .project-info {
        font-size: 16px
    }
}

@media (min-width:1200px) and (max-width:1400px) {

    .h2,
    h2 {
        font-size: 37px
    }

    .h1,
    h1 {
        font-size: 35px
    }

    .h1.h1-xl,
    h1.h1-xl {
        font-size: 36px
    }

    .h2.h2-md,
    h2.h2-md {
        font-size: 34px
    }

    .form.form-contact {
        max-width: 550px
    }

    .form-radio {
        font-size: 16px
    }

    header.main-header {
        position: absolute;
        padding: 15px 0 0
    }

    .sticky-sidebar {
        top: 30px
    }

    .post-right.ms-xl-5 {
        width: 30%;
        margin-left: 30px !important
    }

    .preview,
    nav.menu.main-menu>ul>li.has-children>ul li a {
        font-size: 15px
    }

    .carousel-featured-posts .slick-arrow {
        top: -50px
    }

    .carousel-featured-posts .slick-dots {
        top: -40px;
        width: 100%;
        text-align: right
    }

    .posts .post.post-featured .content-holder .title {
        font-size: 30px
    }

    .projects .project {
        height: 420px
    }

    section.article-module article.content-holder {
        padding: 0
    }

    section.banner.banner-post .banner-holder,
    section.banner.banner-post .d-table-cell {
        height: 450px
    }

    section.content-image-module .content-holder {
        max-width: 530px
    }

    .rollover-boxes.rollover-boxes-inline .box {
        width: 270px;
        margin-right: 15px
    }

    .posts .post.post-featured .content {
        max-width: 400px
    }

    .posts .post.post-featured .content-holder .h2 {
        font-size: 28px
    }

    .posts .post.post-featured.post-featured-xl {
        height: 350px;
        width: 880px;
        padding-left: 0;
        margin: 0
    }

    section.banner .content-holder {
        max-width: 500px
    }

    .txt-rotate .wrap {
        border-width: 2px
    }

    section.stats-module .offset-xl-1 {
        margin-left: 2.33333333%;
        width: 47.66666667%
    }

    .stats .stat .info {
        font-size: 14px;
        line-height: 1.2
    }

    .featured-boxes .featured-box {
        padding: 15px
    }

    .news-banner {
        height: 370px;
        width: 100%
    }

    section.services-tabs-module .boxes {
        margin-right: -30px;
        margin-left: -30px
    }

    section.banner .front-image {
        width: 500px
    }

    section.banner.banner-slider .content-holder,
    section.sticky-image .content-column .content-holder {
        max-width: 550px
    }

    header.main-header .partners-logo {
        margin-top: 10px
    }

    header.main-header .logo {
        margin: 10px 0
    }

    header.main-header nav.menu {
        margin: 15px 0 0;
        padding: 0
    }

    nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>a {
        font-size: 26px
    }

    nav.menu.main-menu>ul>li.has-children>ul {
        padding-top: 80px;
        padding-bottom: 80px;
        padding-left: calc((100% - 1130px)/2);
        padding-right: calc((100% - 1130px)/2);
        height: 500px
    }

    nav.menu.main-menu>ul>li>a.active:before {
        bottom: 51px
    }

    nav.menu.main-menu>ul>li>a {
        padding: 18px 0
    }

    html.adminbar-on main.main-content {
        padding-top: 204px
    }

    nav.menu.main-menu>ul>li {
        padding: 0 50px 0 0
    }

    main.main-content {
        padding-top: 155px
    }

    section.sticky-image .content-column .box:last-child {
        margin-bottom: 200px
    }

    .rollover-boxes .box.box-lg,
    section.sticky-image .content-column .box,
    section.sticky-image .sticky-column .box {
        height: 400px
    }

    header.main-header nav.menu:before {
        content: "";
        z-index: -1;
        height: 54px;
        width: 2000px;
        max-width: 100%;
        pointer-events: none;
        position: absolute;
        left: 0;
        right: 0;
        border-top: 1px solid #eeeef1;
        border-bottom: 1px solid #eeeef1
    }

    header.main-header .button-holder {
        top: 10px;
        right: inherit;
        margin-left: 50px;
        position: relative
    }

    header.main-header .column-logo {
        width: 40%;
        order: 1
    }

    header.main-header .column-partners {
        width: 60%;
        order: 2
    }

    header.main-header .column-partners .d-flex {
        width: 100%
    }

    header.main-header .column-menu {
        width: 100%;
        order: 3
    }

    .rollover-boxes .box {
        height: 188px
    }

    .useful-pages .useful-page {
        font-size: 14px
    }

    .useful-pages .useful-page .image-holder {
        width: 35px
    }

    .logos-holder .logo {
        margin-bottom: 0
    }

    .mb-xl-5 {
        margin-bottom: 1rem !important
    }

    .posts.mt-4 {
        margin-top: 0 !important
    }

    section.banner.banner-page .banner-holder,
    section.banner.banner-page .d-table-cell {
        height: 400px
    }

    section.banner.banner-slider .banner-holder,
    section.banner.banner-slider .d-table-cell {
        height: 450px
    }

    section.banner.banner-slider .slick-arrow.slick-prev {
        left: calc((100% - 1150px)/2)
    }

    section.banner.banner-slider .slick-arrow.slick-next {
        left: calc((100% - 1150px)/2 + 40px)
    }

    section.banner .slick-dots li.slick-active {
        width: 100px
    }

    section.banner .slick-dots li {
        width: 40px
    }

    .projects .project .project-info {
        font-size: 14px
    }
}

@media (min-width:1200px) {
    section.tabs-module:not(.tabs-module-compact) .tab-content .content-holder {
        min-height: 390px
    }

    .form .form-control {
        padding-left: 15px
    }

    section.we-are-module .content-columns {
        margin-right: -80px
    }

    .project-holder {
        flex: 0 0 auto;
        width: 20%
    }

    .animate-ajax-project:nth-of-type(n+1) {
        width: 30%
    }

    .animate-ajax-project:nth-of-type(2n+1) {
        width: 50%
    }

    .animate-ajax-project:nth-of-type(2n+1) .project-info {
        display: block
    }

    .animate-ajax-project:nth-of-type(3n+1) {
        width: 20%
    }

    .animate-ajax-project:nth-of-type(3n+1) .project-info {
        display: none
    }
}

@media (max-width:1200px) {
    body {
        font-size: 16px
    }

    .h1,
    h1 {
        line-height: 1.4
    }

    .h1.h1-xl,
    h1.h1-xl {
        font-size: 42px;
        line-height: 1.4
    }

    .h1,
    .h1 big,
    .h2,
    .h2.h2-xl,
    .post.post-featured-xl .title,
    h1,
    h1 big,
    h2,
    h2.h2-xl {
        font-size: 38px
    }

    .h2.h2-md,
    h2.h2-md {
        line-height: 1.2
    }

    .h3,
    h3 {
        font-size: 26px
    }

    .h4,
    h4 {
        font-size: 22px
    }

    .title br,
    h1 br,
    h2 br {
        display: none
    }

    article .h2,
    article h2 {
        font-size: 34px
    }

    article .h3,
    article h3 {
        font-size: 30px
    }

    article .h4,
    article h4 {
        font-size: 22px
    }

    section.boxes-module.boxes-module-medium .box-right .content-holder {
        padding-left: calc((100vw - 930px)/2)
    }

    section.boxes-module.boxes-module-medium .box-left .content-holder {
        padding-right: calc((100vw - 930px)/2);
        padding-left: 30px
    }

    header.main-header {
        position: absolute;
        padding: 0 0 10px
    }

    section.tabs-module:not(.tabs-module-compact) .tab-content .content-holder {
        min-height: auto
    }

    nav.menu.footer-menu>ul a,
    nav.menu.main-menu>ul>li.has-children>ul li a {
        font-size: 14px
    }

    .approach-boxes {
        min-height: 290px
    }

    .marquee-scroll {
        overflow: auto
    }

    section.bubble-module .bubble-holder .boxes .box {
        width: 35%
    }

    section.project-tags-module {
        padding: 0
    }

    section.project-tags-module .project-tags .project-tag {
        margin: 50px 10px
    }

    .icon-scroll {
        pointer-events: none
    }

    nav.menu-anchors {
        padding-left: 50px
    }

    nav.menu-anchors .nav .nav-item .nav {
        display: block;
        opacity: 1
    }

    .carousel-featured-posts .slick-arrow {
        top: -100px
    }

    .carousel-featured-posts .slick-dots {
        width: 100%;
        text-align: right;
        top: -86px
    }

    .posts .sticky-column {
        position: relative;
        top: 0;
        margin-bottom: 50px
    }

    .posts .post.post-featured.post-featured-xl,
    .tiles-collapse .tile-holder:hover .tile-collapse,
    .tiles-collapse .tile-holder:hover .tile-tab {
        width: 100%
    }

    .news-banner .content-holder .title br {
        display: block
    }

    .projects {
        padding: 0 15px
    }

    .tiles-collapse .tile-holder a {
        display: block;
        padding: 40px
    }

    .tiles-collapse .tile-holder .tile-collapse .content {
        width: 100%;
        text-align: center;
        padding: 0
    }

    .card .rollover-boxes.rollover-boxes-inline .box,
    nav.menu.main-menu ul li.has-children.on,
    section.banner .slick-dots li button {
        background: #fff
    }

    section.banner.banner-slider .video-holder {
        height: 418px;
        overflow: hidden
    }

    section.banner.banner-slider .video-holder video {
        position: relative;
        top: -50px
    }

    section.banner.banner-slider .banner-holder,
    section.banner.banner-slider .d-table-cell {
        height: auto;
        transition: none;
        opacity: 1
    }

    section.banner.banner-slider .slick-dotted.slick-slider {
        margin-bottom: 0
    }

    section.banner.banner-slider .banner-holder .container,
    section.banner.banner-slider .banner-holder .content-holder,
    section.banner.banner-slider .slide.slick-active .button-holder,
    section.banner.banner-slider .slide.slick-active .content-holder {
        opacity: 1;
        transform: translateY(0);
        transition-delay: 0s;
        transition: none
    }

    section.banner.banner-slider .content-holder {
        max-width: 100%;
        padding: 0
    }

    section.banner.banner-slider .d-table-cell {
        display: block;
        padding: 70px 0
    }

    section.banner.banner-page .banner-holder,
    section.banner.banner-page .banner-holder .container,
    section.banner.banner-page .d-table-cell {
        height: auto;
        transition: none;
        opacity: 1
    }

    section.banner.banner-page .content-holder {
        padding: 50px 0;
        opacity: 1;
        transition: none
    }

    section.banner.banner-slider .slick-arrow.slick-prev {
        top: 50px;
        left: calc((100% - 960px)/2)
    }

    section.banner.banner-slider .slick-arrow.slick-next {
        top: 50px;
        left: calc((100% - 960px)/2 + 50px)
    }

    section.sticky-image .content-column .content-holder {
        max-width: 100%
    }

    section.sticky-image .content-column .content-holder .holder {
        max-width: 600px
    }

    section.sticky-image .sticky-column {
        position: relative;
        top: 0;
        height: auto;
        overflow: visible;
        margin-bottom: 0
    }

    section.sticky-image .content-column .box,
    section.sticky-image .sticky-column .box {
        height: auto;
        margin-bottom: 80px
    }

    section.sticky-image .sticky-column .box .image-holder {
        position: relative;
        opacity: 1
    }

    .project-tags,
    body.menu-open {
        overflow: hidden
    }

    .preview {
        font-size: 18px
    }

    section.stats-module .testimonial {
        max-width: 750px
    }

    .news-banner {
        height: 370px;
        width: 100%
    }

    .useful-pages .useful-page {
        width: 50%;
        float: left
    }

    .projects .project {
        height: 480px
    }

    .button-custom.button-xl {
        font-size: 17px;
        padding: 15px 30px;
        min-width: 135px
    }

    main.main-content {
        padding-top: 100px;
        width: 100%;
        overflow: hidden;
        transition: opacity ease .5s;
        min-height: auto
    }

    body.menu-open {
        height: 100%;
        background: #000
    }

    body.menu-open main.main-content {
        opacity: .4;
        background: #fff
    }

    header.main-header .column-menu {
        order: 3
    }

    header.main-header .button-holder {
        position: relative;
        margin-left: 60px;
        margin-right: 40px;
        right: 20px;
        top: 26px
    }

    body.menu-open header.main-header nav.menu {
        opacity: 1;
        visibility: visible;
        transform: translateX(0);
        pointer-events: all
    }

    html.adminbar-on header.main-header nav.menu {
        top: 149px
    }

    header.main-header nav.menu {
        position: fixed;
        box-shadow: -50px 50px 50px rgba(255, 255, 255, .25);
        background-repeat: repeat;
        pointer-events: none;
        background-color: #fff;
        opacity: 0;
        visibility: hidden;
        transform: translateX(100%);
        transition: all ease .3s;
        margin: 0;
        width: 350px;
        max-width: 100%;
        right: 0;
        top: 100px;
        height: 100%;
        overflow: auto;
        padding-bottom: 150px;
        z-index: 999
    }

    nav.menu.main-menu>ul>li.has-children.row-menu.industries>ul:before,
    nav.menu.main-menu>ul>li.has-children:hover>a:after,
    nav.menu.main-menu>ul>li.has-children>a:after,
    nav.menu.main-menu>ul>li>a.active:before {
        content: none
    }

    nav.menu.main-menu>ul>li {
        display: block;
        margin: 0;
        position: relative
    }

    .tabs-content-circle,
    nav.menu.main-menu ul li {
        position: relative
    }

    nav.menu.main-menu>ul>li>a {
        padding: 20px 25px;
        display: block;
        border-bottom: 1px solid #e1e1e1
    }

    nav.menu.main-menu>ul>li.has-children>ul li {
        opacity: 1;
        display: block;
        margin-bottom: 0;
        transform: translateX(0)
    }

    nav.menu.main-menu>ul>li.has-children>ul li>a {
        padding: 8px 25px;
        display: block
    }

    nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>a {
        display: block;
        padding: 20px 25px;
        font-family: "Roboto", sans-serif;
        color: #2c3e50;
        border-bottom: 1px solid #ddd;
        text-transform: none;
        font-size: 16px
    }

    nav.menu.main-menu>ul>li.has-children.row-menu>ul {
        padding: 15px 0
    }

    nav.menu.main-menu>ul>li {
        padding: 0
    }

    nav.menu.main-menu>ul>li.has-children>ul {
        padding: 0;
        height: auto;
        visibility: visible;
        opacity: 1;
        position: relative;
        pointer-events: all;
        box-shadow: none
    }

    nav.menu.main-menu ul li.has-children {
        transition: none
    }

    nav.menu.main-menu>ul>li:first-child {
        border-top: 1px solid #ddd
    }

    nav.main-menu .has-children .arrow {
        cursor: pointer;
        border: 0;
        height: 60px;
        text-align: center;
        padding: 0;
        width: 56px;
        border-radius: 0;
        top: 0;
        right: 0;
        color: #2c3e50;
        border-left: 1px solid #ddd;
        background: 0 0;
        display: block;
        position: absolute;
        font-size: 20px;
        line-height: 56px
    }

    nav.menu.main-menu>ul>li.has-children.on:hover>a,
    nav.menu.main-menu>ul>li.has-children.on>a,
    nav.menu.main-menu>ul>li.has-children>ul li.has-children.on>a {
        color: #00c4cc
    }

    nav.menu.main-menu>ul>li.has-children:hover>a,
    nav.menu.main-menu>ul>li>a:hover {
        color: #2c3e50
    }

    nav.main-menu .has-children .arrow:after {
        content: "";
        font-family: "fontAwesome", sans-serif;
        display: inline-block
    }

    nav.main-menu .has-children .arrow:before {
        content: "";
        height: 100%;
        width: 1px;
        background: #fff;
        left: 0;
        position: absolute;
        top: 2px
    }

    nav.menu.main-menu>ul>li.has-children>ul li.submenu-title>ul {
        margin-top: 0;
        padding: 10px 0
    }

    nav.main-menu .has-children .has-children .has-children ul {
        margin-bottom: 0;
        margin-top: 0;
        padding: 10px 0
    }

    nav.main-menu .has-children .has-children .arrow:after {
        content: ""
    }

    nav.main-menu .has-children .has-children.on .arrow:after {
        content: ""
    }

    nav.main-menu .has-children.on>.arrow:after {
        content: "";
        font-family: "fontAwesome"
    }

    nav.menu.main-menu>ul>li.has-children.row-menu>ul>li {
        display: block;
        width: 100%;
        padding-right: 0;
        float: none;
        opacity: 1;
        transform: translateX(0);
        transition-delay: 0s
    }

    nav.main-menu .has-children ul {
        display: none;
        border-bottom: 1px solid #ddd
    }

    .rollover-boxes.rollover-boxes-inline .box {
        width: 300px;
        margin-right: 15px;
        float: left
    }

    .rollover-boxes .box.box-lg {
        height: 440px
    }

    .rollover-boxes .box {
        height: 210px
    }

    section.services-tabs-module .boxes {
        margin-right: -30px;
        margin-left: -15px
    }

    section.tabs-module .tab-content .image-holder {
        margin-right: -65px;
        margin-left: 20px
    }

    section.tabs-module .tab-content .button-holder.button-holder-image {
        left: 0
    }

    section.tabs-module .tab-content .content-holder {
        min-height: auto
    }

    section.tabs-module .tab-content .button-holder {
        margin-left: 20px;
        top: 10px
    }

    section.tabs-module.tabs-module-compact .card-body,
    section.tabs-module.tabs-module-full .card-body {
        padding: 1.5rem !important
    }

    section.tabs-module .tabs-content {
        padding-left: 0;
        margin-bottom: 0
    }

    section.tabs-module .tab-content .content-holder {
        background: 0 0
    }

    section.tabs-module.tabs-module-full .tab-content .content-holder {
        margin-top: 0
    }

    section.tabs-module.tabs-module-compact .tab-content .button-holder {
        margin-left: 20px;
        margin-bottom: 15px
    }

    section.tabs-module.tabs-module-circle .tab-content .content-holder,
    section.tabs-module.tabs-module-compact .tab-content .content-holder,
    section.tabs-module.tabs-module-full .tab-content .content-holder {
        padding-left: 20px
    }

    .tabs-content-circle .card,
    .tabs-content-compact .card,
    .tabs-content-full .card {
        background: #f9f9fb !important
    }

    .tabs-content-circle .card .card-title a {
        padding-left: 45px
    }

    .tabs-content-circle .card .card-title a:before {
        z-index: 3;
        content: "";
        height: 18px;
        width: 18px;
        border: 3px solid #e1e1e1;
        background-color: #fff;
        border-radius: 50%;
        transition: all ease .1s;
        display: block;
        position: absolute;
        top: 27px;
        left: 15px
    }

    .tabs-content-circle .card .card-title a[aria-expanded=true]:before {
        height: 22px;
        width: 22px;
        top: 25px;
        left: 13px;
        background: #fff;
        border: 6px solid #00c4cc
    }

    .tabs-content-circle:after {
        position: absolute;
        display: block;
        top: 27px;
        left: 23px;
        content: "";
        height: calc(100% - 58px);
        width: 11px;
        border-left: 1px solid #e1e1e1
    }

    .bg-light .card .card-title a,
    .card .rollover-boxes.rollover-boxes-inline .box .image:before,
    .card.card-white {
        background: #fff
    }

    .card,
    .card .card-title a {
        background: #f9f9fb;
        color: #2c3e50
    }

    .card {
        border: 0;
        margin-bottom: 3px;
        border-radius: 6px;
        overflow: hidden
    }

    .card .card-header {
        border: 0;
        padding: 0;
        background: 0 0
    }

    .card .card-title {
        font-size: 24px
    }

    .card .card-title a {
        display: block;
        position: relative;
        padding: 22px 35px 22px 25px
    }

    section.tabs-module.tabs-module-compact .tabs-content {
        padding-left: 0
    }

    .card .card-body {
        padding: 20px 20px 0;
        overflow: hidden
    }

    .card .card-title a[aria-expanded=true] {
        color: #00c4cc
    }

    .card .card-title a[aria-expanded=true] .arrow:before {
        transform: rotate(-45deg);
        background: #00c4cc
    }

    .card .card-title a[aria-expanded=true] .arrow:after {
        transform: rotate(45deg);
        background: #00c4cc
    }

    .card .card-title a .arrow {
        position: absolute;
        right: 20px;
        top: 30px;
        width: 20px;
        height: 20px
    }

    .card .card-title a .arrow:after,
    .card .card-title a .arrow:before {
        content: "";
        position: absolute;
        height: 11px;
        width: 1px;
        top: 3px;
        background: #2c3e50
    }

    .card .card-title a .arrow:after {
        transform: rotate(-45deg);
        left: 5px
    }

    .card .card-title a .arrow:before {
        transform: rotate(45deg);
        right: 6px
    }

    .news-module {
        width: 100%;
        overflow: hidden
    }

    .posts .post.post-featured .content-holder {
        max-width: 500px
    }

    .post.post-featured .title {
        font-size: 28px
    }

    .post .title {
        font-size: 24px
    }

    section.banner .slick-dots {
        padding-left: calc((100% - 950px)/2);
        bottom: inherit;
        top: -10px
    }

    .breadcrumb li,
    .breadcrumb li a {
        font-size: 12px
    }

    section.banner {
        background-image: radial-gradient(#e0e0e2 2%, transparent 3%), radial-gradient(#e0e0e2 2%, transparent 3%);
        background-size: 60px 60px;
        transition: all ease 1s;
        background-position: 0 0, 30px 30px
    }

    .planner .downtime-summary {
        margin-right: 0;
        max-width: 100%
    }

    .planner .form-planner {
        max-width: 100%
    }

    .bg-py,
    section.content-image-module {
        padding: 60px 0
    }

    section.remove-space {
        margin-top: -50px
    }

    section.add-space {
        margin-top: 50px
    }
}

@media (min-width:992px) and (max-width:1200px) {
    section.banner.banner-slider .video-holder video {
        position: relative;
        top: -50px
    }

    section.services-tabs-module .boxes {
        margin-right: -30px;
        margin-left: 0
    }

    .rollover-boxes.rollover-boxes-inline .box {
        width: 290px;
        margin-right: 15px;
        float: left
    }
}

@media (max-width:992px) {

    .h3,
    h3 {
        font-size: 24px
    }

    section.boxes-module.boxes-module-medium .box-left .content-holder,
    section.boxes-module.boxes-module-medium .box-right .content-holder {
        padding-left: calc((100vw - 690px)/2)
    }

    section.banner.banner-slider .video-holder {
        height: 314px;
        overflow: hidden
    }

    section.banner.banner-slider .video-holder video {
        position: relative;
        top: -50px;
        height: 440px
    }

    header.main-header,
    section.article-module article.content-holder {
        padding: 0
    }

    header.main-header nav.menu {
        top: 90px
    }

    section.bubble-module {
        margin: 50px 0
    }

    .flex-quote,
    section.bubble-module .description {
        font-size: 18px
    }

    section.bubble-module .bubble-holder .boxes {
        margin-top: 70px
    }

    section.bubble-module .bubble-holder .boxes .box {
        min-height: 115px
    }

    section.bubble-module .bubble-holder .boxes .box .text {
        line-height: 1.4;
        font-size: 15px
    }

    section.bubble-module .image-holder {
        height: 500px;
        top: 0;
        -webkit-background-size: contain;
        background-size: contain;
        width: 500px;
        display: block;
        margin: 0 auto
    }

    section.bubble-module .bubble-holder .title {
        margin-top: 0
    }

    section.tabs-module.tabs-module-full .tab-content .content-holder {
        padding: 40px 40px 30px
    }

    section.tabs-module .tab-content .content-holder {
        min-height: 250px
    }

    section.banner .slick-dots {
        padding-left: calc((100% - 700px)/2)
    }

    section.banner .slick-dots li button {
        background: #fff
    }

    section.services-tabs-module .boxes {
        margin-right: 0;
        margin-left: 0;
        margin-bottom: 0;
        overflow: hidden
    }

    .rollover-boxes .box .box-title {
        font-size: 20px
    }

    .rollover-boxes .box .image:before {
        bottom: -32px;
        height: 38%;
        transform: skew(0deg, 9deg)
    }

    .rollover-boxes.rollover-boxes-inline .box.box-lg {
        width: 260px;
        height: 320px
    }

    .rollover-boxes.rollover-boxes-inline .box:not(.box-lg) {
        width: 58%;
        margin-right: 0;
        height: auto;
        margin-bottom: 24px;
        padding: 18px 25px
    }

    .rollover-boxes.rollover-boxes-inline .box:not(.box-lg) .box-title {
        position: relative;
        margin-bottom: 0;
        left: 0;
        bottom: 0
    }

    .useful-pages .useful-page {
        width: 100%;
        float: none
    }

    .projects .project .project-content {
        max-width: calc(100% - 30px);
        bottom: 20px;
        left: 20px
    }

    .logos-holder .d-table-cell {
        height: 80px
    }

    section.banner.banner-slider .slick-arrow.slick-prev {
        top: 50px;
        left: calc((100% - 725px)/2)
    }

    section.banner.banner-slider .slick-arrow.slick-next {
        top: 50px;
        left: calc((100% - 725px)/2 + 50px)
    }

    header.main-header .button-holder {
        position: relative;
        margin-left: 50px;
        margin-right: 20px
    }

    header.main-header .partners-logo {
        max-width: 120px;
        margin-top: 27px
    }

    .button-custom.button-xl {
        font-size: 16px;
        min-width: 120px
    }

    section.sticky-image .content-column .content-holder .holder {
        max-width: 500px;
        padding: 0
    }

    .posts .post.post-featured .content {
        max-width: 400px
    }

    .posts .post.post-featured .content-holder .h2 {
        font-size: 28px
    }

    .posts .post.post-featured.post-featured-xl {
        height: 350px;
        width: 880px;
        padding-left: 0;
        margin: 0
    }

    section.plans-module .holder {
        padding: 20px;
        margin: 0-15px;
        width: calc(100% + 30px)
    }

    .custom-table .custom-table-body .custom-table-row .custom-table-cell {
        padding: 10px 0
    }

    .custom-table .custom-table-body .custom-table-row .custom-table-cell .button-custom {
        min-width: auto
    }

    .custom-table .custom-table-body .custom-table-row .custom-table-cell .status svg {
        display: block;
        margin: 0 auto 10px !important
    }

    section.banner-infrastructure.animate .pattern-line.line-01 {
        right: -14%
    }

    section.banner-infrastructure.animate .pattern-line.line-02 {
        right: -27%
    }
}

@media (max-width:767px) {

    .h1.h1-xl,
    h1.h1-xl {
        font-size: 35px;
        line-height: 1.2
    }

    .h1,
    h1 {
        font-size: 28px
    }

    .h1,
    .h2,
    h1,
    h2 {
        line-height: 1.2
    }

    .h2.h2-xl,
    h2.h2-xl {
        font-size: 32px
    }

    .h2,
    .h2.h2-md,
    article .h2,
    article h2,
    h2,
    h2.h2-md {
        font-size: 30px
    }

    .h3,
    h3 {
        font-size: 20px
    }

    section.boxes-module.boxes-module-medium .box-left .content-holder,
    section.boxes-module.boxes-module-medium .box-right .content-holder {
        padding-left: 1rem;
        padding-right: 1rem
    }

    .custom-table .custom-table-body .custom-table-row .custom-table-cell {
        font-size: 14px;
        line-height: 1.4
    }

    blockquote {
        font-size: 16px;
        padding-left: 15px
    }

    article .h3,
    article h3,
    section.banner h1 {
        font-size: 26px
    }

    article .h4,
    article h4 {
        font-size: 18px
    }

    nav.menu.footer-menu>ul {
        display: grid;
        grid-template-columns: 1fr;
        text-align: left
    }

    nav.menu.footer-menu>ul>li>a {
        margin-bottom: 8px
    }

    nav.menu.footer-menu>ul li {
        margin-bottom: 8px;
        font-size: 16px
    }

    nav.menu ul ul {
        margin-bottom: 0
    }

    .button-menu {
        top: 0
    }

    main.main-content {
        padding-top: 75px
    }

    header.main-header .logo {
        margin: 15px 0 10px
    }

    header.main-header {
        padding: 0
    }

    section.project-single .pre-title {
        font-size: 20px
    }

    .card .card-title a {
        padding-right: 45px
    }

    .preview {
        font-size: 15px
    }

    .button-custom {
        min-width: 150px;
        padding: 18px 30px
    }

    .button-custom.button-wide {
        min-width: 180px
    }

    nav.menu-anchors {
        margin-left: 0;
        margin-right: 0;
        padding-right: 0;
        padding-left: 10px
    }

    .posts .post.post-featured .pattern,
    section.banner.banner-slider h1 br,
    section.bubble-module .bubble-holder .boxes .box .text .dot {
        display: none
    }

    .posts .post.post-featured {
        width: 100%
    }

    .posts .post.post-featured.post-featured-xl {
        height: 350px;
        width: 100%;
        padding-left: 20px;
        margin: 0
    }

    .posts .post.post-featured .image-holder {
        left: 0;
        right: 0;
        height: 100%;
        background: #2c3e50;
        width: 100%;
        overflow: hidden;
        border-radius: 6px
    }

    .posts .post.post-featured.post-featured-xl .content-holder {
        width: 100%;
        padding-left: 0
    }

    .posts .post.post-featured.post-featured-xl .image-holder {
        width: 100%;
        height: 350px
    }

    .posts .post.post-featured .date {
        color: #fff
    }

    .posts .post.post-featured .image-holder:before {
        content: "";
        height: 100%;
        width: 100%;
        position: absolute;
        left: 0;
        right: 0;
        z-index: 2;
        background: rgba(0, 0, 0, .4)
    }

    .posts .post.post-featured .content-holder .title-gradient a {
        color: #fff;
        background-image: linear-gradient(to right, #fff 0, #fff 100%)
    }

    .posts .post.post-featured .content-holder {
        padding: 20px
    }

    .carousel-posts,
    .posts .post.post-featured {
        padding: 0 15px;
        height: 350px
    }

    .carousel-posts .slick-list {
        overflow: hidden
    }

    .carousel-posts .slick-dots {
        bottom: 12px;
        text-align: left;
        padding-left: 25px
    }

    .planner .table thead tr th {
        font-size: 8px
    }

    .planner .table tbody tr td {
        font-size: 10px;
        padding: 5px 0
    }

    .planner .downtime-summary {
        padding: 20px 10px
    }

    .planner .downtime-summary .info {
        font-size: 10px;
        color: #fff !important
    }

    .planner .downtime-summary .button-holder .button-custom {
        font-size: 12px
    }

    .planner .downtime-summary .button-holder {
        position: relative;
        left: 0;
        right: 0;
        bottom: 0;
        margin: 15px 0 0
    }

    .news-banner {
        height: 430px
    }

    .post .title {
        font-size: 22px
    }

    section.banner.banner-slider .video-holder {
        height: 170px;
        overflow: hidden
    }

    section.banner.banner-slider .video-holder video {
        position: relative;
        top: -95px;
        height: 350px
    }

    section.banner.banner-page .content-holder {
        padding: 50px 0 40px
    }

    section.services-tabs-module .boxes {
        margin-right: 0;
        margin-left: 0;
        margin-bottom: 0;
        overflow: hidden
    }

    .rollover-boxes .box {
        height: auto;
        padding: 20px 25px;
        margin-bottom: 10px
    }

    .rollover-boxes .box.box-lg .box-title {
        padding-left: 25px
    }

    .rollover-boxes.rollover-boxes-inline .box {
        padding: 0
    }

    .rollover-boxes.rollover-boxes-inline .box .box-title {
        bottom: 70px
    }

    .rollover-boxes .box .box-title {
        font-size: 22px;
        position: relative;
        left: 0;
        bottom: 0;
        margin-bottom: 0
    }

    .rollover-boxes .box .image:before {
        bottom: -32px;
        height: 38%;
        transform: skew(0deg, 9deg)
    }

    .rollover-boxes.rollover-boxes-inline {
        margin-bottom: 15px
    }

    .rollover-boxes.rollover-boxes-inline .box.box-lg {
        width: 100%;
        height: 400px;
        margin-bottom: 15px;
        float: none
    }

    .rollover-boxes.rollover-boxes-inline .box:not(.box-lg) {
        width: 100%;
        float: none;
        margin-right: 0;
        height: auto;
        margin-bottom: 15px;
        padding: 18px 25px
    }

    .rollover-boxes.rollover-boxes-inline .box:not(.box-lg) .box-title {
        position: relative;
        margin-bottom: 0;
        left: 0;
        bottom: 0
    }

    .projects .project .title {
        background-size: 0 1px
    }

    .projects .project:hover .title {
        background-size: 100% 1px
    }

    .projects .project .project-title {
        font-size: 20px
    }

    .accordion .accordion-button {
        font-size: 22px
    }

    .accordion-tiles .accordion-button .image-holder {
        width: 35px
    }

    .accordion-tiles .accordion-button .image-holder svg {
        height: 35px;
        width: 35px
    }

    .accordion-tiles .accordion-body {
        padding-top: 0
    }

    .projects .project {
        height: 300px
    }

    .stats {
        padding: 0 15px
    }

    .stats .stat {
        border: 0;
        margin-bottom: 10px
    }

    .stats .col {
        flex: 0 0 auto;
        width: 50%
    }

    header.main-header nav.menu {
        width: 300px;
        top: 73px;
        max-width: 100%
    }

    section.banner.banner-slider .d-table-cell {
        display: block;
        padding: 40px 0 50px
    }

    section.banner.banner-slider .slick-arrow.slick-prev {
        left: -10px
    }

    section.banner.banner-slider .slick-arrow.slick-next {
        left: 35px
    }

    section.banner .slick-dots li.slick-active {
        width: 100px
    }

    section.banner .slick-dots li {
        width: 40px
    }

    section.banner .slick-dots {
        padding-left: 0;
        left: -10px;
        bottom: inherit;
        top: -10px
    }

    .form.form-contact {
        padding: 20px;
        border: 1px solid #ddd;
        border-radius: 10px;
        background: #fff
    }

    .form.form-contact .form-control {
        background: #f9f9fb
    }

    .form .form-field {
        margin-bottom: 15px
    }

    section.tabs-module.tabs-module-classic .tab-content .image-holder {
        margin-left: 0
    }

    section.tabs-module .tab-content .image-holder {
        margin-right: 0;
        margin-left: 20px
    }

    section.tabs-module .tab-content .content-holder {
        padding-right: 0
    }

    section.tabs-module .tab-content .button-holder {
        margin-left: 20px
    }

    section.tabs-module.tabs-module-full .tab-content .content-holder {
        padding: 40px 20px 30px;
        margin-top: 0
    }

    section.bubble-module {
        padding-bottom: 50px
    }

    section.bubble-module .description {
        font-size: 16px
    }

    section.bubble-module .bubble-holder,
    section.bubble-module .bubble-holder .boxes {
        margin-top: 0
    }

    section.bubble-module .image-holder {
        width: 100%;
        height: inherit;
        position: relative
    }

    section.bubble-module .image-holder img {
        position: relative;
        bottom: inherit;
        max-width: 300px;
        margin: -30px 0 0
    }

    section.bubble-module .bubble-holder .title {
        text-align: left
    }

    section.bubble-module .bubble-holder .boxes .box .text {
        border: 0;
        padding-left: 20px;
        font-size: 16px
    }

    section.bubble-module .bubble-holder .boxes .box .text:before {
        content: "";
        height: 6px;
        width: 6px;
        top: 10px;
        border-radius: 50%;
        position: absolute;
        left: 0;
        display: inline-block;
        margin-right: 5px;
        background: #fff
    }

    section.bubble-module .bubble-holder .boxes .box:nth-child(5) .text {
        top: inherit;
        border: 0
    }

    section.bubble-module .bubble-holder .boxes .box {
        text-align: left !important;
        margin-bottom: 0;
        border-bottom: none;
        position: relative;
        min-height: inherit;
        float: none !important;
        width: 100% !important
    }

    section.banner-infrastructure {
        height: auto
    }

    section.banner-infrastructure .content-holder {
        padding: 40px 0
    }

    section.banner-infrastructure .pattern-line {
        display: none
    }

    section.banner-infrastructure .banner-wrapper {
        position: relative
    }

    section.banner-infrastructure .form-infrastructure .form .form-field.active .button-submit {
        right: 0
    }

    section.banner-infrastructure.animate .form-infrastructure {
        height: auto;
        position: relative;
        padding: 0 10px
    }

    .button-like-form {
        position: absolute;
        z-index: 30;
        top: -8px;
        left: 5px
    }

    .projects .project .project-content {
        bottom: 10px;
        left: 15px
    }

    aside.chat-container .chat-body {
        padding: 10px !important
    }

    aside.chat-container .chat-holder>div {
        max-height: 80vh
    }

    aside.chat-container {
        max-width: 92%
    }

    aside.chat-container .chat-header .icon.icon-chat {
        top: 5px
    }

    a.chat-button>svg,
    aside.chat-container .chat-header .icon.icon-chat svg {
        width: 20px
    }

    aside.chat-container .chat-header .icon {
        top: 13px
    }

    aside.chat-container .chat-header {
        height: 50px;
        padding: 16px 20px
    }

    a.chat-button .icon-rollover {
        height: 50px;
        padding: 5px 25px;
        display: none
    }

    a.chat-button:hover .icon-rollover,
    section.tabs-module .tab-content .content-holder h3.title {
        display: none
    }

    a.chat-button {
        height: 50px;
        width: 50px;
        font-size: 24px;
        padding: 5px;
        right: 10px;
        bottom: 10px
    }

    section.pages-module .pages .page-holder {
        opacity: 1 !important;
        transform: translateX(0) !important
    }

    section.tabs-module .tab-content .content-holder {
        min-height: 100px
    }
}

@media (max-width:500px) {
    .projects .project {
        height: 260px
    }

    section.banner.banner-slider {
        background: 0 0
    }

    section.banner.banner-slider .d-table-cell {
        display: block;
        height: 40vh;
        padding: 40px 0 30px
    }

    section.banner.banner-slider .banner-holder .content-holder {
        max-width: 350px
    }
}

@media (max-width:360px) {

    section.banner.banner-slider .h1,
    section.banner.banner-slider h1 {
        font-size: 23px
    }

    .h2,
    h2 {
        font-size: 30px
    }

    .posts .post.post-featured .image-holder {
        height: 115px;
        width: 115px;
        min-width: 115px
    }

    .categories .category {
        font-size: 10px
    }

    .posts .post.post-featured .content-holder {
        padding: 0 0 0 130px
    }

    section.banner h1 {
        font-size: 24px
    }
}

@media (min-width:1200px) {

    .horiz-gallery-strip,
    .horiz-gallery-wrapper {
        display: flex;
        flex-wrap: nowrap;
        will-change: transform;
        position: relative
    }

    .horiz-wrap {
        width: 20vw;
        box-sizing: content-box
    }

    nav.menu.main-menu>ul>li.has-children.row-menu>ul {
        display: block !important
    }

    nav.menu.main-menu>ul>li.has-children>ul {
        display: flex !important
    }

    section.custom-tabs .tab-content .card .collapse {
        display: block
    }

    section.custom-tabs:not(.custom-tabs-open) .card .card-header {
        display: none
    }
}

@media (max-width:1200px) {
    section.custom-tabs .tab-content>.tab-pane {
        display: block;
        opacity: 1
    }

    section.custom-tabs .tab-content>.collapse:not(.show) {
        display: block;
        opacity: 1
    }
}