#paginator.loading,
.paginator.loading {
    position: relative;
}
#paginator.loading .output,
.paginator.loading .output {
    opacity: 0.4;
}
#paginator.loading:before,
.paginator.loading:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 70px;
    height: 70px;
    background: url(images/loading.svg) no-repeat;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}
#paginator,
.paginator {
    min-height: 250px;
}
#paginator .paginationjs,
.paginator .paginationjs {
    position: relative;
    width: 220px;
    text-align: center;
    margin: 30px auto 0;
}
#paginator .paginationjs-pages,
.paginator .paginationjs-pages {
    margin: 0 auto;
    float: none;
    width: 100%;
    overflow: hidden;
}
#paginator .paginationjs-pages ul,
.paginator .paginationjs-pages ul {
    display: block;
    width: 100%;
    list-style: none;
    margin: 0;
    padding: 0;
}
#paginator .paginationjs-pages ul li,
.paginator .paginationjs-pages ul li {
    border: none !important;
    float: right;
}
#paginator .paginationjs-pages ul li a,
.paginator .paginationjs-pages ul li a {
    position: relative;
    left: 0;
    right: 0;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
    text-indent: -9999px;
    overflow: hidden;
    background: url(images/arrow.svg);
    background-repeat: no-repeat !important;
    -webkit-background-size: 16px 15px !important;
    -moz-background-size: 16px 15px !important;
    -o-background-size: 16px 15px !important;
    background-size: 16px 15px !important;
    background-position: 50% 50% !important;
}
#paginator .paginationjs-pages ul li a:hover,
.paginator .paginationjs-pages ul li a:hover {
    background: url(images/arrow.svg);
}
#paginator .paginationjs-pages ul li.paginationjs-prev,
.paginator .paginationjs-pages ul li.paginationjs-prev {
    float: left;
}
#paginator .paginationjs-pages ul li.paginationjs-prev a,
.paginator .paginationjs-pages ul li.paginationjs-prev a {
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg);
}
#paginator .paginationjs-pages ul li.disabled,
.paginator .paginationjs-pages ul li.disabled {
    opacity: 0;
}
#paginator .paginationjs-pages ul li:first-child,
.paginator .paginationjs-pages ul li:first-child {
    margin-right: 100px;
}
#paginator .paginationjs-nav,
.paginator .paginationjs-nav {
    position: absolute;
    left: 50%;
    top: 0;
    margin: 0;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
}
.arrow:after,
a.button:before {
    content: "";
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
}
.arrow:after,
a.button:after {
    top: 50%;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
}
body,
h2,
h3 {
    font-weight: 400;
}
.clear,
.wrap {
    clear: both;
}
.slider_button:hover,
a.button {
    cursor: pointer;
}
a,
a:active,
a:focus,
a:visited,
button[type="submit"]:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="submit"]:focus,
textarea:focus {
    outline: 0;
}
body {
    font-family: Roboto, sans-serif, Arial, Helvetica, Verdana;
    font-size: 16px;
    line-height: 1.4;
    margin: 0;
    padding: 115px 0 0;
    background: #fff;
    color: #014051;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
body.home {
    padding-top: 0;
}
html {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
*,
:after,
:before {
    -webkit-box-sizing: inherit;
    -moz-box-sizing: inherit;
    box-sizing: inherit;
}
.sr .reveal {
    visibility: hidden;
}
.chromeframe {
    margin: 0.2em 0;
    background: #f6ff94;
    color: #000;
    padding: 0.2em 0;
    text-align: center;
}
.jsflag {
    display: none;
}
.no-js .jsflag {
    display: block;
}
a {
    color: #014051;
    text-decoration: none;
}
p a {
    color: #61d8ca;
}
a.button,
p a:hover {
    color: #014051;
}
.arrow {
    position: relative;
    padding-right: 20px;
}
.arrow:after {
    background-image: url(images/arrow_link.svg);
    background-position: center;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
    width: 4.5px;
    height: 16px;
    position: absolute;
    right: 0;
    transform: translateY(-50%);
    transition: all 0.3s ease-in-out;
}
.arrow:hover:after {
    right: -5px;
}
a.button {
    display: inline-block;
    padding: 12px 35px 12px 24px;
    height: 45px;
    background: #afece9;
    letter-spacing: 1px;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
    position: relative;
}
a.button.dark {
    background: #014051;
    color: #fff;
}
a.button.dark:before {
    border-color: transparent transparent transparent #014051;
}
a.button.dark:after {
    background-image: url(images/arrow_link_white.svg);
}
a.button:hover:after {
    right: 10px;
}
a.button:before {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 100%;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 22.5px 0 22.5px 8px;
    border-color: transparent transparent transparent #afece9;
}
#main_header a.logo,
a.button:after {
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
}
a.back_to:before,
a.button:after {
    height: 16px;
    content: "";
}
a.button:after {
    background-image: url(images/arrow_link_dark.svg);
    background-position: center;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
    width: 4.5px;
    position: absolute;
    right: 15px;
    transform: translateY(-50%);
    transition: all 0.3s ease-in-out;
}
a.button.button_white {
    color: #333;
    background: #fff;
    border: 4px solid #fff;
}
a.button.button_white:hover {
    color: #fff;
    background: 0 0;
}
a.button.button_small {
    padding: 6px 20px;
    font-size: 12px;
}
a.back_to {
    margin-bottom: 30px;
    padding-left: 20px;
    display: block;
    position: relative;
    font-size: 16px;
}
a.back_to:before {
    background-image: url(images/arrow_link_dark.svg);
    background-position: center;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
    position: absolute;
    top: 2px;
    width: 5px;
    left: 0;
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg);
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}
a.back_to:hover:before {
    left: -4px;
}
img {
    max-width: 100%;
    height: auto;
}
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: Roboto, sans-serif;
    margin: 0;
}
h1.has_seperator,
h2.has_seperator,
h3.has_seperator,
h4.has_seperator,
h5.has_seperator,
h6.has_seperator {
    margin-bottom: 40px;
    position: relative;
}
h1.has_seperator:after,
h2.has_seperator:after,
h3.has_seperator:after,
h4.has_seperator:after,
h5.has_seperator:after,
h6.has_seperator:after {
    content: "";
    position: absolute;
    bottom: -20px;
    left: 0;
    width: 24px;
    height: 1px;
    background: #014051;
}
h1 {
    font-size: 2.125em;
    line-height: 1.2;
    margin-bottom: 40px;
}
@media (max-width: 700px) {
    h1 {
        font-size: 1.7em;
    }
}
h2 {
    font-size: 1.75em;
}
@media (max-width: 700px) {
    h2 {
        font-size: 1.4em;
    }
}
h3 {
    font-size: 1.25em;
}
#main_header #nav_main ul li a,
.bold {
    font-weight: 700;
}
.wrap {
    width: 100%;
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 80px;
}
.inner_wrap {
    max-width: 740px;
    margin: 0 auto;
}
.videoWrapper {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 25px;
    height: 0;
}
.videoWrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
a.download {
    display: block;
    margin-top: 13px;
    padding-left: 25px;
    position: relative;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}
#main_header,
#main_header a.logo img {
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
}
a.download:before {
    content: "";
    position: absolute;
    left: 0;
    top: 2px;
    width: 18px;
    height: 17px;
    background: url(images/download.svg) no-repeat;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
}
a.download:hover {
    color: #61d8ca;
}
.dotbar {
    height: 26px;
    width: 200px;
    background: url(images/dot_tuerkis.svg);
    position: absolute;
    bottom: -18px;
    left: -20px;
    z-index: -1;
}
.dotbar.links_unten_druber,
.dotbar.rechts_unten_druber {
    z-index: 10;
}
.dotbar.rechts_unten,
.dotbar.rechts_unten_druber {
    left: auto;
    right: -20px;
}
#main_header {
    background: 0 0;
    height: 115px;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 200;
    transition: all 0.3s ease-in-out;
}
#main_header.fixed {
    background: #fff;
    height: 70px;
}
#main_header.fixed a.logo {
    margin-top: 4px;
}
#main_header.fixed a.logo img {
    height: 45px;
}
#main_header.fixed #nav_sub {
    margin-top: 5px;
    margin-bottom: 0;
}
#main_header #menu-trigger {
    display: none;
}
#main_header #nav_sub .search_area,
#main_header div.main_header_wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
}
#main_header div.main_header_wrap {
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -moz-box-orient: vertical;
    -moz-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
    height: 100%;
}
#main_header a.logo {
    position: absolute;
    right: 80px;
    top: 50%;
    transform: translateY(-50%);
    display: block;
    height: 50px;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}
#main_header a.logo img {
    height: 60px;
    transition: all 0.3s ease-in-out;
}
#main_header a.logo:hover {
    opacity: 0.75;
}
#main_header #nav_main,
#main_header #nav_sub {
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}
#main_header #nav_main ul,
#main_header #nav_sub ul {
    padding: 0;
    margin: 0;
}
#main_header #nav_main ul li,
#main_header #nav_sub ul li {
    float: left;
    margin: 0 16px;
}
#main_header #nav_main ul li:first-child,
#main_header #nav_sub ul li:first-child {
    margin-left: 0;
}
#main_header #nav_main ul li a,
#main_header #nav_sub ul li a {
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}
#main_header #nav_main ul li a:hover,
#main_header #nav_sub ul li a:hover {
    color: #43baac;
}
#main_header #nav_main ul li.current-menu-item a,
#main_header #nav_main ul li.current_page_ancestor a,
#main_header #nav_sub ul li.current-menu-item a,
#main_header #nav_sub ul li.current_page_ancestor a {
    text-decoration: underline;
}
#main_header #nav_sub {
    margin-top: 25px;
    margin-bottom: 30px;
}
#main_header #nav_sub ul {
    float: left;
}
#main_header #nav_sub ul li a {
    font-size: 0.75em;
    letter-spacing: 1px;
}
#main_header #nav_sub .search_area {
    display: flex;
    float: left;
    position: relative;
    top: -3px;
    margin-left: 15px;
}
#main_header #nav_sub .search_area .search_toggle {
    width: 30px;
    height: 30px;
    margin-right: 5px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
}
#main_header #nav_sub .search_area .search_toggle:hover .svg g,
#main_header #nav_sub .search_area .search_toggle:hover .svg line {
    stroke: #afece9 !important;
}
#main_header #nav_sub .search_area input {
    width: 130px;
    padding: 0;
    border: 0;
    margin-top: 3px;
    border-bottom: 1px solid #014051;
}
#main_header #nav_sub .search_area form {
    display: none;
}
#main_header #nav_main ul li:hover ul.sub-menu,
#main_header #nav_sub .search_area form.show {
    display: block;
}
#main_header #nav_main {
    padding-bottom: 10px;
    border-bottom: 1px solid #014051;
}
#main_header #nav_main ul li {
    margin: 0 62.5px;
    position: relative;
}
#main_header #nav_main ul.sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: -20px;
    min-width: 100%;
    padding-top: 11px;
}
#main_header #nav_main ul.sub-menu li {
    margin: 0;
    display: block;
    float: none;
    background: rgba(255, 255, 255, 0.9);
}
#main_header #nav_main ul.sub-menu li a {
    display: block;
    padding: 8px 20px;
    white-space: nowrap;
    font-weight: 400;
    position: relative;
}
#main_header #nav_main ul.sub-menu li a:before {
    content: "";
    width: -webkit-calc(100% - 40px);
    width: -moz-calc(100% - 40px);
    width: calc(100% - 40px);
    position: absolute;
    top: 0;
    left: 20px;
    height: 1px;
    background: #014051;
}
#main_header #nav_main ul.sub-menu li a:hover {
    background: #afece9;
    color: #014051;
}
#main_header #nav_main ul.sub-menu li:first-child a:before {
    display: none;
}
#mobile_nav {
    position: fixed;
    top: 0;
    left: -300px;
    width: 290px;
    height: 100%;
    background: #fff;
    z-index: 100;
    padding: 100px 30px 20px;
    -webkit-box-shadow: 0 2px 10px rgba(0, 0, 0, 0.4);
    -moz-box-shadow: 0 2px 10px rgba(0, 0, 0, 0.4);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.4);
    -webkit-transition: all 0.24s ease-out;
    -o-transition: all 0.24s ease-out;
    -moz-transition: all 0.24s ease-out;
    transition: all 0.24s ease-out;
}
.slider_button.prev,
body.navShow #mobile_nav {
    left: 0;
}
#mobile_nav ul {
    margin: 0;
    padding: 0;
    list-style: none;
}
#mobile_nav ul li a {
    display: block;
    font-weight: 700;
    padding: 10px 0;
}
#mobile_nav .menu-subnavigation-container {
    border-top: 1px solid #014051;
    margin-top: 10px;
    padding-top: 10px;
}
#mobile_nav form {
    padding-left: 30px;
    position: relative;
    margin-top: 15px;
}
#mobile_nav form:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    background: url(images/search.svg) 50% 50% no-repeat;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
}
#mobile_nav form input {
    border: 0;
    border-bottom: 1px solid #014051;
    padding: 0;
    width: 100%;
}
.slider_button {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
    z-index: 50;
    width: 32px;
}
.slider_button path {
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}
.slider_button.next {
    right: 0;
    -webkit-transform: translateY(-50%) rotate(180deg);
    -moz-transform: translateY(-50%) rotate(180deg);
    -ms-transform: translateY(-50%) rotate(180deg);
    -o-transform: translateY(-50%) rotate(180deg);
    transform: translateY(-50%) rotate(180deg);
}
.slider_button:hover path {
    fill: #014051;
}
img.slider_button {
    width: 13px;
    height: auto;
}
img.slider_button.prev {
    left: 10px;
}
img.slider_button.next {
    right: 10px;
}
img.slider_button:hover {
    opacity: 0.7;
}
.lSSlideOuter .lSPager.lSpg li.active a {
    background-color: #014051;
}
.lSSlideOuter .lSPager.lSpg li a {
    height: 2px;
    width: 30px;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    background-color: #fff;
}
#main_footer {
    background: #014051;
    padding: 60px 0;
    color: #fff;
    font-size: 14px;
}
#main_footer a {
    color: #fff;
}
#main_footer a:hover {
    color: #afece9;
}
#main_footer .wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -moz-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}
#main_footer .infobox {
    position: relative;
    padding-bottom: 80px;
    margin-right: auto;
}
#main_footer .infobox .logo {
    margin-bottom: 30px;
}
#main_footer .infobox a {
    display: block;
    margin-bottom: 4px;
}
#main_footer .infobox span.copy {
    position: absolute;
    bottom: 0;
    left: 0;
}
#main_footer nav {
    margin-right: 70px;
}
#main_footer nav ul {
    margin: 0;
    padding: 0;
}
#main_footer nav ul li {
    margin: 4px 0;
}
#main_footer .first {
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    margin-bottom: 50px;
    display: block;
    position: relative;
}
#main_footer .first:after {
    content: "";
    display: block;
    position: absolute;
    width: 30px;
    height: 1px;
    bottom: -25px;
    left: 0;
    background: #fff;
}
#main_footer .link_box a {
    color: #014051;
}
button[type="submit"],
input[type="text"],
input[type="email"],
input[type="password"],
input[type="submit"],
textarea {
    background: 0 0;
    border: 1px solid #999;
    padding: 11px 15px;
    font-family: Roboto, sans-serif;
    color: #014051;
}
.caldera-grid button[type="submit"],
.caldera-grid input[type="submit"] {
    background: #014051;
    color: #fff;
    border: none;
    padding: 11px 30px;
    -webkit-transition: all 0.1s ease-out;
    -o-transition: all 0.1s ease-out;
    -moz-transition: all 0.1s ease-out;
    transition: all 0.1s ease-out;
    text-transform: uppercase;
    font-family: Roboto, sans-serif;
    font-style: normal;
    font-weight: 700;
    letter-spacing: 1px;
}
.caldera-grid button[type="submit"]:hover,
.caldera-grid input[type="submit"]:hover {
    background: #1f5e6f;
}
.field-wrap .ninja-forms-field-error {
    color: #222;
    font-weight: 400;
}
body .caldera-grid select {
    width: 100%;
    -moz-appearance: none;
    appearance: none;
    -webkit-appearance: none;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    font-size: 14px;
    padding: 10px 20px 8px 15px;
    display: block;
    background: url(images/select_arrow.svg) 93% 50% no-repeat #fff;
    color: #014051;
    border: none;
    font-family: Roboto, sans-serif;
    font-weight: 700;
    position: relative;
    outline: 0;
}
select::-ms-expand {
    display: none;
}
::-webkit-input-placeholder {
    color: #222;
}
::-moz-placeholder {
    color: #222;
    opacity: 1;
}
::-ms-input-placeholder {
    color: #222;
}

#flyout .content,
#flyout .handle {
    -moz-border-radius-bottomleft: 7px;
}
#flyout {
    position: fixed;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
    right: -360px;
    -webkit-transition: all 0.3s ease-out;
    -o-transition: all 0.3s ease-out;
    -moz-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
    z-index: 1000;
}
#flyout:hover {
    right: 0;
}
#flyout:hover .content {
    -webkit-box-shadow: -1px 3px 10px rgba(0, 0, 0, 0.4);
    -moz-box-shadow: -1px 3px 10px rgba(0, 0, 0, 0.4);
    box-shadow: -1px 3px 10px rgba(0, 0, 0, 0.4);
}
#flyout .handle {
    width: 60px;
    height: 50px;
    position: absolute;
    background: #fff;
    left: -60px;
    top: 0;
    -webkit-border-bottom-left-radius: 7px;
    border-bottom-left-radius: 7px;
    -webkit-border-top-left-radius: 7px;
    -moz-border-radius-topleft: 7px;
    border-top-left-radius: 7px;
    -webkit-box-shadow: -1px 3px 10px rgba(0, 0, 0, 0.4);
    -moz-box-shadow: -1px 3px 10px rgba(0, 0, 0, 0.4);
    box-shadow: -1px 3px 10px rgba(0, 0, 0, 0.4);
    cursor: pointer;
}
#flyout .handle:before {
    content: "";
    display: block;
    width: 40px;
    height: 30px;
    position: absolute;
    top: 50%;
    left: 12px;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
    background: url(images/mail_color.svg) no-repeat;
    background-position: 50% 50% !important;
    -webkit-background-size: contain !important;
    -moz-background-size: contain !important;
    -o-background-size: contain !important;
    background-size: contain !important;
}
#flyout .content a.kontakt:before,
#flyout .handle:after {
    content: "";
    display: block;
    top: 0;
}
#flyout .handle:after {
    position: absolute;
    right: -15px;
    height: 100%;
    width: 15px;
    background: #fff;
}
#flyout .content {
    background: #fff;
    padding: 30px;
    width: 360px;
    -webkit-border-bottom-left-radius: 7px;
    border-bottom-left-radius: 7px;
}
#flyout .content .titel {
    font-weight: 700;
    margin-bottom: 30px;
}
#flyout .content a.kontakt {
    display: block;
    margin-bottom: 15px;
    position: relative;
    padding-left: 43px;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}
#flyout .content a.kontakt:hover {
    color: #61d8ca;
}
#flyout .content a.kontakt:before {
    width: 30px;
    height: 20px;
    position: absolute;
    left: 0;
    background: url(images/mail.svg) no-repeat;
    background-position: 50% 50% !important;
    -webkit-background-size: contain !important;
    -moz-background-size: contain !important;
    -o-background-size: contain !important;
    background-size: contain !important;
}
#flyout .content a.kontakt.telefon:before {
    height: 26px;
    top: -2px;
    background: url(images/phone.svg) no-repeat;
}
#flyout .content .button {
    margin-top: 15px;
    margin-bottom: 0;
}
@media (max-width: 600px) {
    #flyout {
        top: auto;
        bottom: 0;
        -webkit-transform: none;
        -moz-transform: none;
        -ms-transform: none;
        -o-transform: none;
        transform: none;
        right: -300px;
    }
    #flyout .handle {
        top: auto;
        bottom: 0;
        -webkit-border-bottom-left-radius: 0;
        -moz-border-radius-bottomleft: 0;
        border-bottom-left-radius: 0;
        width: 50px;
        height: 40px;
        left: -50px;
    }
    #flyout .handle:before {
        left: 9px;
        width: 34px;
        height: 20px;
    }
    #flyout .content {
        width: 300px;
    }
}
.produkt_content {
    padding: 90px 0;
}
#produkt_modal {
    position: fixed;
    top: 130%;
    left: 0;
    height: 100%;
    width: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    z-index: 999999;
    background: #fff;
    -webkit-transition: 0.4s ease-out;
    -o-transition: 0.4s ease-out;
    -moz-transition: 0.4s ease-out;
    transition: 0.4s ease-out;
}
#produkt_modal #close_produkt_modal {
    position: absolute;
    right: 25px;
    top: 25px;
    cursor: pointer;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}
#produkt_modal #close_produkt_modal:hover {
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -ms-transform: scale(1.2);
    -o-transform: scale(1.2);
    transform: scale(1.2);
}
#produkt_modal .loader {
    display: none;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}
#produkt_modal .loader svg {
    width: 80px;
    height: 80px;
}
#produkt_modal.loading .loader {
    display: block;
}
body.show_produkt_modal {
    overflow: hidden;
}
body.show_produkt_modal #produkt_modal {
    top: 0;
}
.produkt_template {
    padding: 60px 0;
}
.produkt_template h1 {
    color: #61d8ca;
}
.produkt_template img.print_logo {
    margin-bottom: 40px;
    display: none;
}
.produkt_template img.print_img {
    display: none;
}
.produkt_template .produkt_header {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.produkt_template .produkt_header .spalte {
    width: 50%;
}
.produkt_template .produkt_header .spalte.rechts {
    padding-left: 50px;
}
.produkt_template .produkt_header .button.print {
    padding-left: 55px;
    letter-spacing: 1px;
}
.produkt_template .produkt_header .button.print img {
    position: absolute;
    top: 10px;
    left: 15px;
    height: 26px;
    width: auto;
}
.produkt_template .produkt_header .downloads {
    margin-top: 20px;
}
.produkt_template .produkt_header .slider_wrapper {
    position: relative;
    padding: 25px 40px;
    -webkit-box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.3);
    -moz-box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.3);
    box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.3);
}
.produkt_template .produkt_header .slider_wrapper img {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    height: auto;
}
.produkt_template .produkt_header .slider_wrapper .caption {
    margin-top: 14px;
    font-size: 0.8em;
    text-align: center;
}
.produkt_template .produkt_header .slider_wrapper .slider_button path {
    fill: #61d8ca;
}
.produkt_template .produkt_header .slider_wrapper .slider_button:hover path {
    fill: #014051;
}
.produkt_template .produkt_header .slider_wrapper .lSPager.lSpg {
    position: absolute;
    width: 100%;
    bottom: -30px;
    left: 50%;
    -webkit-transform: translateX(-50%) !important;
    -moz-transform: translateX(-50%) !important;
    -ms-transform: translateX(-50%) !important;
    -o-transform: translateX(-50%) !important;
    transform: translateX(-50%) !important;
}
.produkt_template .produkt_header .slider_wrapper .lSPager.lSpg > li a {
    background: #61d8ca;
}
.produkt_template .produkt_header .slider_wrapper .lSPager.lSpg > li.active a {
    background: #014051;
}
.produkt_template .produkt_header .produkt_intro {
    margin-top: 80px;
}
.produkt_template .produkt_features {
    margin-top: 60px;
}
.produkt_template .produkt_features .features_wrapper {
    margin-top: 30px;
    -webkit-column-count: 2;
    -moz-column-count: 2;
    column-count: 2;
}
.produkt_template .produkt_features .features_wrapper ul {
    display: block;
    list-style: none;
    margin: 0;
    padding: 0;
}
.produkt_template .produkt_features .features_wrapper ul li:before {
    content: "";
    display: block;
    position: absolute;
    top: 3px;
    left: 0;
    width: 20px;
    height: 16px;
    background: url(images/list_arrow.svg) no-repeat;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
}
.produkt_template .produkt_features .features_wrapper ul li {
    padding-left: 18px;
    margin-bottom: 14px;
    max-width: 90%;
    position: relative;
}
.produkt_template .produk_details {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 60px;
    padding-top: 50px;
    border-top: 1px solid #014051;
}
.produkt_template .produk_details h3 {
    font-size: 28px;
    margin-bottom: 30px;
}
.produkt_template .produk_details .spalte {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
}
.produkt_template .produk_details .liste .item {
    margin-bottom: 20px;
}
.produkt_template .produk_details .liste .item strong {
    display: block;
}
@media (max-width: 600px) {
    .produkt_template .produkt_header .spalte {
        width: 100%;
    }
    .produkt_template .produkt_header .spalte.rechts {
        padding-left: 0;
        margin-top: 30px;
    }
    .produkt_template .produkt_features .features_wrapper {
        -webkit-column-count: 1;
        -moz-column-count: 1;
        column-count: 1;
    }
    .produkt_template .produk_details .spalte {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 100%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
    }
    .produkt_template .produk_details .spalte.rechts {
        margin-top: 30px;
    }
}
@media print {
    #close_produkt_modal,
    #flyout,
    #main_footer,
    #main_header,
    #produkt_modal,
    .produkt_template a.back_to {
        display: none;
    }
    body {
        padding-top: 0;
    }
    .produkt_template {
        padding-top: 0;
        font-size: 12px;
    }
    .produkt_template h1 {
        margin-top: 0;
    }
    .produkt_template img.print_img,
    .produkt_template img.print_logo {
        display: block;
        max-height: 200px;
        width: auto;
    }
    .produkt_header .slider_wrapper,
    .produkt_header .spalte.rechts {
        display: none;
    }
    .produkt .produkt_features .features_wrapper {
        -webkit-column-count: 1;
        -moz-column-count: 1;
        column-count: 1;
        page-break-after: always;
    }
    ul {
        list-style: disc !important;
    }
    ul li {
        max-width: none !important;
        padding-left: 0 !important;
    }
    ul li:before {
        display: none !important;
    }
    .produkt_template .produk_details .liste .item,
    .produkt_template .produkt_features .features_wrapper ul li {
        margin-bottom: 8px;
    }
}
.suchergebnisse {
    padding: 50px 0;
}
.suchergebnisse h1 {
    color: #61d8ca;
}
.suchergebnisse .trennlinie {
    height: 1px;
    background: #014051;
    margin: 40px 0;
}
.suchergebnisse .ergebnis {
    margin-bottom: 60px;
}
.suchergebnisse .ergebnis .button {
    margin-top: 20px;
}
.produkt_kategorie {
    padding: 70px 0;
}
.produkt_kategorie .kategorie_intro {
    max-width: 740px;
    margin: 0 auto;
    font-size: 1.25em;
    padding-top: 20px;
    padding-bottom: 80px;
}
.produkt_kategorie .kategorie_intro h1,
.produkt_kategorie .kategorie_intro h2 {
    font-size: 1.8em;
    color: #61d8ca;
}
.produkt_kategorie .sub_kategorie {
    border-top: 1px solid #014051;
    padding: 50px 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}
.produkt_kategorie .sub_kategorie .name {
    font-size: 1.6em;
    width: 400px;
    margin-right: 50px;
}
.produkt_kategorie .sub_kategorie .produkte {
    padding: 5px 0;
    width: 300px;
}
.produkt_kategorie .sub_kategorie .produkte .produkt {
    display: block;
    font-weight: 700;
    font-size: 20px;
    margin-bottom: 20px;
    position: relative;
    padding-right: 30px;
    width: 230px;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}
.produkt_kategorie .sub_kategorie .produkte .produkt span {
    display: block;
    position: absolute;
    top: 0;
    right: 10px;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
    color: #61d8ca;
}
.produkt_kategorie .sub_kategorie .produkte a.produkt:hover {
    color: #61d8ca;
}
.produkt_kategorie .sub_kategorie .produkte a.produkt:hover span {
    -webkit-transform: scale(1.3);
    -moz-transform: scale(1.3);
    -ms-transform: scale(1.3);
    -o-transform: scale(1.3);
    transform: scale(1.3);
}
.produkt_kategorie .sub_kategorie .bild_wrapper {
    position: relative;
    width: 230px;
    padding: 0 10px;
    background: #fff;
}
.produkt_kategorie .sub_kategorie .bild_wrapper.active {
    z-index: 100;
}
.produkt_kategorie .sub_kategorie .bild_wrapper img {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: auto;
}
@media (max-width: 800px) {
    .produkt_kategorie {
        padding: 20px 0 50px;
    }
    .produkt_kategorie .sub_kategorie {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    .produkt_kategorie .sub_kategorie .name {
        margin-bottom: 40px;
    }
    .produkt_kategorie .sub_kategorie .bild_wrapper {
        display: none;
    }
}
div.template_startseite section.startseite_header {
    height: 100vh;
    background-position: center !important;
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -moz-box-orient: vertical;
    -moz-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -moz-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}
div.template_startseite section.startseite_header .slider_bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}
div.template_startseite section.startseite_header .slider_bg .lSSlideOuter,
div.template_startseite section.startseite_header .slider_bg .lSSlideWrapper,
div.template_startseite section.startseite_header .slider_bg .lightSlider {
    height: 100% !important;
}
div.template_startseite section.startseite_header .slider_bg li {
    height: 100%;
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
    background-position: 50% 50% !important;
}
div.template_startseite section.startseite_header div.header_text_wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -moz-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    margin-bottom: 30px;
    max-width: 1400px;
    position: relative;
    z-index: 10;
}
div.template_startseite section.startseite_header div.header_text_wrap div.header_text {
    font-size: 2.125em;
    line-height: 1.2;
    width: -webkit-calc((100% - 4px)/ 3);
    width: -moz-calc((100% - 4px)/ 3);
    width: calc((100% - 4px) / 3);
    max-width: 400px;
}
@media (max-width: 700px) {
    div.template_startseite section.startseite_header div.header_text_wrap div.header_text {
        font-size: 1.7em;
    }
}
div.template_startseite section.startseite_header div.header_panel_wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
    z-index: 10;
}
div.template_startseite section.startseite_header div.header_panel_wrap div.header_panel {
    background: #014051;
    color: #fff;
    width: -webkit-calc((100% - 4px)/ 3);
    width: -moz-calc((100% - 4px)/ 3);
    width: calc((100% - 4px) / 3);
    padding: 20px 30px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -moz-box-orient: vertical;
    -moz-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}
div.template_startseite section.startseite_header div.header_panel_wrap div.header_panel div.text {
    margin-bottom: 15px;
}
div.template_startseite section.startseite_header div.header_panel_wrap div.header_panel div.link a {
    color: #61d8ca;
}
@media (max-width: 800px) {
    div.template_startseite section.startseite_header {
        height: auto;
        min-height: 100vh;
        padding-top: 200px;
    }
    div.template_startseite section.startseite_header div.header_text_wrap {
        display: none;
    }
    div.template_startseite section.startseite_header div.header_panel_wrap {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    div.template_startseite section.startseite_header div.header_panel_wrap div.header_panel {
        width: 100%;
        margin-top: 2px;
    }
}
.alignnone {
    margin: 5px 20px 20px 0;
}
.aligncenter,
div.aligncenter {
    display: block;
    margin: 5px auto;
}
.alignright {
    float: right;
    margin: 5px 0 10px 20px;
}
.alignleft {
    float: left;
    margin: 5px 20px 10px 0;
}
.aligncenter {
    display: block;
    margin: 5px auto;
}
a img.alignright {
    float: right;
    margin: 5px 0 10px 20px;
}
a img.alignleft,
a img.alignnone {
    margin: 5px 20px 10px 0;
}
a img.alignleft {
    float: left;
}
a img.aligncenter {
    display: block;
    margin-right: auto;
    margin-left: auto;
}
.wp-caption {
    padding: 5px 3px 10px;
    max-width: 96%;
    border: 1px solid #f0f0f0;
    background: #fff;
    text-align: center;
}
.wp-caption.alignleft,
.wp-caption.alignnone {
    margin: 5px 20px 20px 0;
}
.wp-caption.alignright {
    margin: 5px 0 20px 20px;
}
.wp-caption img {
    margin: 0;
    padding: 0;
    max-width: 98.5%;
    width: auto;
    height: auto;
    border: 0;
}
.wp-caption p.wp-caption-text {
    margin: 0;
    padding: 0 4px 5px;
    font-size: 11px;
    line-height: 17px;
}
section.modul {
    clear: both;
}
section.modul.modul_2_spalten .wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -moz-box-orient: horizontal;
    -moz-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
section.modul.modul_2_spalten .spalte {
    width: 48%;
}
section.modul.modul_2_spalten .spalte p:first-child {
    margin-top: 0;
}
section.modul.modul_2_spalten .spalte img {
    max-width: 100%;
    height: auto;
    margin-top: 0;
}
@media screen and (max-width: 650px) {
    section.modul.modul_2_spalten .spalte {
        width: 100%;
    }
}
section.bild_mit_text {
    padding: 70px 0;
}
section.bild_mit_text div.block {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 40px;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
section.bild_mit_text div.block:last-child {
    margin-bottom: 0;
}
section.bild_mit_text div.block:nth-child(2n) div.img {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
    -moz-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
}
section.bild_mit_text div.block:nth-child(2n) div.content {
    padding-left: 0;
    padding-right: 100px;
}
section.bild_mit_text div.block div.img {
    -webkit-flex-basis: 49%;
    -ms-flex-preferred-size: 49%;
    flex-basis: 49%;
    height: 350px;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    background-position: center;
    position: relative;
}
section.bild_mit_text div.block div.content {
    -webkit-flex-basis: 49%;
    -ms-flex-preferred-size: 49%;
    flex-basis: 49%;
    padding-left: 100px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -moz-box-orient: vertical;
    -moz-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
@media (max-width: 840px) {
    section.bild_mit_text div.block div.content {
        padding-left: 20px;
    }
}
@media (max-width: 640px) {
    section.bild_mit_text div.block {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    section.bild_mit_text div.block div.img {
        -webkit-flex-basis: 100%;
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        -webkit-box-ordinal-group: 3 !important;
        -webkit-order: 2 !important;
        -moz-box-ordinal-group: 3 !important;
        -ms-flex-order: 2 !important;
        order: 2 !important;
        margin-top: 20px;
        height: auto;
        padding-bottom: 66%;
        -webkit-background-size: contain;
        -moz-background-size: contain;
        -o-background-size: contain;
        background-size: contain;
        background-repeat: no-repeat;
    }
    section.bild_mit_text div.block div.content {
        -webkit-flex-basis: 100%;
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        padding-left: 0;
        -webkit-box-ordinal-group: 2 !important;
        -webkit-order: 1 !important;
        -moz-box-ordinal-group: 2 !important;
        -ms-flex-order: 1 !important;
        order: 1 !important;
    }
}
section.firmen_daten {
    padding: 80px 0 70px;
    background: #afece9;
}
section.firmen_daten .wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
section.firmen_daten .data {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 23%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 23%;
    flex: 0 0 23%;
    font-weight: 700;
}
section.firmen_daten .data .titel {
    font-size: 20px;
    padding-bottom: 10px;
    margin-bottom: 15px;
    border-bottom: 1px solid #014051;
}
section.firmen_daten .data .zahl_wrapper {
    font-size: 100px;
    line-height: 1;
}
@media (max-width: 1170px) {
    section.firmen_daten .data .zahl_wrapper {
        font-size: 75px;
    }
}
@media (max-width: 940px) {
    section.firmen_daten {
        padding-bottom: 20px;
    }
    section.firmen_daten .data {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 46%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 46%;
        flex: 0 0 46%;
        margin-bottom: 50px;
    }
    section.firmen_daten .data .zahl_wrapper {
        font-size: 75px;
    }
}
@media (max-width: 600px) {
    section.firmen_daten .data {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 100%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
    }
    section.firmen_daten .data .zahl_wrapper {
        font-size: 75px;
    }
}
section.google_map {
    padding: 60px 0;
}
section.google_map .gmap_wrapper {
    height: 640px;
    background: #eee;
    position: relative;
}
section.google_map .gmap_wrapper #gmap {
    height: 100%;
    position: relative;
    z-index: 0;
}
section.google_map h2 {
    margin-bottom: 20px;
}
section.google_map .kontakt_box {
    background: #014051;
    color: #fff;
    width: 470px;
    font-size: 1.2em;
    padding: 15px 20px 30px;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 30;
}
section.google_map .kontakt_box .titel {
    font-size: 1em;
    font-weight: 700;
    margin-bottom: 30px;
}
section.google_map .kontakt_box a {
    color: #fff;
}
section.google_map .kontakt_box .item {
    padding-left: 60px;
    margin-top: 20px;
    position: relative;
}
section.google_map .kontakt_box .item:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-repeat: no-repeat !important;
    -webkit-background-size: contain !important;
    -moz-background-size: contain !important;
    -o-background-size: contain !important;
    background-size: contain !important;
    background-position: 50% 50% !important;
    width: 40px;
    height: 30px;
}
section.google_map .kontakt_box .item.location:before {
    height: 40px;
    top: 3px;
    background: url(images/location.svg);
}
section.google_map .kontakt_box .item.telefon {
    margin-top: 50px;
}
section.google_map .kontakt_box .item.telefon:before {
    background: url(images/phone_white.svg);
}
section.google_map .kontakt_box .item.mail:before {
    width: 30px;
    left: 4px;
    top: -1px;
    background: url(images/mail_white.svg);
}
@media (max-width: 900px) {
    section.google_map .gmap_wrapper {
        height: auto;
    }
    section.google_map .gmap_wrapper #gmap {
        height: 400px;
    }
    section.google_map .kontakt_box {
        position: relative;
        width: 100%;
    }
}
@media (max-width: 500px) {
    .modul.google_map .wrap {
        padding: 0;
    }
    .modul.google_map .wrap h2 {
        padding: 0 20px;
    }
    section.google_map .gmap_wrapper #gmap {
        height: 250px;
    }
}
section.kontakt_banner {
    background: #afece9;
    background: -webkit-linear-gradient(45deg, #61d8ca 0, #afece9 100%);
    background: oldlinear-gradient(45deg, #61d8ca 0, #afece9 100%) -moz-;
    background: -o-linear-gradient(45deg, #61d8ca 0, #afece9 100%);
    background: linear-gradient(45deg, #61d8ca 0, #afece9 100%);
    padding: 75px 0;
    margin: 0;
}
section.kontakt_banner div.wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}
section.kontakt_banner div.content {
    -webkit-flex-basis: 50%;
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
}
section.kontakt_banner div.content div.content_inner_wrap {
    max-width: 420px;
}
section.kontakt_banner div.kontakt_daten_container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -moz-box-orient: vertical;
    -moz-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-flex-basis: 50%;
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    margin-left: 20px;
}
section.kontakt_banner div.kontakt_daten_container div.kontakt_daten_wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}
section.kontakt_banner div.kontakt_daten_container div.kontakt_daten_wrap div.kontakt_daten {
    -webkit-flex-basis: 50%;
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    position: relative;
    padding-left: 50px;
}
section.kontakt_banner div.kontakt_daten_container div.kontakt_daten_wrap div.kontakt_daten .kontakt_icon {
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
}
@media (max-width: 1100px) {
    section.kontakt_banner .wrap {
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -moz-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
    section.kontakt_banner div.kontakt_daten_container {
        -webkit-flex-basis: 40%;
        -ms-flex-preferred-size: 40%;
        flex-basis: 40%;
    }
    section.kontakt_banner div.kontakt_daten_container div.kontakt_daten_wrap {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    section.kontakt_banner div.kontakt_daten_container div.kontakt_daten_wrap div.kontakt_daten {
        width: 100%;
        -webkit-flex-basis: 100%;
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        margin-bottom: 30px;
    }
}
@media (max-width: 500px) {
    section.kontakt_banner .wrap {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    section.kontakt_banner div.content {
        width: 100%;
        -webkit-flex-basis: 100%;
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    }
    section.kontakt_banner div.kontakt_daten_container {
        width: 100%;
        -webkit-flex-basis: 100%;
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        margin-top: 40px;
        padding-left: 0;
        margin-left: 0;
    }
}
section.kontaktformular {
    padding: 60px 0;
    background: #afece9;
}
section.kontaktformular h2,
section.kontaktformular h3 {
    margin-bottom: 55px;
}
section.kontaktformular .button_container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -moz-box-orient: horizontal;
    -moz-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
    -moz-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    margin-bottom: 20px;
}
section.kontaktformular .button_container .button_toggle {
    background: #014051;
    color: #fff;
    display: block;
    width: 280px;
    padding: 7px 20px;
    font-size: 20px;
    font-weight: 700;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
    margin-right: 5px;
    cursor: pointer;
}
section.kontaktformular .Dienstleistungen_dropdown,
section.kontaktformular .Produkte_dropdown,
section.kontaktformular .produkte_radios {
    display: none;
}
section.kontaktformular .button_container .button_toggle.inaktiv {
    background: #99b3b9;
}
section.kontaktformular .button_container .button_toggle:hover {
    background: #1f5e6f;
}
section.kontaktformular .produkte_radios label {
    position: relative !important;
}
section.kontaktformular .Dienstleistungen_dropdown select,
section.kontaktformular .Produkte_dropdown select {
    max-width: 280px;
}
section.kontaktformular hr {
    margin: 10px 0 50px;
    border-top: 1px solid #014051;
}
section.kontaktformular .first_col strong {
    display: block;
    font-size: 20px;
}
section.kontaktformular .first_col p {
    margin-top: 0;
}
section.kontaktformular .rueckruf {
    margin-top: 40px;
    display: block;
}
section.kontaktformular .form-group {
    position: relative;
    padding-bottom: 20px;
}
section.kontaktformular .form-group label {
    display: block;
    position: absolute;
    bottom: -4px;
}
section.kontaktformular .form-group.radio_label .radio label {
    position: relative;
    bottom: auto;
    margin-bottom: 13px;
}
section.kontaktformular .form-group input {
    border: none;
    border-bottom: 1px solid #014051;
    max-width: 400px;
}
section.kontaktformular .form-group textarea {
    background: #fff;
    border: none;
    padding: 30px 25px;
}
section.kontaktformular input[type="submit"] {
    margin-top: 30px;
}
section.kontaktformular .checkbox {
    display: block;
    height: 20px;
    margin-bottom: 15px;
    position: relative;
}
section.kontaktformular .icheckbox,
section.kontaktformular .iradio {
    width: 20px;
    height: 20px;
    margin-right: 10px;
    float: left;
    background: 0 0;
    border: 1px solid #014051;
}
section.kontaktformular .icheckbox:before,
section.kontaktformular .iradio:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 14px;
    height: 14px;
    background: #014051;
    -webkit-transform: translateX(-50%) translateY(-50%);
    -moz-transform: translateX(-50%) translateY(-50%);
    -ms-transform: translateX(-50%) translateY(-50%);
    -o-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
    opacity: 0;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    -moz-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}
section.kontaktformular .icheckbox.checked:before,
section.kontaktformular .iradio.checked:before {
    opacity: 1;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    -moz-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}
section.kontaktformular .caldera-grid {
    position: relative;
}
section.kontaktformular #caldera_notices_1 {
    position: absolute;
    bottom: -20px;
    left: 25%;
}
section.kontaktformular #caldera_notices_1 .alert {
    background: #fff;
    padding: 5px 30px;
}
@media (max-width: 768px) {
    section.kontaktformular #caldera_notices_1 {
        left: 0;
    }
}
@media (max-width: 700px) {
    section.kontaktformular .button_container {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    section.kontaktformular .button_container .button_toggle {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 100%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        margin-top: 2px;
    }
    section.kontaktformular select {
        max-width: 600px;
    }
}
section.kopfbereich {
    padding: 30px 0;
}
section.kopfbereich img {
    display: block;
    width: 100%;
    position: relative;
    z-index: 0;
}
section.kopfbereich .textbox {
    width: 80%;
    margin: -100px auto 0;
    background: #fff;
    padding: 50px 20px;
    position: relative;
    z-index: 20;
}
section.kopfbereich .textbox .inner {
    max-width: 700px;
    margin: 0 auto;
}
section.kopfbereich .textbox h1 {
    color: #61d8ca;
    margin-bottom: 40px;
}
section.kopfbereich .textbox strong {
    font-size: 1.2em;
}
@media (max-width: 900px) {
    .modul.kopfbereich .textbox {
        margin-top: -50px;
    }
}
@media (max-width: 600px) {
    .modul.kopfbereich .textbox {
        width: 100%;
        margin-top: 0;
        padding: 30px 0;
    }
    .modul.kopfbereich .textbox h1 {
        margin-bottom: 20px;
    }
}
.modul.loop_posts .post,
.modul.loop_posts .post .titel {
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
}
.modul.loop_posts {
    background: #f5f5f5;
    padding: 70px 0 90px;
}
.modul.loop_posts .post {
    opacity: 0;
    transition: all 0.2s ease-out;
    border-bottom: 1px solid #014051;
}
.modul.loop_posts .post .titel {
    font-weight: 700;
    padding: 12px 50px 12px 0;
    transition: all 0.2s ease-out;
    cursor: pointer;
    position: relative;
}
.modul.loop_posts .post .titel span {
    display: block;
    font-weight: 400;
}
.modul.loop_posts .post .titel:hover {
    opacity: 0.7;
}
.modul.loop_posts .post .titel:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 15px;
    height: 36px;
    width: 10px;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
    background: url(images/toggle_arrow_tuerkis.svg);
    background-repeat: no-repeat !important;
    -webkit-background-size: contain !important;
    -moz-background-size: contain !important;
    -o-background-size: contain !important;
    background-size: contain !important;
}
.modul.loop_posts .post .inhalt {
    display: none;
    padding: 25px 0;
    border-top: 1px solid #014051;
}
.modul.loop_posts .post.show {
    opacity: 1;
}
.modul.loop_posts .post.toggled .titel:after {
    -webkit-transform: rotate(-90deg) translateY(-50%);
    -moz-transform: rotate(-90deg) translateY(-50%);
    -ms-transform: rotate(-90deg) translateY(-50%);
    -o-transform: rotate(-90deg) translateY(-50%);
    transform: rotate(-90deg) translateY(-50%);
    margin-top: -15px;
    right: -5px;
}
section.mitarbeiter {
    padding: 60px 0;
    background: #f5f5f5;
}
section.mitarbeiter .wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
section.mitarbeiter .wrap .mitarbeiter {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 25%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    padding: 15px 10px;
}
section.mitarbeiter .wrap .mitarbeiter .inner {
    position: relative;
    padding-bottom: 70px;
    height: 100%;
}
section.mitarbeiter .wrap .mitarbeiter .bild {
    width: 170px;
    height: 200px;
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
    background-position: 50% 50% !important;
}
section.mitarbeiter .wrap .mitarbeiter .name {
    margin-top: 30px;
    font-weight: 700;
    font-size: 1.25em;
    padding-top: 20px;
    border-top: 1px solid #014051;
}
section.mitarbeiter .wrap .mitarbeiter .kontakt {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}
section.mitarbeiter .wrap .mitarbeiter .kontakt a {
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
    display: block;
}
section.mitarbeiter .wrap .mitarbeiter .kontakt a:hover {
    color: #61d8ca;
}
@media (max-width: 840px) {
    section.mitarbeiter .wrap .mitarbeiter {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 50%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
    }
}
@media (max-width: 500px) {
    section.mitarbeiter .wrap .mitarbeiter {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 100%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
    }
}
section.news_teaser {
    background: #f5f5f5;
    margin: 0;
    padding: 70px 0;
}
section.news_teaser div.news_teaser_wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 45px;
}
section.news_teaser div.news_teaser_wrap article.teaser {
    width: -webkit-calc((100% - 45px)/ 4);
    width: -moz-calc((100% - 45px)/ 4);
    width: calc((100% - 45px) / 4);
    padding: 18px 15px;
    background: #014051;
    color: #fff;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -moz-box-orient: vertical;
    -moz-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}
section.news_teaser div.news_teaser_wrap article.teaser div.link {
    margin-top: auto;
    justify-self: flex-end;
}
section.news_teaser div.news_teaser_wrap article.teaser a {
    color: #61d8ca;
}
section.news_teaser div.news_teaser_wrap article.teaser div.datum {
    margin-bottom: 5px;
}
section.news_teaser div.news_teaser_wrap article.teaser div.titel {
    height: 45px;
    margin-bottom: 20px;
    font-weight: 700;
}
section.news_teaser div.news_teaser_wrap article.teaser div.content {
    margin-bottom: 45px;
}
@media (max-width: 940px) {
    section.news_teaser div.news_teaser_wrap {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    section.news_teaser div.news_teaser_wrap article.teaser {
        width: -webkit-calc((100% - 25px)/ 2);
        width: -moz-calc((100% - 25px)/ 2);
        width: calc((100% - 25px) / 2);
        margin-bottom: 25px;
    }
}
@media (max-width: 560px) {
    section.news_teaser div.news_teaser_wrap {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    section.news_teaser div.news_teaser_wrap article.teaser {
        width: 100%;
        margin-bottom: 10px;
    }
}
section.produkte_loop {
    padding: 90px 0;
}
section.produkte_loop .wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
section.produkte_loop .wrap .kachel {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 25%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    padding: 6px;
    min-height: 300px;
}
section.produkte_loop .wrap .kachel .inner {
    background: #f9f9f9;
    height: 100%;
    position: relative;
    overflow: hidden;
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
    background-position: 50% 50% !important;
}
section.produkte_loop .wrap .kachel .inner img {
    max-width: 160px;
    height: auto;
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    margin-top: -30px;
}
.no-touch section.produkte_loop .wrap .kachel .inner:hover .toggle_box,
section.produkte_loop .wrap .kachel .inner.hovered .toggle_box {
    top: 0;
    margin-top: 0;
}
section.produkte_loop .wrap .kachel .toggle_box {
    background: #014051;
    color: #fff;
    padding: 15px 20px;
    position: absolute;
    z-index: 20;
    left: 0;
    width: 100%;
    height: 100%;
    top: 100%;
    margin-top: -56px;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}
section.produkte_loop .wrap .kachel .toggle_box .titel {
    font-weight: 700;
    display: block;
    font-size: 18px;
    margin-bottom: 20px;
    white-space: nowrap;
}
section.produkte_loop .wrap .kachel .toggle_box .mehr {
    position: absolute;
    bottom: 20px;
    left: 20px;
    color: #61d8ca;
}
@media (max-width: 1000px) {
    section.produkte_loop .wrap .kachel {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 50%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
    }
}
@media (max-width: 600px) {
    section.produkte_loop .wrap .kachel {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 100%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
    }
}
.modul.modul_services {
    padding: 70px 0;
}
.modul.modul_services h2.has_seperator {
    margin-bottom: 70px;
}
.modul.modul_services .service_container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -moz-box-orient: horizontal;
    -moz-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.modul.modul_services .service {
    width: -webkit-calc((100% - 100px)/ 3);
    width: -moz-calc((100% - 100px)/ 3);
    width: calc((100% - 100px) / 3);
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -moz-box-orient: vertical;
    -moz-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}
.modul.modul_services .service img {
    width: 100%;
    margin-bottom: 35px;
}
.modul.modul_services .service h3 {
    font-size: 1.4em;
    margin: 10px 0;
}
.modul.modul_services .service .seperator {
    width: 20px;
    height: 1px;
    background: #000;
    margin: 15px 0;
}
.modul.modul_services .service div.text {
    max-width: 250px;
    margin-bottom: 35px;
}
.modul.modul_services .service .button-wrapper {
    margin-top: auto;
    justify-self: flex-end;
}
@media (max-width: 1000px) {
    .modul.modul_services .service {
        width: 100%;
        margin-bottom: 70px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -moz-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-flex-wrap: nowrap;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -moz-box-orient: horizontal;
        -moz-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        -webkit-box-align: start;
        -webkit-align-items: flex-start;
        -moz-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
    }
    .modul.modul_services .service img {
        max-width: 300px;
        height: auto;
        margin-right: 50px;
    }
    .modul.modul_services .service .textcontent {
        -webkit-box-flex: 2;
        -webkit-flex: 2;
        -moz-box-flex: 2;
        -ms-flex: 2;
        flex: 2;
    }
    .modul.modul_services .service div.text {
        max-width: none;
    }
}
@media (max-width: 700px) {
    .modul.modul_services .service {
        width: 100%;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -moz-box-orient: vertical;
        -moz-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
    }
}
.modul.tabs .wrap {
    position: relative;
}
.modul.tabs .dotbar {
    position: absolute;
    top: 25px;
    left: 100%;
    margin-left: -100px;
    z-index: 22230;
}
.modul.tabs nav.tabnav {
    position: -webkit-sticky;
    position: sticky;
    top: 115px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -moz-box-orient: horizontal;
    -moz-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    -moz-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    z-index: 40;
}
.modul.tabs nav.tabnav a {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -moz-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    color: #014051;
    background: #fff;
    padding: 10px 30px 7px;
    border-bottom: 1px solid #014051;
    display: block;
    text-align: center;
}
.modul.tabs nav.tabnav a.active,
.modul.tabs nav.tabnav a:hover {
    background: #61d8ca;
}
.modul.tabs nav.tabnav a.active {
    font-weight: 700;
}
.modul.tabs .tab_content {
    background: #f5f5f5;
}
.modul.tabs .tab_content .tab {
    display: none;
}
.modul.tabs .tab_content .tab .wrap {
    padding: 0;
}
.modul.tabs .tab_content .tab.active {
    display: block;
}
.back_to_tabnav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    padding: 8px 20px;
    background: #014051;
    color: #fff;
    z-index: 600;
    opacity: 0;
    cursor: pointer;
    -webkit-transition: all 0.4s ease-out;
    -o-transition: all 0.4s ease-out;
    -moz-transition: all 0.4s ease-out;
    transition: all 0.4s ease-out;
}
.back_to_tabnav:after {
    content: "";
    position: absolute;
    top: 9px;
    right: 24px;
    width: 18px;
    height: 16px;
    -webkit-transform: rotate(-90deg);
    -moz-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    -o-transform: rotate(-90deg);
    transform: rotate(-90deg);
    background: url(images/arrow_white.svg) no-repeat;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
}
.back_to_tabnav.show {
    opacity: 1;
    top: 60px;
}
@media (max-width: 760px) {
    .modul.tabs nav.tabnav {
        position: relative;
        top: 0;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        margin: 0 -20px;
    }
    .modul.tabs nav.tabnav a {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 100%;
        -moz-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        padding: 10px 20px 7px;
    }
    .modul.tabs .modul {
        padding: 15px 0;
    }
}
section.slider_2_spalten {
    background: #afece9;
    padding-top: 75px;
    padding-bottom: 50px;
    margin: 0;
}
section.slider_2_spalten div.wrap {
    position: relative;
}
section.slider_2_spalten ul.slider_2_spalten_slider li.slide div.slide_wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
section.slider_2_spalten ul.slider_2_spalten_slider li.slide div.slide_wrap div.spalte {
    width: -webkit-calc(50% - 40px);
    width: -moz-calc(50% - 40px);
    width: calc(50% - 40px);
}
section.slider_2_spalten ul.slider_2_spalten_slider li.slide div.slide_wrap div.spalte img {
    margin: 60px 0;
}
section.slider_2_spalten .lSSlideOuter .lSPager.lSpg {
    margin-top: 150px !important;
}
@media (max-width: 700px) {
    section.slider_2_spalten ul.slider_2_spalten_slider li.slide div.slide_wrap {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    section.slider_2_spalten ul.slider_2_spalten_slider li.slide div.slide_wrap div.spalte {
        width: 100%;
    }
    section.slider_2_spalten ul.slider_2_spalten_slider li.slide div.slide_wrap div.spalte img {
        margin: 20px 0;
    }
    section.slider_2_spalten .lSSlideOuter .lSPager.lSpg {
        margin-top: 20px !important;
    }
}
section.text_block {
    padding: 70px 0;
}
section.text_block.intro h1 {
    color: #61d8ca;
    margin-bottom: 50px;
}
section.text_block.intro h3 {
    margin-bottom: 50px;
}
section.text_block.intro p {
    font-size: 1.25em;
}
section.text_block ul {
    display: block;
    list-style: none;
    margin: 0;
    padding: 0;
}
section.text_block ul li {
    padding-left: 18px;
    position: relative;
    margin-bottom: 14px;
}
section.text_block ul li:before {
    content: "";
    display: block;
    position: absolute;
    top: 3px;
    left: 0;
    width: 20px;
    height: 16px;
    background: url(images/list_arrow.svg) no-repeat;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
}
section.zitat_banner {
    background: #014051;
    color: #fff;
    padding: 70px 0;
    margin: 0;
    text-align: center;
}
section.zitat_banner div.zitat_banner_wrap {
    max-width: 66.66%;
    margin: 0 auto;
}
section.zitat_banner div.zitat_banner_wrap div.img {
    margin-bottom: 55px;
}
section.zitat_banner div.zitat_banner_wrap div.text {
    font-size: 1.75em;
    font-weight: 400;
    font-style: italic;
    margin-bottom: 60px;
}
@media (max-width: 700px) {
    section.zitat_banner div.zitat_banner_wrap div.text {
        font-size: 1.4em;
    }
    section.zitat_banner div.zitat_banner_wrap {
        max-width: 100%;
        padding: 0 20px;
    }
    section.zitat_banner div.zitat_banner_wrap div.img,
    section.zitat_banner div.zitat_banner_wrap div.text {
        margin-bottom: 35px;
    }
}
section.zitat_banner div.zitat_banner_wrap div.autor {
    font-size: 1.25em;
    font-weight: 400;
    font-weight: 700;
}
section.modul_toggle_box {
    padding: 60px 0;
}
section.modul_toggle_box ul.toggle_box_list {
    list-style: none;
    padding: 0;
    margin: 0;
}
section.modul_toggle_box ul.toggle_box_list li:hover {
    cursor: pointer;
}
section.modul_toggle_box ul.toggle_box_list header {
    position: relative;
    padding: 15px 0;
    border-bottom: 1px solid #014051;
}
section.modul_toggle_box ul.toggle_box_list header .titel {
    display: block;
    padding-right: 70px;
    padding-left: 0;
    font-size: 1em;
    font-weight: 700;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}
section.modul_toggle_box ul.toggle_box_list header .titel .sub {
    font-weight: 400;
    display: block;
}
section.modul_toggle_box ul.toggle_box_list header .titel:hover {
    opacity: 0.75;
}
section.modul_toggle_box ul.toggle_box_list header:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 15px;
    height: 36px;
    width: 10px;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out;
    -moz-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
    background: url(images/toggle_arrow.svg);
    background-repeat: no-repeat !important;
    -webkit-background-size: contain !important;
    -moz-background-size: contain !important;
    -o-background-size: contain !important;
    background-size: contain !important;
}
section.modul_toggle_box ul.toggle_box_list header.arrow_tuerkis:after {
    background: url(images/toggle_arrow_tuerkis.svg);
}
section.modul_toggle_box ul.toggle_box_list header.arrow_dunkel:after {
    background: url(images/toggle_arrow_dunkel.svg);
}
section.modul_toggle_box ul.toggle_box_list .box_content {
    display: none;
    padding: 5px 20px;
    border-bottom: 1px solid #014051;
}
section.modul_toggle_box ul.toggle_box_list .box_content ul {
    display: block;
    list-style: none;
    margin: 0;
    padding: 0;
}
section.modul_toggle_box ul.toggle_box_list .box_content ul li {
    padding-left: 18px;
    position: relative;
    margin-bottom: 14px;
}
section.modul_toggle_box ul.toggle_box_list .box_content ul li:before {
    content: "";
    display: block;
    position: absolute;
    top: 3px;
    left: 0;
    width: 20px;
    height: 16px;
    background: url(images/list_arrow.svg) no-repeat;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
}
section.modul_toggle_box ul.toggle_box_list .box_content .inner {
    max-width: 600px;
    margin: 0 auto;
    padding: 20px 0;
}
section.modul_toggle_box ul.toggle_box_list .box_content .downloads a {
    display: block;
    margin-bottom: 10px;
}
section.modul_toggle_box ul.toggle_box_list li.toggled header:after {
    -webkit-transform: rotate(-90deg) translateY(-50%);
    -moz-transform: rotate(-90deg) translateY(-50%);
    -ms-transform: rotate(-90deg) translateY(-50%);
    -o-transform: rotate(-90deg) translateY(-50%);
    transform: rotate(-90deg) translateY(-50%);
    margin-top: -15px;
    right: -5px;
}
@media screen and (max-width: 1100px) {
    #main_footer nav {
        margin-right: 30px;
    }
    .wrap {
        padding: 0 50px;
    }
}
@media screen and (max-width: 1000px) {
    .wrap {
        padding: 0 30px;
    }
    #main_header {
        height: 70px;
    }
    #nav_main,
    #nav_sub {
        display: none;
    }
    #main_header a.logo {
        right: 50px;
        margin-top: 4px;
    }
    #main_header a.logo img {
        height: 45px;
    }
    header#main_header #menu-trigger {
        display: block;
        position: absolute;
        top: 20px;
        left: 30px;
        cursor: pointer;
    }
}
@media screen and (max-width: 900px) {
    #main_footer .wrap {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    #main_footer .link_box {
        width: 100%;
        margin-top: 50px;
        text-align: right;
    }
}
@media (max-width: 700px) {
    #main_footer nav.inhalt,
    #main_footer nav.produkte {
        display: none;
    }
}
@media screen and (max-width: 600px) {
    body {
        font-size: 14px;
    }
    #main_header a.logo {
        right: 30px;
    }
}
@media (max-width: 340px) {
    #main_footer nav.info {
        width: 100%;
        margin-top: 40px;
    }
    #main_footer .link_box {
        text-align: left;
    }
}


/*# sourceMappingURL=assets/style.css.map */



/* Tooltips */

.tooltip-trigger {
    position: absolute;
    cursor: pointer;
	display: inline-block;
	text-decoration: dashed;
	transition: all ease 0.25s;
	font-weight: 700;
}

.tooltip-trigger:hover {
	color: #61D8CA;
}

.tooltip-trigger:after {
	position: absolute;
	top: 0;
	right: -18px;
	float: right;
	width: 16px;
	height: 16px;
	content: "";
	display: block;

	background: #61D8CA;
	mask: url(images/icon-info.svg) no-repeat;
	-webkit-mask: url(images/icon-info.svg) no-repeat;
	mask-size: 100% 100%;
	-webkit-mask-size: 100% 100%;
}

.tooltip-content {
    display: none;
    position: absolute;
    left: 15px;
	top: 30px;
	width: 480px;
	height: auto;
    background-color: #FFF;
    padding: 20px;
    border-radius: 10px;
    font-size: 14px;
    z-index: 9999;
	border: 2px solid #EEE;
	color: #014051;
	font-weight: 400;
}

.tooltip-trigger[aria-expanded="true"] .tooltip-content {
    display: block;
}

.tooltip-content img {
	width: 100%;
	height: auto;
	display: block;
	max-width: 100px;
}


@media only screen and (max-width: 780px) {
	
	.tooltip-content {
		left: 0;
		width: 300px;
	}
	
} /* End Media */


/* Plugin adjustments: Contact Form 7 */

.wpcf7-form,
.fieldset-cf7mls-wrapper {
	overflow: visible;
}

.wpcf7-list-item {
	display: block;
    margin: 0 0 10px 0 !important;
}        

img.ajax-loader {
    width: 16px !important;
    height: auto !important;
}

.wpcf7 form .wpcf7-response-output {
    border: none !important;
    width: 95%;
    margin: 0 !important;
    padding: 10px 2.5% 10px 2.5% !important;

    color: #fff !important;
}

.wpcf7 form.sent .wpcf7-response-output {
    background: green;
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
    background: red;
}

.wpcf7-not-valid-tip {
    color: red !important;
}

.form-img-choice {
	display: grid;
	gap: 2.5rem;
	grid-template-columns: repeat(4, 1fr);
}

.form-img-choice img {
	width: 100%;
	height: auto;
	display: block;
	cursor: pointer;
	outline: 2px solid #EEE;
	transition: all ease 0.25s;
}


@media only screen and (max-width: 780px) {
	
	.form-img-choice {
		gap: 1.25rem;
		grid-template-columns: repeat(2, 1fr);
	}
	
} /* End Media */

