html, body {
    margin: 0;
    padding: 0;
}

body {
    font-family: "gesta", sans-serif;
    font-weight: 400;
    font-style: normal;
    color: #021D1D;
    font-size: 18px;
    background-color: #FFF;
    overflow-x: hidden;
}
p {
    line-height: 2em;
    margin-bottom: 2em;
}
a {
    text-decoration: none;
    color: inherit;
}
p a {
    text-decoration: underline;
}
ul {
    line-height: 2em;
}

/* focus reset */

a:focus, .slick-slide:focus {
    outline: 0;
}
button {
    cursor: pointer;
}


/* Headings */

h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    color: #025B5F
}
h1 span, h2 span, h3 span, h4 span, h5 span, h6 span {
    color: #00C4CC;
}
h1 {
    font-size: 80px;
    line-height: 80px;
}
h2 {
    font-size: 44px;
    line-height: 60px;
}
h3 {
    font-size: 40px;
    line-height: 50px;
}
h4 {
    font-size: 48px;
    line-height: 48px;
}
.prefix {
    font-weight: 700;
    font-size: 40px;
    color: #025B5F;
    margin-bottom: .6em;
}

/* Buttons */

.btn {
    border-radius: 5px;
    padding: 16px 40px;
    font-weight: 400;
    border: 2px solid transparent;
    display: inline-flex;
    text-decoration: none!important;
}
.btn-primary {
    background-color: #00C4CC;
    border-color: #00C4CC;
    color: #FFF;
}
.btn-secondary {
    background-color: #025B5F;
    border-color: #025B5F;
    color: #fff;
}
.btn-outline-light {
    background-color: transparent;
    border-color: #00C4CC;
    color: #FFF;
}

.btn-group {
    display: flex;
    flex-direction: row;
}
.btn-group .btn {
    margin-right: 15px;
}

.arrow-link {
    display: flex!important;
    flex-direction: row!important;
    position: relative;
    padding-right: 20px;
}
.arrow-link::after {
    content: '\f105';
    font-family: 'Font Awesome 5 Pro';
    margin-left: 1em;
    margin-top: 5px;
    position: absolute;
    right: 0;
}

.share-buttons-wrapper  {
    display: flex;
    justify-content: start;
    align-self: flex-start;
    
}
.share-buttons-wrapper .share-buttons {
    display: flex;
    justify-content: start;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
}
.share-buttons-wrapper .share-buttons li {
    margin: 0px 20px 20px 0px;
}
.share-buttons-wrapper .share-buttons li a img {
    width: 40px;
}

/* ul */

ul.social-list {
    list-style: none;
    margin: 20px 0px;
    padding: 0px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
ul.social-list li {
    margin-right: 1em;
}
ul.social-list li a {
    display: block;
    width: 50px;
    height: 50px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #00C4CC;
}
ul.social-list li a span {
    color: #FFF;
    font-size: 1.5em;
}


/* Sections, grids, containers */

section {
    padding: 100px 0px;
    position: relative;
    box-sizing: border-box;
}

.container-fluid {
    width: 100%;
    box-sizing: border-box;
}

.page-wrapper {
    padding-left: 80px;
}

/* Header */

header {
    position: relative;
    padding: 30px 80px 20px 0;
    z-index: 999;
}
header .logo a img {
    max-width: 393px;
}
header .desktop-nav nav ul {
    list-style: none;
    display: flex;
    margin-left: 0;
    padding-left: 0;
}
header .desktop-nav nav ul li {
    margin-left: 2em;
    display: flex;
    align-items: center;
    position: relative;
}
header .desktop-nav nav ul li.dropdown::after {
    font-family: 'Material Icons';
    content: "expand_more";
    -webkit-font-feature-settings: 'liga' 1;
    -moz-font-feature-settings: 'liga' 1;
    font-feature-settings: 'liga' 1;
    margin-left: .3em;
}
header .desktop-nav nav ul li a {
    font-weight: 700;
}
header .desktop-nav nav ul li:hover ul {
    display: flex;
}
header .desktop-nav nav ul li ul {
    display: none;
    position: absolute;
    bottom: 0px;
    transform: translateY(100%);
    left: -30px;
    min-width: 250px;
    z-index: 9;
    flex-direction: column;
    background-color: #FFF;
    border-radius: 0px 0px 5px 5px;
    margin: 0px;
    padding: 40px 10px 10px 10px;
    box-sizing: border-box;
    box-shadow: 0px 10px 10px rgba(0,0,0,.1);
}
header .desktop-nav nav ul li ul li {
    margin: 0px;
}
header .desktop-nav nav ul li ul li a {
    padding: 10px 20px;
    display: flex;
    width: 100%;
    font-weight: 400;
    border-bottom: 1px solid #EFEFEF;
}
header .desktop-nav nav ul li ul li:last-child a {
    border-bottom: none;
}


header .mobile-nav .hamburger {
    width: 40px;
    height: 40px;
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    background: #00C4CC;
    border-radius: 5px;
    padding: 10px;
}

header .mobile-nav .hamburger span {
    height: 2px;
    left: 20px;
    right: 20px;
    border-radius: 20px;
    background: #FFF;
    display: block;
    position: absolute;
    transition: all 250ms ease-in-out
}

header .mobile-nav .hamburger span:first-child {
    top: 20px
}

header .mobile-nav .hamburger span:nth-child(2) {
    top: 50%;
    transform: translateY(-50%)
}

header .mobile-nav .hamburger span:last-child {
    bottom: 20px;
    right: 30px
}

header .mobile-nav .hamburger.open span:nth-child(2) {
    width: 0px;
    opacity: 0
}

header .mobile-nav .hamburger.open span:first-child {
    top: 50%;
    transform: translateY(-50%) rotate(-45deg)
}

header .mobile-nav .hamburger.open span:last-child {
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
    width: 20px;
}


/* Menu overlay */

.menu-overlay {
    display: none;
    visibility: hidden;
    position: fixed;
    top: 0px;
    right: 0px;
    bottom: 0px;
    left: 0px;
    background: #ffffff;
    opacity: 0;
    transition: opacity .60s,visibility .60s,height .60s;
    z-index: 99;
    overflow-x: hidden;
    overflow-y: scroll;
}
.menu-overlay.open {
    display: block;
    opacity: 1;
    visibility: visible;
    height: 100%;
}
.menu-overlay nav {
    padding-top: 130px;
}
.menu-overlay nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.menu-overlay nav ul li {
    display: block;
    width: 100%;
    margin-bottom: 20px;
}
.menu-overlay nav ul li a {
   color: #025B5F;
   font-weight: 600;
   font-size: 20px;
   padding: 10px 0px 10px 20px;
   display: block;
   text-decoration: none;
   display: flex;
   justify-content: space-between;
}
.menu-overlay nav ul li a::after {
    font-family: 'Material Icons';
    content: "arrow_forward";
    -webkit-font-feature-settings: 'liga' 1;
    -moz-font-feature-settings: 'liga' 1;
    font-feature-settings: 'liga' 1;
    margin-left: 1em;
    font-size: 1.3em;
    color: #00C4CC;
}
.menu-overlay nav ul li ul {
    margin-left: 1em;
    display: none;
}
.menu-overlay nav ul li ul li a {
    font-weight: 400;
    font-size: 16px;
}
.menu-overlay nav ul li ul li a::after {
    display: none;
}
.menu-overlay .button-group {
    margin-top: 50px;
}
.menu-overlay .button-group .btn {
    margin-bottom: 15px;
}



/* Slider */

.slider .action-button {
    position: absolute;
    right: 80px;
    top: 0;
    z-index: 9;
}
.slider .action-button a {
    background-color: #00C4CC;
    color: #FFF;
    font-weight: 700;
    border-radius: 0px 0px 5px 5px;
    padding: 16px 40px;
    display: flex;
    transition: ease .5s;
}
.slider .action-button a:hover {
    background-color: #025B5F;
}

.slider .slick-arrow {
    position: absolute;
    top: 50%;
    background: transparent;
    border: none;
    color: #025B5F;
    background: #FFF;
    height: 50px;
    width: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.5em;
    line-height: 0;
    z-index: 9
}
.slider .slick-arrow.slick-prev {
    left: 0px;
    display: none;
    visibility: hidden;
}
.slider .slick-arrow.slick-next {
    right: 0px;
    border-radius: 5px 0px 0px 5px;
}

/* Scroll */

.direction-scroll{
    display: flex!important;
    position: absolute;
    left: -65px;
    bottom: 50px;
    flex-direction: row;
    margin: 0 auto;
    width: inherit;
    height: 100%;
    z-index: 3;
    justify-content: center;
    cursor: pointer;
}
.inner{
    position: relative;
    z-index: 2;
    background: transparent;
    align-self: flex-end;
    padding: 20px 0px 0px 0px;
}
.scroll-line{
    height: 400px;
    width: 2px;
    background: #025B5F;
    margin: 0 auto;
    animation: flowdown 1.5s infinite;
}
@keyframes flowdown{
    0%{
        transform-origin: 0% 0%;
        transform: scale(1,0);
    }
    50%{
        transform-origin: 0% 0%;
        transform: scale(1, 1);
    }
    50.1%{
        transform-origin: 0% 100%;
        transform: scale(1, 1);
    }
    100%{
        transform-origin: 0% 100%;
        transform: scale(1, 0);
    }
}
.scroll-text{
    transform: rotate(-90deg);
    height: 100px;
    color: #025B5F;
    font-size: .8em;
    display: flex;
    align-items: center;
}

@media screen and (max-width: 991px) {
    .direction-scroll {
        display: none!important;
    }
}

/* Slider Home */

.slider-home {
    position: relative;
    padding: 0px;
    height: calc(100vh - 108px);
    min-height: 800px;
}
.slider-home::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 200px;
    left: 0;
    right: 0;
    bottom: -1px;
    background-image: url(../img/wave-01.svg);
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: 9;
}
/* .slider-home::after {
    content: '';
    background: linear-gradient(-180deg,rgba(0,67,126,0) 0%,rgba(0,67,126,0.8) 100%);
    filter: brightness(0.5);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    height: 100%;
    width: 100%;
    z-index: 3;
} */
.slider-home .slider-home-items {
    border-radius: 50px 0px 0px 0px;
    overflow: hidden;
}
.slider-home .slider-home-items .slider-home-item {
    height: calc(100vh - 108px);
    min-height: 800px;
    position: relative;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.slider-home .content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 4;
}
.slider-home .content .content-box {
    background-color: #025B5F;
    padding: 40px 80px 180px 40px;
    border-radius: 5px;
    color: #FFF;
    line-height: 2em;
}
.slider-home .content .content-box h1 {
    color: #FFF;
    margin-top: 0px;
    margin-bottom: 40px;
    font-size: 44px;
    line-height: 54px;
}


/* Slider General */

.slider-general {
    position: relative;
    padding: 0px;
    height: calc(60vh - 108px);
    min-height: 700px;
}
.slider-general::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 200px;
    left: 0;
    right: 0;
    bottom: -1px;
    background-image: url(../img/wave-01.svg);
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: 9;
}
.slider-general .slider-general-items {
    border-radius: 50px 0px 0px 0px;
    overflow: hidden;
}
.slider-general .slider-general-items .slider-general-item {
    height: calc(60vh - 108px);
    min-height: 700px;
    position: relative;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.slider-general .content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 4;
}
.slider-general .content .content-box {
    background-color: #025B5F;
    padding: 40px 80px 120px 40px;
    border-radius: 5px;
    color: #FFF;
    line-height: 2em;
}
.slider-general .content .content-box h1 {
    color: #FFF;
    margin-top: 0px;
    margin-bottom: 40px;
    font-size: 44px;
    line-height: 54px;
}

/* Hero General */

.hero-general {
    position: relative;
    padding: 0px;
    height: calc(60vh - 108px);
    min-height: 700px;
    border-radius: 50px 0px 0px 0px;
}
.hero-general.hero-general-secondary {
    background-color: #025B5F;
}
.hero-general.hero-general-primary {
    background-color: #00C4CC;
}
.hero-general::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 200px;
    left: 0;
    right: 0;
    bottom: -1px;
    background-image: url(../img/wave-01.svg);
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: 9;
}
.hero-general .content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 4;
}
.hero-general .content .content-box {
    padding-bottom: 150px;
    border-radius: 5px;
    color: #FFF;
    line-height: 2em;
}
.hero-general .content .content-box h1 {
    color: #FFF;
    margin-top: 0px;
    margin-bottom: 40px;
    font-size: 60px;
    line-height: 54px;
}

.hero-general .action-button {
    position: absolute;
    right: 80px;
    top: 0;
    z-index: 9;
}
.hero-general .action-button a {
    background-color: #00C4CC;
    color: #FFF;
    font-weight: 700;
    border-radius: 0px 0px 5px 5px;
    padding: 16px 40px;
    display: flex;
    transition: ease .5s;
}
.hero-general.hero-general.hero-general-primary .action-button a {
    background-color: #025B5F;
}

.hero-general .action-button a:hover {
    background-color: #025B5F;
}

/* Cards home */

.cards-home .card {
    padding: 40px 80px 40px 40px;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    border-radius: 5px;
}
.cards-home .card.card-primary {
    background: #025B5F;
}
.cards-home .card .icon {
    width: 94px;
    height: 94px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #025B5F;
    color: #FFF;
    font-size: 2.5em;
    border-radius: 5px;
}
.cards-home .card.card-primary .icon {
    background: #FFF;
    color: #025B5F;
}
.cards-home .card .title {
    font-weight: 700;
    font-size: 1.5em;
    color: #025B5F;
    margin: 1.3em 0;
}
.cards-home .card.card-primary .title {
    color: #FFF;
}
.cards-home .card.card-primary .description {
    color: #FFF;
}
.cards-home .card .button-group {
    margin-top: 2em;
}

/* Services carousel */

.services-carousel {
    background-color: #EFEFEF;
    border-radius: 50px 0px 0px 50px;
}
.services-carousel .services-carousel-items {
    margin: 0 -50px;
}
.services-carousel .services-carousel-items .services-carousel-item {
    margin: 50px 50px;

}
.services-carousel .services-carousel-items .services-carousel-item .card a {
    display: flex;
    flex-direction: column;
}
.services-carousel .services-carousel-items .services-carousel-item .card a .icon {
    width: 94px;
    height: 94px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #fff;
    color: #00C4CC;
    font-size: 2.5em;
    border-radius: 5px;
}
.services-carousel .services-carousel-items .services-carousel-item .card a .title {
    font-weight: 700;
    font-size: 1.5em;
    color: #025B5F;
    margin: 1.3em 0;
}
.services-carousel .services-carousel-items  .slick-arrow {
    position: absolute;
    right: 40px;
    top: -100px;
    background: transparent;
    border: none;
    font-size: 2em;
    color: #025B5F
}
.services-carousel .services-carousel-items  .slick-arrow.slick-prev {
    right: 100px;
}



/* Featured projects carousel */

.featured-projects-carousel {
    background-color: #025B5F;
    border-radius: 50px 0px 0px 0px;
    margin: 50px 0px;
}
.featured-projects-carousel h2 {
    color: #FFF;
}
.featured-projects-carousel .featured-projects-carousel-items {
    margin: 0 -50px;
}
.featured-projects-carousel .featured-projects-carousel-items .featured-projects-carousel-item {
    margin: 50px 50px;
}
.featured-projects-carousel .featured-projects-carousel-items .featured-projects-carousel-item .card a {
    display: flex;
    flex-direction: column;
    position: relative;
}
.featured-projects-carousel .featured-projects-carousel-items .featured-projects-carousel-item .card a .badges {
    position: absolute;
    top: 20px;
    right: 20px;
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    align-content: center;
}
.featured-projects-carousel .featured-projects-carousel-items .featured-projects-carousel-item .card a .badges span {
    background: #00C4CC;
    border-radius: 5px;
    padding: 10px 20px;
    color: #FFF;
    margin-left: 10px;
    font-size: .8em;
}
.featured-projects-carousel .featured-projects-carousel-items .featured-projects-carousel-item .card a .image img {
    width: 100%;
    border-radius: 0px 0px 50px 0px;
}
.featured-projects-carousel .featured-projects-carousel-items .featured-projects-carousel-item .card a .title {
    color: #FFF;
    font-weight: 700;
    padding: 1em 0;
    font-size: 1.5em;
    border-bottom: 2px solid #00C4CC;
}
.featured-projects-carousel .featured-projects-carousel-items .slick-arrow {
    position: absolute;
    right: 40px;
    top: -100px;
    background: transparent;
    border: none;
    font-size: 2em;
    color: #fff;
}
.featured-projects-carousel .featured-projects-carousel-items .slick-arrow.slick-prev {
    right: 100px;
}

/* Text image block */

.text-image-block .text h3 {
    margin-top: 0px;
}
.text-image-block .image img {
    width: 100%;
    border-radius: 0px 0px 50px 0px;
}

/* USP Cards */

.usp-cards {
    background-color: #025B5F;
    border-radius: 50px 0px 0px 50px;    
}
.usp-cards h2 {
    color: #FFF;
    margin-top: 0;
}
.usp-cards .usp-cards-items {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 50px;
    row-gap: 50px;
    margin-top: 50px;
}
.usp-cards .usp-cards-items .usp-cards-item {
    color: #FFF;
}
.usp-cards .usp-cards-items .usp-cards-item .title {
    font-weight: 700;
    font-size: 1.5em;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.usp-cards .usp-cards-items .usp-cards-item .title span {
    background-color: #00C4CC;
    border-radius: 5px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 1em;
}

/* Client carousel */

.client-carousel {

}
.client-carousel .client-carousel-items {
    margin: 50px 0;
}
.client-carousel .client-carousel-items .client-carousel-item img {
    max-height: 100px;
    max-width: 90%;
}
.client-carousel .client-carousel-items .slick-arrow {
    position: absolute;
    right: 40px;
    top: -150px;
    background: transparent;
    border: none;
    font-size: 2em;
    color: #025B5F;
}
.client-carousel .client-carousel-items .slick-arrow.slick-prev {
    right: 100px;
}

/* References overview */

.references-overview .references-overview-items {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}
.references-overview .references-overview-items .references-overview-item {
    border: 1px solid #EFEFEF;
    padding: 40px;
}
.references-overview .references-overview-items .references-overview-item .title {
    color: #025B5F;
    font-weight: 700;
    font-size: 1.5em;
    margin-bottom: 15px;
}


/* Cases overview */

.cases-overview {
    padding-bottom: 200px;
}

.cases-overview .cases-overview-filter {
  margin: 2em 0 5em 0;
}
.cases-overview .cases-overview-filter ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  overflow: auto;
  white-space: nowrap;
}
.cases-overview .cases-overview-filter ul::-webkit-scrollbar {
  display: none;
}
.cases-overview .cases-overview-filter ul li {
  margin-right: 1em;
}
.cases-overview .cases-overview-filter ul li:first-child {
  margin-right: 2em;
  font-weight: 600;
  text-transform: uppercase;
}
.cases-overview .cases-overview-filter ul li button {
  font-size: inherit;
}

.cases-overview .cases-overview-items {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 100px;
    row-gap: 100px;
}
.cases-overview .cases-overview-items .cases-overview-item a {
    display: flex;
    flex-direction: column;
    position: relative;
}
.cases-overview .cases-overview-items .cases-overview-item a .badges {
    position: absolute;
    top: 20px;
    right: 20px;
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    align-content: center;
}
.cases-overview .cases-overview-items .cases-overview-item a .badges span {
    background: #00C4CC;
    border-radius: 5px;
    padding: 10px 20px;
    color: #FFF;
    margin-left: 10px;
    font-size: .8em;
}
.cases-overview .cases-overview-items .cases-overview-item a .image img {
    width: 100%;
    border-radius: 0px 0px 50px 0px;
}
.cases-overview .cases-overview-items .cases-overview-item a .description .title {
    color: #025B5F;
    font-weight: 700;
    padding: 1em 0;
    font-size: 1.5em;
    border-bottom: 2px solid #00C4CC;
}


/* Cases detail */

.cases-detail .cases-detail-content {
    text-align: center;
    margin-bottom: 80px;
}

.cases-detail .cases-detail-images-main .cases-detail-images-main-items .cases-detail-images-main-item img {
    width: 100%;
    border-radius: 50px;
}
.cases-detail .cases-detail-images-nav {
    margin: 50px 0px;
}
.cases-detail .cases-detail-images-nav .cases-detail-images-nav-items .cases-detail-images-nav-item img {
    width: 100%;
    border-radius: 20px;
}
.cases-detail .cases-detail-images-nav .cases-detail-images-nav-items {
    margin: 0 -30px;
}
.cases-detail .cases-detail-images-nav .cases-detail-images-nav-items .cases-detail-images-nav-item {
    margin: 0 30px;
}
.cases-detail .cases-detail-images-nav .cases-detail-images-nav-items .slick-slide {
    opacity: 0;
}
.cases-detail .cases-detail-images-nav .cases-detail-images-nav-items .slick-active {
    opacity: 1;
}


.cases-detail .cases-detail-images-main .cases-detail-images-main-items .slick-arrow {
    position: absolute;
    top: 50%;
    background: transparent;
    border: none;
    color: #025B5F;
    background: #FFF;
    height: 50px;
    width: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.5em;
    line-height: 0;
    z-index: 9
}
.cases-detail .cases-detail-images-main .cases-detail-images-main-items .slick-arrow.slick-next {
    right: 0;
}
.cases-detail-buttons .button-group {
    display: flex;
    justify-content: center;
}
.cases-detail-buttons .button-group a {
    margin: 10px;
}

/* Blogs overview */

.blogs-overview {
    padding-bottom: 200px;
}
.blogs-overview .blogs-overview-filter {
  margin: 2em 0 5em 0;
}
.blogs-overview .blogs-overview-filter ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  overflow: auto;
  white-space: nowrap;
}
.blogs-overview .blogs-overview-filter ul::-webkit-scrollbar {
  display: none;
}
.blogs-overview .blogs-overview-filter ul li {
  margin-right: 1em;
}
.blogs-overview .blogs-overview-filter ul li:first-child {
  margin-right: 2em;
  font-weight: 600;
  text-transform: uppercase;
}
.blogs-overview .blogs-overview-filter ul li button {
  font-size: inherit;
}

.blogs-overview .blogs-overview-items {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 100px;
    row-gap: 100px;
}
.blogs-overview .blogs-overview-items .blogs-overview-item {
    
}
.blogs-overview .blogs-overview-items .blogs-overview-item a {
    display: flex;
    flex-direction: column;
}
.blogs-overview .blogs-overview-items .blogs-overview-item  .image img {
    width: 100%;
    border-radius: 0px 0px 50px 0px;
}
.blogs-overview .blogs-overview-items .blogs-overview-item a .description .title {
    color: #025B5F;
    font-weight: 700;
    padding: 1em 0;
    font-size: 1.3em;
    border-bottom: 2px solid #00C4CC;
}

/* Blogs detail */

.blog-detail .blog-detail-content {
    text-align: center;
    margin-bottom: 80px;
}

.blog-detail .blog-detail-images-main .blog-detail-images-main-items .blog-detail-images-main-item img {
    width: 100%;
    border-radius: 50px;
}
.blog-detail .blog-detail-description {
    padding: 50px 0px;
}
.blog-detail-buttons .button-group {
    display: flex;
    justify-content: center;
}
.blog-detail-buttons .button-group a {
    margin: 10px;
}

/* Blogs carousel */

.blogs-carousel .blogs-carousel-items {
    margin: 0 -50px;
}
.blogs-carousel .blogs-carousel-items .blogs-carousel-item {
    margin: 50px 50px;

}
.blogs-carousel .blogs-carousel-items .blogs-carousel-item a {
    display: flex;
    flex-direction: column;
}
.blogs-carousel .blogs-carousel-items .blogs-carousel-item  .image img {
    width: 100%;
    border-radius: 0px 0px 50px 0px;
}
.blogs-carousel .blogs-carousel-items .blogs-carousel-item a .description .title {
    color: #025B5F;
    font-weight: 700;
    padding: 1em 0;
    font-size: 1.3em;
    border-bottom: 2px solid #00C4CC;
}
.blogs-carousel .btn {
    margin-top: 50px;
}
.blogs-carousel .blogs-carousel-items  .slick-arrow {
    position: absolute;
    right: 40px;
    top: -100px;
    background: transparent;
    border: none;
    font-size: 2em;
    color: #025B5F
}
.blogs-carousel .blogs-carousel-items  .slick-arrow.slick-prev {
    right: 100px;
}



/* Information page */

.information-page ul {
    line-height: 2em;
}

/* Jobs overview */

.jobs-overview .jobs-overview-items {
    display: grid;
    grid-template-columns: 1fr 1fr;
    row-gap: 30px;
    gap: 30px;
}
.jobs-overview .jobs-overview-items .jobs-overview-item {
    box-shadow: 0px 0px 20px rgba(0,0,0,.1);
    border-radius: 0px 0px 50px 0px;
    padding: 40px;
}
.jobs-overview .jobs-overview-items .jobs-overview-item a {
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    justify-content: space-between;
    color: #025B5F
}
.jobs-overview .jobs-overview-items .jobs-overview-item a .title {
    font-weight: 700;
    font-size: 1.3em;
}
.jobs-overview .jobs-overview-items .jobs-overview-item a .details {
    margin: 1em 0;
}
.jobs-overview .jobs-overview-items .jobs-overview-item a .details ul {
    display: flex;
    justify-content: flex-start;
    list-style: none;
    margin: 0;
    padding: 0;
}
.jobs-overview .jobs-overview-items .jobs-overview-item a .details ul li {
    margin: 1em 0;
}
.jobs-overview .jobs-overview-items .jobs-overview-item a .details ul li::after {
    content: '|';
    margin: 0 1em;
}
.jobs-overview .jobs-overview-items .jobs-overview-item a .details ul li:last-child:after { 
    display: none;
}
.jobs-overview .jobs-overview-items .jobs-overview-item a .action {
    color: #00C4CC;
    display: flex;
    align-items: center;
}
.jobs-overview .jobs-overview-items .jobs-overview-item a .action::after {
    font-family: 'Material Icons';
    content: "arrow_forward";
    -webkit-font-feature-settings: 'liga' 1;
    -moz-font-feature-settings: 'liga' 1;
    font-feature-settings: 'liga' 1;
    margin-left: 1em;
    font-size: 1.3em;
}

.jobs-overview .jobs-overview-items .jobs-overview-item.open-application {
    background: #025B5F;
}
.jobs-overview .jobs-overview-items .jobs-overview-item.open-application a {
    color: #FFF;
}
.jobs-overview .jobs-overview-items .jobs-overview-item.open-application a .details {
    margin: 2em 0;
}
.jobs-overview .jobs-overview-items .jobs-overview-item.open-application a .action {
    color: #FFF;
}


/* Jobs detail content */

.slider-job-detail .prefix {
    color: #00C4CC;
}

.jobs-detail-content {

}
.jobs-detail-content .container-fluid {
    padding-right: 0;
}
.jobs-detail-content .jobs-detail-content-attributes {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    border-bottom: 2px solid #EFEFEF;
}
.jobs-detail-content .jobs-detail-content-attributes .jobs-detail-content-attribute {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.jobs-detail-content .jobs-detail-content-attributes .jobs-detail-content-attribute .icon {
    margin-right: 1em;
}
.jobs-detail-content .jobs-detail-content-attributes .jobs-detail-content-attribute .icon span {
    color: #00C4CC;
    font-size: 20px;
}
.jobs-detail-content .jobs-detail-content-attributes .jobs-detail-content-attribute .text h5 {
    font-size: 20px;
}
.jobs-detail-content .jobs-detail-content-text h2:first-child {
    margin-top: 50px;
}
.jobs-detail-content .jobs-detail-content-action-form {
    background-color: #EFEFEF;
    border-radius: 50px 0px 0px 0px;
}
.jobs-detail-content .jobs-detail-content-action-form .inner {
    padding: 50px;
}
.jobs-detail-content .jobs-detail-content-action-form .jobs-detail-content-action {
    background-color: #EFEFEF;
    border-radius: 50px 0px 0px 0px;
}
.jobs-detail-content .jobs-detail-content-action-form .jobs-detail-content-action h2 {
    margin-top: 0;
}
.jobs-detail-content .jobs-detail-content-action-form .jobs-detail-content-form {
    background-color: #025B5F;
    border-radius: 50px 0px 0px 50px;
}
.jobs-detail-content .jobs-detail-content-action-form .jobs-detail-content-form h2 {
    color: #FFF;
}
.jobs-detail-content .jobs-detail-content-action-form .jobs-detail-content-form p {
    color: #FFF;
}

/* Form */

form .form-group {
    
}
form .form-group .form-control {
    margin-bottom: 25px;
    padding: 15px 30px;
    background: #FFF;
    border-radius: 5px;
    border: 1px solid #FFF;
    font-size: 16px;
    width: 100%;
    box-sizing: border-box;
    color: #021D1D;
    font-family: "gesta", sans-serif;
}
form .form-group .form-control::placeholder {
    font-size: 16px;
    color: #021D1D;
}
form .form-group .form-control:focus {
    outline: none;
}
form button {
    width: 100%;
    justify-content: center;
    font-size: 16px;
    font-weight: 700;
}
form .upload-button {
    border-radius: 5px;
    padding: 16px 40px;
    font-weight: 400;
    border: 2px solid transparent;
    display: inline-flex;
    background-color: transparent;
    border-color: #fff;
    color: #FFF;
}
.responsiv-uploader-fileupload {
    width: 100%;
}
.upload-files-container {
    display: flex;
    flex-direction: column;
}
.upload-files-container .upload-object {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 10px 30px;
    border: 2px solid #FFF;
    border-radius: 5px;
    margin: 10px 0px;
}
.upload-files-container .upload-object .icon-container img {
    max-width: 100px;
}
.upload-files-container .upload-object .info {
    display: flex;
    flex-direction: row;
    align-items: center;
}
.upload-files-container .upload-object .info h4 {
    font-size: inherit;
    color: #FFF;
    margin: 0;
}
.upload-files-container .upload-object .info h4 span {
    color: #FFF;
}
.upload-files-container .upload-object .info .size {
    color: #FFF;
    opacity: .2;
    margin: 0 0 0 1em;
}
.upload-files-container .upload-object .meta a.upload-remove-button {
    color: #FFF;
}


/* Footer: top */

footer .footer-top {
    border-radius: 50px 0px 0px 0px;
    padding-top: 15vh;
    position: relative;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}
footer .footer-top::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 200px;
    left: 0;
    right: 0;
    bottom: -1px;
    background-image: url(../img/wave-02.svg);
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: 9;
}
footer .footer-top .content-box {
    background-color: #00C4CC;
    border-radius: 5px;
    padding: 40px 40px 200px 40px;
    color: #FFF;
}
footer .footer-top .content-box .title {
    font-size: 2em;
    color: #FFF;
    font-weight: 700;
}

/* Footer: center */

footer .footer-center {
    padding: 60px 0px 80px 0px;
    background-color: #025B5F;
    border-radius: 0px 0px 0px 50px;
}
footer .footer-center .footer-column {
    margin: 50px 0px;
}
footer .footer-center .footer-column .title {
    font-weight: 700;
    color: #FFF;
    margin-bottom: 30px;
}
footer .footer-center .footer-column ul.footer-nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    line-height: 2.5em;
}
footer .footer-center .footer-column ul.footer-nav-list li a::before {
    font-family: 'Material Icons';
    content: "chevron_right";
    -webkit-font-feature-settings: 'liga' 1;
    -moz-font-feature-settings: 'liga' 1;
    font-feature-settings: 'liga' 1;
    color: #00C4CC;
    margin-right: 1em;
}
footer .footer-center .footer-column ul.footer-nav-list li a {
    color: #FFF;
    display: flex;
    align-items: center;
}
footer .footer-center .footer-column address {
    font-style: normal;
    color: #FFF;
    line-height: 1.5em;
}
footer .footer-center .footer-column ul.contact-list {
    list-style: none;
    margin: 20px 0px 0px 0px;
    padding: 0;
    line-height: 2.5em;
}
footer .footer-center .footer-column ul.contact-list li a {
    display: flex;
    color: #FFF;
}
footer .footer-center .footer-column ul.contact-list li a .icon {
    width: 25px;
    margin-right: 1em;
    color: #00C4CC;
}

/* Footer: bottom */

footer .footer-bottom {
    padding: 40px 0px;
}
footer .footer-bottom .footer-links ul {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    align-items: center;
    justify-content: center;
}
footer .footer-bottom .footer-links ul li {
    margin: 0 1em;
}
footer .footer-bottom .footer-links ul li a { 
    color: #6E6EB3;
    text-decoration: underline;
}
footer .footer-bottom .footer-hallmarks ul {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
}
footer .footer-bottom .footer-hallmarks ul li {
    margin: 0 1em 0 0;
    display: block;
}
footer .footer-bottom .footer-hallmarks ul li img {
    max-height: 80px;
    max-width: 160px;
    width: 100%;
}
footer .footer-bottom .footer-logo a img {
    max-width: 250px;
}


@media screen and (max-width: 1500px) {
    header .logo a img {
        max-width: 300px;
    }
    header .desktop-nav nav ul li {
        margin-left: 1.5em;
    }
}


@media screen and (min-width: 768px) and (max-width: 1200px) {
    .jobs-overview .jobs-overview-items .jobs-overview-item a {
        flex-direction: column;
        align-items: start;
    }
    .jobs-overview .jobs-overview-items .jobs-overview-item a .details {
        margin: 1em 0;
    }
    .jobs-overview .jobs-overview-items .jobs-overview-item a .details ul li {
        margin: 0 2em 0 0;
    }
    
}

@media screen and (max-width: 991px) {
    .cases-overview .cases-overview-items {
        grid-template-columns: 1fr;
        row-gap: 50px;
    }
    .cases-overview .cases-overview-items .cases-overview-item a .description .title {
        font-size: 1.3em;
    }

    .blogs-overview .blogs-overview-items {
        grid-template-columns: 1fr 1fr;
        row-gap: 50px;
    }

    .usp-cards .usp-cards-items {
        grid-template-columns: 1fr;
        row-gap: 50px;
    }

    .jobs-detail-content .jobs-detail-content-text h2:first-child {
        margin-top: 0;
    }

    .cases-detail .cases-detail-content h1 {
        font-size: 40px;
        line-height: 40px;
    }

    .blog-detail .blog-detail-content h1 {
        font-size: 40px;
        line-height: 40px;
    }
}

@media screen and (max-width: 768px) {

    body {
        font-size: 16px;
    }

    .page-wrapper {
        padding-left: 0px;
        overflow-x: hidden;
    }

    h2 {
        font-size: 32px;
        line-height: 38px;
    }
    h3 {
        font-size: 28px;
        line-height: 34px;
    }

    section {
        padding: 60px 0px;
    }

    .text-image-block .image {
        margin: 0px!important;
    }
    .usp-cards {
        margin: 30px 0px 30px 10px;
    }
    .jobs-detail-content .jobs-detail-content-attributes {
        margin-bottom: 30px;
    }

    header .logo a img {
        max-width: 250px;
    }

    .slider-home {
        min-height: 500px;
        margin-left: 10px;
        height: auto;
    }
    .slider-home .slider-home-items .slider-home-item {
    min-height: 360px;
    height: auto;
}
    .slider-home::after {
        height: 60px;
        bottom: -1px;
    }
    .slider-home .action-button {
        right: 16px;
    }
    .slider-home .slick-arrow {
        top: 20%;
    }
    .slider-home .content .content-box {
        padding: 40px 40px 70px 40px;
    }
    .slider-home .content .content-box h1 {
        font-size: 24px;
        line-height: 32px;
    }
    .slider-home .content .content-box p {
        display: none;
    }
    .slider .action-button {
        right: 15px;
    }

    .hero-general {
        min-height: 550px;
    }
    .hero-general .action-button {
        right: 15px;
    }
    .slider-general {
        min-height: auto;
        height: auto;
    }
    .slider-general::after {
        height: 60px;
        bottom: -1px;
        display: none;
    }

    .slider-general .content {
        position: relative;
        margin: 0 -20px;
    }
    .slider-general .content .content-box {
        padding: 30px;
        margin-top: -50px;
        z-index: 2;
    }
    .slider-general .content .content-box h1 {
        font-size: 32px;
        line-height: 34px;
    }
    .slider-general .slider-general-items .slider-general-item {
        min-height: 300px;
    }

    .hero-general .content .content-box h1 {
        font-size: 34px;
        line-height: 32px;
    }

    .blogs-overview .blogs-overview-items {
        grid-template-columns: 1fr;
        row-gap: 50px;
    }

    .blogs-carousel .blogs-carousel-items .slick-arrow {
        top: auto;
        bottom: -30px;
    }

    .cards-home .card {
        padding: 30px;
    }

    .services-carousel {
        margin-left: 10px;
    }

    .services-carousel .services-carousel-items .slick-arrow {
        top: auto;
        bottom: -30px;
    }
    .featured-projects-carousel {
        margin-left: 10px;
    }
    .featured-projects-carousel .featured-projects-carousel-items .slick-arrow {
        top: auto;
        bottom: -30px;
    }

    .text-image-block .image {
        margin: 30px 0px;
    }

    .references-overview .references-overview-items { 
        grid-template-columns: 1fr;
    }

    .jobs-overview .jobs-overview-items { 
        grid-template-columns: 1fr;
    }
.jobs-overview .jobs-overview-items .jobs-overview-item a .details ul li::after {
    display: none;
}
    .jobs-overview .jobs-overview-items .jobs-overview-item a {
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
    }
    .jobs-overview .jobs-overview-items .jobs-overview-item a .details {
        margin: 1em 0;
    }
    .jobs-overview .jobs-overview-items .jobs-overview-item a .details ul {
        flex-direction: column;
        line-height: 2em;
    }
    .jobs-overview .jobs-overview-items .jobs-overview-item a .details ul li {
        margin: 0 1em 0 0;
    }

    .jobs-detail-content .jobs-detail-content-attributes {
        grid-template-columns: 1fr;
    }

    .cases-detail .cases-detail-images-nav .cases-detail-images-nav-items {
        margin: 0 -5px;
    }

    .cases-detail .cases-detail-images-main .cases-detail-images-main-items .cases-detail-images-main-item img {
        border-radius: 30px;
    }
    .cases-detail .cases-detail-images-nav .cases-detail-images-nav-items .cases-detail-images-nav-item {
        margin: 0 5px;
    }
    .cases-detail-buttons .button-group {
        flex-direction: column;
        align-items: center;
    }

    .client-carousel .client-carousel-items {
        margin: 20px 0px 50px 0px;
    }
    .client-carousel .client-carousel-items .slick-arrow {
        top: 120px;
    }

    footer {
        padding-left: 10px;
    }

    footer .footer-top::after {
        height: 60px;
        bottom: -1px;
    }

    footer .footer-top .content-box {
        padding-bottom: 80px;
    }

    footer .footer-center .footer-column {
        margin: 30px 0px;
    }

    footer .footer-bottom .footer-logo {
        margin-top: 30px;
    }

}