@charset "utf-8";
/* CSS Document */

body, html {
    margin: 0;
    padding: 0;
}

html, body, div, p, label, span, ul, li, td, th {
    font-family: 'Lato', sans-serif;
    color: black;
    font-size: 14px;
}

.anchor {
    position: absolute;
    margin-top: -150px;
}

.feedback-box {
    background-color: white;
    padding: 24px;
    text-align: center;
}
.feedback-box p{
    margin: 0;
}


.feedback-box.error {
    border: 2px solid #d53f40;
}
.feedback-box.success {
    border: 2px solid #71d53f;
}

p {
    line-height: 140%;
}

h1, h2, h3, h4 {
    font-family: 'Heebo', sans-serif;
    color: black;
    font-weight: 200;
}
h2, h3, h4 {
    font-weight: 400;
}

h1 {
    font-size: 36px;
}

.mb-1 {
    margin-bottom: 12px !important;
}
.mb-2 {
    margin-bottom: 24px !important;
}
.mb-3 {
    margin-bottom: 36px !important;
}
.mb-4 {
    margin-bottom: 48px !important;
}

.container {
    box-sizing: border-box;
    width: 100%;
    max-width: 1000px;
    align-self: center;
    margin: auto;
    padding-left: 24px;
    padding-right: 24px;
}
.container.fluid {
    max-width: 100%;
    padding-left: 24px;
    padding-right: 24px;
}
.container.smaller {
    max-width: 640px;
}

.cols {
    display: flex;
    flex-direction: row;
    width: 100%;
    flex: 1;
    justify-content: space-between;
}
.cols .col2 { width: calc(16.6% - 24px); }
.cols .col3 { width: calc(25% - 24px); }
.cols .col4 { width: calc(33.3% - 24px); }
.cols .col6 { width: calc(50% - 24px); }
.cols .col8 { width: calc(66.6% - 24px); }
.cols .col9 { width: calc(75% - 24px); }
.cols .col12 { width: 100%; }

.cols.dense .col2 { width: calc(16.6% - 12px); }
.cols.dense .col3 { width: calc(25% - 12px); }
.cols.dense .col4 { width: calc(33.3% - 12px); }
.cols.dense .col6 { width: calc(50% - 12px); }
.cols.dense .col8 { width: calc(66.6% - 12px); }
.cols.dense .col9 { width: calc(75% - 12px); }
.cols.dense .col12 { width: 100%; }

@media only screen and (max-width: 800px) {
    .cols.functions {
        flex-wrap: wrap;
    }
    .cols.functions .box {
        width: calc(50% - 12px);
        margin-bottom: 24px;
    }
}

@media only screen and (max-width: 500px) {
    .cols.functions .box {
        width: calc(100%);
    }
}

a {
    color: #024489;
    text-decoration: none;
    font-weight: bold;
}
a:hover {
    color: #003975;
}

a.dark {
    color: #a6a6a6;
    font-weight: normal;
}
a.dark:hover {
    color: #dfdfdf;
}

a.primary,
button.primary {
    display: inline-block;
    padding: 12px 18px;
    border-radius: 99px;
    background-color: #024489;
    color: white;
    font-weight: bold;
    box-shadow: 0px 1px 3px rgba(0,0,0,0.5);
    border: 0;
    font-family: 'Lato', sans-serif;
    font-size: 14px;
}
a.primary:hover,
button.primary:hover {
    cursor: pointer;
    text-decoration: none;
    background-color: #07519e;
}
a.primary.dark {
    background-color: white;
    font-weight: bold;
    color: #024489;
}
a.primary.dark:hover {
    background-color: #deeeff;
}

button:disabled,
button[disabled],
button:hover[disabled] {
    background-color: #a6a6a6;
    cursor: default;
    color: #60676f;
    box-shadow: none;
}

header {
    height: 70px;
    display: flex;
    position: sticky;
    width: 100%;
    background-color: rgba(255, 255, 255, 0.9);
    justify-content: center;
    top: 0;
    z-index: 100;
    box-shadow: 0px 1px 5px rgba(0,0,0,.2);
}
header .container {
    display: flex;
    flex-direction: row;
    align-items: center;
}
header .logo {
    margin: 0;
}
header .logo img {
    height: 25px;
}

@media only screen and (max-width: 500px) {
    #bilconsult-logo {
        display: none;
    }
}

header nav {
    flex: 1;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
header nav a {
    margin-left: 6px;
    display: inline-block;
    padding: 4px 8px;
}
header nav a.first {
    margin-left: 24px;
}
header nav a:hover {
    text-decoration: underline;
}

main {
    background-color: white;
}

main #impressum-teaser {
    height: 200px;
    position: relative;
    overflow: hidden;
}
main #impressum-teaser .parallax-window {
    min-height: 100%;
    background: transparent;
}

main #impressum-teaser .overlay-container {
    left: 0; 
    top: 0;
    position: absolute;
    text-align: center;
    display: flex;
    height: 100%;
    width: 100%;
    justify-content: center;
    align-items: center;
    background-color: rgba(2, 68, 137, .5);
}

main #impressum-teaser .overlay-container h1 {
    color: white;
    text-shadow: 0px 1px 3px rgba(0,0,0,.3);
}

main #main-teaser {
    height: 750px;
    position: relative;
    overflow: hidden;
}

main #main-teaser .container {
    bottom: 48px;
    left: 0; 
    right: 0; 
    margin-left: auto; 
    margin-right: auto; 
    position: absolute;
}

main #main-teaser .pipe {
    background-color: #024489;
    border-radius: 999px;
    position: absolute;
    transform: rotate(-30deg);
}

main #main-teaser .pipe1 {
    opacity: .2;
    width: 1000px;
    height: 350px;
    left: -400px;
    bottom: -200px;
}
main #main-teaser .pipe2 {
    opacity: .5;
    width: 1800px;
    height: 100px;
    left: -1500px;
    bottom: -200px;
}

main #main-teaser .container .overlay {
    border-radius: 5px;
    background-color: rgba(2,68,137,0.8);
    width: 50%;
    box-sizing: border-box;
    padding: 24px 30px;
}
@media only screen and (max-width: 800px) {
    main #main-teaser {
        height: 500px;
    }
    
    main #main-teaser .container .overlay {
        width: 100%;
    }
}

main #main-teaser .container .overlay .headline {
    margin-top: 10px;
    margin-bottom: 20px;
}
main #main-teaser .container .square {
    position: absolute;
    border-radius: 5px;
    background-color: #024489;
}
main #main-teaser .container .square.square1 {
    opacity: .7;
    width: 100px;
    height: 100px;
    left: -90px;
    top: -24px;
    animation: float 6s ease-in-out infinite;
}
main #main-teaser .container .square.square2 {
    opacity: .6;
    width: 75px;
    height: 75px;
    left: 24px;
    top: -90px;
    animation: float 5s ease-in-out infinite;
}
main #main-teaser .container .square.square3 {
    opacity: .5;
    width: 45px;
    height: 45px;
    left: -45px;
    top: -116px;
    animation: float 4s ease-in-out infinite;
}
main #main-teaser .container .overlay h1 {
    color: white;
    margin-top: 0px;
    margin-bottom: 0.5em;
}
main #main-teaser .container .overlay p {
    color: white;
    font-size: 16px;
}
main #main-teaser .container .overlay a {
    margin-top: 16px;
}
main #main-teaser .parallax-window {
    min-height: 100%;
    background: transparent;
}

main .features {
    padding: 48px 0px;
    border-bottom: 2px solid #E5E5E5;
}

main .features:last-of-type {
    border-bottom: 0;
}

main .features .box h2 {
    margin-bottom: 0;
}
main .features .headline {
    margin-bottom: 48px;
}

main .features .headline h1 {
    text-align: center;
    color: #60676f;
    margin-top: 0px;
    margin-bottom: 0;
}
main .features .headline.dark h1 {
    color: white;
}
main .features .headline.dense {
    margin-bottom: 24px;
}
main .features .headline.dense h1 {
    font-size: 24px;
}

main .features .headline img.kondis {
    height: 0.8em;
}
main .features .headline .sub-headline {
    max-width: 500px;
    font-size: 16px;
    color: #949494;
    text-align: center;
    margin-bottom: 18px;
    margin: 0 auto;
}
main .features .headline.dark .sub-headline {
    color: white;
}

.text-box {
    margin-bottom: 48px;
}
.text-box.reverse {
    flex-direction: row-reverse;
}
.text-box .image {
    display: flex;
    justify-content: center;
    align-items: center;
}
.text-box .text {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
}
.text-box.reverse .text {
    align-items: flex-end;
}
.text-box .text > div {
    border-radius: 5px;
    background-color: #efefef;
    padding: 12px 24px;
    position: relative;
}

.text-box .text .arrow {
    display: block;
    position: absolute;
    width: 0; 
    height: 0; 
    border-top: 20px solid transparent;
    border-bottom: 20px solid transparent; 
    border-right:20px solid #efefef; 
    top: 0;
    bottom: 0;
    margin: auto 0;
    left: -20px;
}
.text-box.reverse .text .arrow {
    border-right: 20px solid transparent;
    border-left:20px solid #efefef;
    left: auto;
    right: -40px;
}
.text-box .image-link {
    transition: all .2s ease-out;
    box-shadow: 0px 0px 0px rgba(0,0,0,0);
}
.text-box .image-link:hover {
    transform: scale(1.05);
    box-shadow: 0px 5px 10px rgba(0,0,0,.1);
}
.text-box .image-link img {
    display: block;
}

.box {
    background: #efefef;
    border-radius: 5px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    text-align: center;
    box-sizing: border-box;
    padding: 24px;
    transition: background-color .2s ease-out;
}
.box:hover {
    background: #e4e4e4;
}
.box .icon {
    width: 114px;
    height: 114px;
    margin-top: 24px;
    margin-bottom: 24px;
	transform: translatey(0px);
	animation: float 6s ease-in-out infinite;
}

.slick-prev:before, .slick-next:before {
    color: #024489 !important;
}

.case-studies {
    background-color: #f7f7f7;
}
.case-study {
    height: 350px;
    background-color: #EDEDED;
    position: relative;
    border-radius: 5px;
    overflow: hidden;
}
.case-study .fab {
    position: absolute;
    right: 24px;
    bottom: 24px;
}

.case-study .text h1 {
    color: white;
    text-align: left;
}
.case-study .text p,
.case-study .text li {
    color: white;
}
.case-study .text li {
    margin-bottom: 5px;
}
.case-study .image {
    width: 100%;
    height: 100%;
}
.case-study .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.case-studies2 .case-study {
    height: 500px;
    border-radius: 0;
    opacity: 1;
    transform: scale(1);
}
.case-studies2 .case-study .container {
    position: absolute;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    left: 0;
    right: 0;
    margin-left: auto; 
    margin-right: auto;
    bottom: 0;
    height: 100%;
}
.case-studies2 .case-study h1 {
    margin-top: 0;
    margin-bottom: 12px;
    font-size: 32px;
}
.case-studies2 .text {
    border-radius: 5px;
    position: relative;
    width: 400px;
    background-color: rgba(0,0,0,0.7);
    margin: 48px;
    margin-left: 0;
    padding: 36px;
}
.case-studies2 .text.full {
    width: 100%;
    margin-right: 0;
}

.case-studies2 .text .quote {
    width: 48px;
    height: 48px;
    position: absolute;
    animation: slight-float 4s infinite;
}
.case-studies2 .text .quote.start {
    top: -18px;
    left: -18px;
}
.case-studies2 .text .quote.end {
    right: -18px;
    bottom: -18px;
    transform: rotate(180deg);
}
.case-studies2 .case-study .fab {
    position: absolute;
    right: 36px;
    bottom: 36px;
}

.case-studies2 .flex {
    display: flex;
    flex-direction: row;
}
.case-studies2 .flex .flex-item:first-child {
    flex-shrink: 1;
    margin-right: 24px;
}
.case-studies2 .flex .flex-item:last-child {
    flex: 1;
}

@media only screen and (max-width: 800px) {
    .case-studies2 .text {
        width: 100%;
        margin-right: 0;
    }
}


.slideshow2 {
    margin-bottom: 56px !important;
}
.slideshow2 .slick-dots {
    bottom: -40px !important;
}

.slideshow2 .slick-dots {
    bottom: -40px !important;
}

.slideshow2 .slick-next,
.slideshow2 .slick-prev {
    width: 50px;
    height: 50px;
    z-index: 1;
}
.slideshow2 .slick-next {
    right: 25px;
}
.slideshow2 .slick-prev {
    left: 25px;
}
.slideshow2 .slick-prev:before,
.slideshow2 .slick-next:before {
    font-size: 48px;
}

section.contact {
    background-color: #efefef;
}

section.cta {
    height: 350px;
    position: relative;
    overflow: hidden;
    padding: 0;
}
section.cta .parallax-window {
    min-height: 100%;
    background: transparent;
}

section.cta .container {
    position: absolute;
    margin: 0 auto;
    left: 0;
    right: 0;
    top: 48px;
    z-index: 1;
}

.contact-boxes {
    border: 1px solid rgba(255,255,255,.5);
    display: flex;
    border-radius: 5px;
    /* background-color: rgba(255, 255, 255, 0.5); */
    overflow: hidden;
}
.contact-boxes .contact-box {
    flex: 1;
    padding: 20px;
    border-right: 1px solid rgba(255,255,255,.5);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: background-color .2s ease-out;
}
.contact-boxes .contact-box:hover {
    background-color: rgba(0,0,0,.1);
}
.contact-boxes .contact-box:last-child {
    border-right: 0;
}
@media only screen and (max-width: 800px) {
    section.cta {
        height: 460px;
    }
    .contact-boxes {
        flex-direction: column;
    }
    .contact-boxes .contact-box {
        border-bottom: 1px solid rgba(255,255,255,.5);
    }
    .contact-boxes .contact-box:last-child {
        border-bottom: 0;
    }
}

.contact-box > div {
    display: flex;
}
.contact-box .icon {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 24px;
    text-align: center;
}
.contact-box .text {
    display: flex;
    align-items: center;
}
.contact-box .text span {
    color: rgba(255,255,255,.8);
}
.contact-boxes .contact-box:hover .text span {
    color: white;
}
.contact-box .text p {
    margin-top: 0;
}


.contact-form .input {
    display: flex;
    flex-direction: column;
}

.contact-form .input.checkbox {
    flex-direction: row;
}

.contact-form .input label {
    text-transform: uppercase;
    font-weight: bold;
    color: #60676f;
    margin-bottom: 3px;
}

.contact-form .input label .req {
    color: #60676f;
    opacity: .7;
}

.contact-form .cols {
    margin-bottom: 24px;
}

.contact-form .input input[type=checkbox] {
    margin-right: 6px;
}

.contact-form .input select,
.contact-form .input input[type=text],
.contact-form .input input[type=email],
.contact-form .input textarea {
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
    background-color: white;
    border: 2px solid rgba(0,0,0,.3);
    border-radius: 3px;
    transition: border .2s ease-out;
}
.contact-form .input select:hover,
.contact-form .input input[type=text]:hover,
.contact-form .input textarea:hover {
    border-color: rgba(0,0,0,.5);
}

.contact-form .input select:focus,
.contact-form .input input[type=text]:focus,
.contact-form .input textarea:focus {
    border-color: #024489;
}

.contact-form .meta {
    text-align: left;
    font-size: 12px;
    opacity: .7;
}



footer {
    position: relative;;
    border-top: 2px rgba(0,0,0,.5);
    padding: 32px 0px;
    background: url("../assets/footer-bg.gif");
    background-attachment: fixed;
}
footer .shadow {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 20px;
    background: linear-gradient(180deg, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0) 100%);
}

footer p {
    text-align: center;
    color: #7E7E7E;
}

footer p b {
    color: #949494;;
}
footer .container {
    display: flex;
    flex-direction: column;
    align-items: center;
}
footer .copyright {
    width: 100%;
    border-top: 2px solid rgba(0,0,0,.2);
    text-align: center;
    margin-top: 24px;
    padding-top: 18px;
    color: #7E7E7E;
}
footer h3 {
    margin-top: 0;
    color: white;
    font-size: 14px;
}
footer ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
footer ul li {
}
footer ul li a {
    color: #9B9B9B;
    display: inline-block;
    line-height: 150%;
}
footer ul li a:hover {
    color: #DCDCDC;
}

footer .col3 {
    border-left: 1px solid rgba(255, 255, 255, 0.15);
    padding-left: 24px;
}

/** Animations */
@keyframes float {
	0% { transform: translatey(0px); }
	50% { transform: translatey(-12px);	}
	100% { transform: translatey(0px); }
}
@keyframes slight-float {
	0% { transform: translatey(0px); }
	50% { transform: translatey(-8px);	}
	100% { transform: translatey(0px); }
}