﻿html,
body {
    color: #555;
    font-size: 16px;
    line-height: 150%;
    font-family: arial;
    width: 100%;
    background: #c2c2c2
}

h1,
h2,
h3,
h4 {
    line-height: 150%;
    padding-top: 1rem;
    text-transform: uppercase;
    font-family: arial
}

h1 {
    font-size: 2.25rem;
    padding-top: 50px
}

h2 {
    font-size: 1.5rem
}

h3 {
    font-size: 1.125rem
}

p a,
p a:hover {
    color: #153D8A
}

p a:hover {
    text-decoration: underline
}

.row {
    margin: 0 auto;
    max-width: 1400px;
    width: 100%
}

.row.width-140 {
    max-width: 140% !important;
    width: 140% !important;
}

.row .row {
    margin: 0;
    max-width: 100%;
    width: 100%
}

.columns {
    padding: 0 48px
}

#landing-section .columns {
    padding: 0
}

.sections-move {
    height: 3660px;
    position: relative;
    overflow: hidden
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    .sections-move {
        height: 3790px;
    }
}

@supports (-ms-ime-align:auto) {

    .sections-move {
        height: 3744px;
    }

}
    
.brandcolor-orange {
    color: #FAB233
}

.brandcolor-green {
    color: #99af2b
}

.brandcolor-purple {
    color: #8a2d6a
}

.brandcolor-blue {
    color: #008ab7
}

.brandcolor-darkblue {
    color: #264684
}

.bg-darkgrey {
    background: #c2c2c2 !important
}

.bg-lightgrey {
    background: #efefef
}

.bg-white {
    background: #fff
}

.bg-blue {
    background: #1885A8
}

.bg-darkblue {
    background: #264684
}

.bg-tex-blue {
    background: #008ab7
}

.bg-tex-purple {
    background: #8a2d6a
}

.bg-tex-formblue {
    background: #6f97b2
}

.bg-tex-darkblue {
    background: #153d8a
}

.bg-tex-green {
    background: #99af2b
}

.bg-tex-grey {
    background: #6e7a84
}

.bg-tex-orange {
    background: #fab233
}

.bg-calculated {
    width: calc((100% - 1400px)/2);
    width: -webkit-calc((100% - 1400px)/2);
    width: -moz-calc((100% - 1400px)/2);
    float: left;
    position: relative
}

.bg-new-blue {
    background: #6F97B2;
    background-image: -ms-radial-gradient(center, ellipse closest-side, #FFF 0, #6F97B2 100%);
    background-image: -moz-radial-gradient(center, ellipse closest-side, #FFF 0, #6F97B2 100%);
    background-image: -o-radial-gradient(center, ellipse closest-side, #FFF 0, #6F97B2 100%);
    background-image: -webkit-gradient(radial, center center, 0, center center, 125, color-stop(0, #FFF), color-stop(100, #6F97B2));
    background-image: -webkit-radial-gradient(center, ellipse closest-side, #FFF 0, #6F97B2 100%);
    background-image: radial-gradient(ellipse closest-side at center, #FFF 0, #6F97B2 100%);
    position: relative;
    z-index: 3
}

.bg-newer-blue {
    background: #bed3e0;
    background-image: -ms-radial-gradient(center, ellipse closest-side, #FFF 0, #bed3e0 100%);
    background-image: -moz-radial-gradient(center, ellipse closest-side, #FFF 0, #bed3e0 100%);
    background-image: -o-radial-gradient(center, ellipse closest-side, #FFF 0, #bed3e0 100%);
    background-image: -webkit-gradient(radial, center center, 0, center center, 125, color-stop(0, #FFF), color-stop(100, #bed3e0));
    background-image: -webkit-radial-gradient(center, ellipse closest-side, #FFF 0, #bed3e0 100%);
    background-image: radial-gradient(ellipse closest-side at center, #FFF 0, #bed3e0 100%);
    position: relative;
    z-index: 3
}

#topics-section,
#content-section,
#references-section,
#about-section {
    background: #6F97B2
}

#topics-section .main-column,
#topics-section .sub-column {
    height: 800px;
    position: relative;
    top: 0;
    z-index: 1
}

#content-section .main-column {
    height: 800px;
    position: relative;
    top: -120px;
    z-index: 5
}

#content-section .sub-column {
    height: 680px;
    position: relative;
    top: 0;
    z-index: 1
}

#references-section .main-column {
    height: 1500px;
    position: relative;
    top: -240px;
    z-index: 6
}

#references-section .sub-column {
    height: 1135px;
    position: relative;
    top: -120px;
    z-index: 1
}

#about-section .main-column {
    height: 850px;
    position: relative;
    top: -480px;
    z-index: 7
}

#about-section .sub-column {
    height: 730px;
    position: relative;
    top: -360px;
    z-index: 7
}

.hvr-grow:hover,
.hvr-grow:focus,
.hvr-grow:active {
    -webkit-transform: scale(1.2);
    transform: scale(1.2)
}

#landing-section {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    height: 100%
}

#landing-section:after {
    content: "";
    width: 100%;
    height: 10px;
    display: block;
    position: absolute;
    left: 0;
    bottom: -10px;
    z-index: 10;
    background: url(../img/shadow.png) left top repeat-x
}

.landing-top-left,
.landing-bottom-left,
.landing-top-right,
.landing-bottom-right {
    height: 50%;
    width: 50%;
    position: relative;
    z-index: 1
}

.landing-top-left,
.landing-bottom-left {
    border-right: solid 1px white
}

.landing-top-right,
.landing-bottom-right {
    border-left: solid 1px white
}

.landing-top-left,
.landing-top-right {
    border-bottom: solid 1px white
}

.landing-top-left-bg {
    background: url(../img/desktop_was_wir_tun.png);
    background-size: auto 90%;
    background-repeat: no-repeat;
    background-position: center bottom;
    position: relative;
    bottom: 0;
    z-index: 10;
    width: 100%;
    height: 100%
}

.landing-top-right-bg {
    background: url(../img/desktop_mit_was_arbeiten.png);
    background-size: auto 120%;
    background-repeat: no-repeat;
    background-position: center -25px;
    position: relative;
    bottom: 0;
    z-index: 10;
    width: auto;
    height: 100%
}

.landing-bottom-left-bg {
    background: url(../img/desktop_was_man-sieht.png);
    background-size: auto 130%;
    background-repeat: no-repeat;
    background-position: center -40px;
    position: relative;
    bottom: 0;
    z-index: 10;
    width: auto;
    height: 100%
}

.landing-bottom-right-bg {
    background: url(../img/desktop_wer_wir_sind.png);
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-position: center 50px;
    position: relative;
    bottom: 0;
    z-index: 10;
    width: auto;
    height: 100%
}

.landing-bg {
    height: 100%;
    width: auto
}

.button-topics,
.button-content,
.button-references,
.button-about {
    position: relative;
    z-index: 10;
    color: #fff;
    height: 180px;
    width: 180px;
    text-transform: uppercase;
    text-align: center;
    font-size: 1.625rem;
    line-height: 150%
}

.button-topics:hover,
.button-content:hover,
.button-references:hover,
.button-about:hover {
    color: #fff
}

.button-topics {
    background: #fab233 none repeat scroll 0 0;
    border-radius: 100px 100px 10px;
    bottom: 145px;
    padding: 30px 40px 0;
    position: relative;
    right: 80px
}

.button-content {
    background: #99af2b none repeat scroll 0 0;
    border-radius: 100px 100px 100px 10px;
    bottom: 324px;
    left: 180px;
    padding: 30px 20px 0
}

.button-references {
    background: #8a2d6a none repeat scroll 0 0;
    border-radius: 100px 10px 100px 100px;
    padding: 30px 40px 0;
    right: 80px;
    bottom: 225px
}

.button-about {
    background: #008ab7 none repeat scroll 0 0;
    border-radius: 10px 100px 100px;
    left: 180px;
    padding: 30px 40px 0;
    bottom: 405px
}

#landing-section .logo {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 280px;
    height: 170px;
    border-radius: 20px;
    margin-left: -140px;
    margin-top: -85px;
    background: #fff;
    z-index: 1
}

#landing-section .logo a {
    text-decoration: none;
    color: #fff
}

#landing-section .logo img {
    height: 100%;
    left: 0;
    padding: 30px;
    position: absolute;
    top: 0;
    width: 100%
}

#landing-section .logo-frame {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 280px;
    height: 170px;
    border-radius: 20px;
    margin-left: -140px;
    margin-top: -85px;
    background: 0;
    border: solid #fff 1px;
    z-index: 7
}

.arrow-down {
    position: absolute;
    bottom: 0;
    left: 50%;
    margin-left: -35px;
    width: 70px;
    height: 38px;
    border-radius: 35px 35px 0 0;
    padding-top: 5px;
    text-align: center;
    background: #153d8a;
    z-index: 10
}

.arrow-down img {
    width: 30px;
    height: auto
}

.button-bewerbung-box {
    width: 216px;
    height: 168px;
    display: block;
    overflow: hidden;
    position: absolute;
    z-index: 11;
    bottom: 0;
    right: 4%
}

.button-bewerbung {
    background-color: #153D8A;
    width: 216px;
    height: 216px;
    display: block;
    border-radius: 50%;
    padding: 7px;
    -moz-transform: rotate(-10deg);
    -ms-transform: rotate(-10deg);
    -o-transform: rotate(-10deg);
    -webkit-transform: rotate(-10deg);
    transform: rotate(-10deg)
}

.button-bewerbung-inner {
    border: 3px solid #fff;
    border-radius: 50%;
    width: 202px;
    height: 202px;
    text-align: center;
    font-size: 23px;
    color: #fff;
    padding: 44px 20px 0 20px
}

.button-bewerbung-inner span {
    font-size: 30px;
    margin-top: 10px;
    display: block
}

#landing-section .button-topics:hover,
#landing-section .button-topics:active,
#landing-section .button-topics:focus {
    -webkit-transform: translate(-17px, -17px) scale(1.2);
    transform: translate(-17px, -17px) scale(1.2)
}

#landing-section .button-content:hover,
#landing-section .button-content:active,
#landing-section .button-content:focus {
    -webkit-transform: translate(17px, -17px) scale(1.2);
    transform: translate(17px, -17px) scale(1.2)
}

#landing-section .button-references:hover,
#landing-section .button-references:active,
#landing-section .button-references:focus {
    -webkit-transform: translate(-17px, 17px) scale(1.2);
    transform: translate(-17px, 17px) scale(1.2)
}

#landing-section .button-about:hover,
#landing-section .button-about:active,
#landing-section .button-about:focus {
    -webkit-transform: translate(17px, 17px) scale(1.2);
    transform: translate(17px, 17px) scale(1.2)
}

.menu-wrap {
    z-index: 98;
    width: 100%;
    height: 90px;
    position: fixed;
    top: 0;
    left: 0;
    -webkit-transition: all .5s;
    transition: all .5s;
    display: none;
    background-color: #153D8A
}

.menu-wrap-inner {
    background-color: transparent;
    width: 100%;
    height: 90px
}

.menu-wrap.transparent {
    background-color: transparent
}

.menu-positioner {
    height: 90px;
    position: relative;
    width: 1214px;
    margin: 0 auto
}

@media(min-width:1278px){

    .sections-move {
        height: 3614px;
    }


    @supports (-ms-ime-align:auto) {

        .sections-move {
            height: 3744px;
        }

    }

}



@media(min-width:1326px) {
    .menu-positioner {
        width: 1326px
    }

    .navigation-list li {
        margin-left: 130px !important
    }
}

@media(min-width:1380px){


    .sections-move {
        height: 3680px;
    }


    @supports (-ms-ime-align:auto) {

        .sections-move {
            height: 3810px;
        }

    }

}




@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) and (min-width:1278px) {

        .sections-move {
            height: 3744px
        }

    }


@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) and (min-width:1380px) {

    .sections-move {
        height: 3810px;
    }

}




.logo-box {
    z-index: 98;
    background: #fff;
    border-radius: 0 0 20px 20px;
    -webkit-box-shadow: 2px 2px 5px 0 #555;
    -moz-box-shadow: 2px 2px 5px 0 #555;
    box-shadow: 2px 2px 5px 0 #555;
    width: 263px;
    height: 115px;
    display: block;
    padding: 22px 32px 0 32px;
    position: absolute;
    top: 0;
    left: 0
}

.logo-box .logo-top {
    display: block;
    width: 100%;
    height: auto
}

.navigation-list {
    width: 100%;
    padding-left: 263px;
    padding-top: 33px;
    margin: 0;
    list-style-type: none;
    text-align: right;
    display: none
}

.navigation-list li {
    display: inline-block;
    margin-left: 100px
}

.navigation-list li a {
    color: #fff;
    text-transform: uppercase
}

.navigation-list li.hidden {
    display: none
}

#topics-section .button-topics,
#content-section .button-content,
#references-section .button-references,
#about-section .button-about {
    width: 120px;
    height: 120px;
    font-size: 1.125rem;
    top: -5px;
    left: -10px;
    position: absolute
}

#topics-section .bg-topics {
    left: -170px;
    max-width: 579px;
    position: relative;
    top: 211px;
    width: 579px;
    height: 469px;
    background: url("../img/desktop_was_wir_tun.png") no-repeat
}

#topics-section .bg-calculated {
    height: 800px;
    float: right;
    top: -800px
}

#topics-section .button-topics {
    top: 70px;
    left: 340px;
    padding: 20px 40px
}

.arrow_box {
    cursor: pointer;
    margin-right: 10px;
    width: 60px
}

.arrow_box.last {
    margin-right: 0
}

.arrow_box.growArrow {
    -webkit-animation: arrowbox-grow .5s .5s 1 normal;
    animation: arrowbox-grow .5s .5s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.arrow_box.shrinkArrow {
    -webkit-animation: arrowbox-shrink .5s 0s 1 normal;
    animation: arrowbox-shrink .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.arrow_bg {
    position: absolute;
    top: 7px;
    right: 55px;
    width: 10px;
    height: 39px;
    background-color: #fab233;
    -webkit-transform-origin: 100% 100%;
    -ms-transform-origin: 100% 100%;
    transform-origin: 100% 100%
}

.arrow {
    position: absolute;
    top: 0;
    right: 0;
    background: rgba(0, 0, 0, 0) url("../img/pfeil.png") no-repeat scroll left center / 53px 57px;
    width: 57px;
    height: 53px
}

.arrow_box.growArrow .arrow_bg {
    -webkit-animation: arrow-grow .5s .5s 1 normal;
    animation: arrow-grow .5s .5s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.arrow_box.shrinkArrow .arrow_bg {
    -webkit-animation: arrow-shrink .5s 0s 1 normal;
    animation: arrow-shrink .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.arrow_box .tab-box .tab-text {
    color: #555;
    font-size: 1.375rem;
    position: absolute;
    top: -20px;
    left: 0;
    -webkit-transform: rotate(270deg);
    -ms-transform: rotate(270deg);
    transform: rotate(270deg);
    -webkit-transform-origin: left top 0;
    -ms-transform-origin: left top 0;
    transform-origin: left top 0;
    -webkit-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out;
    z-index: 5
}

.arrow_box h3 {
    display: block;
    position: absolute;
    z-index: 2;
    top: -10px;
    right: 30px;
    color: #fff;
    font-size: 1.5rem;
    font-weight: bold
}

.arrow_box.growArrow h3 {
    -webkit-animation: arrowtext-grow .5s .5s 1 normal;
    animation: arrowtext-grow .5s .5s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.arrow_box.shrinkArrow h3 {
    -webkit-animation: arrowtext-shrink .5s 0s 1 normal;
    animation: arrowtext-shrink .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.arrow_box.growArrow p {
    -webkit-animation: arrowparagraph-grow .5s .5s 1 normal;
    animation: arrowparagraph-grow .5s .5s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.arrow_box.shrinkArrow p {
    -webkit-animation: arrowparagraph-shrink .5s .5s 1 normal;
    animation: arrowparagraph-shrink .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.arrow_box p {
    display: block;
    position: absolute;
    z-index: 2;
    top: 5px;
    right: -5px;
    opacity: 0;
    width: 100%;
    color: #fff;
    font-size: 1.5rem
}

.arrow_box.growArrow .tab-text {
    opacity: 0
}

.tabs .tab-title.active a {
    background-color: transparent
}

.tabs .tab-title a:hover {
    background-color: transparent
}

@-webkit-keyframes arrowbox-grow {
    0% {
        width: 60px
    }

    100% {
        width: 280px
    }
}

@keyframes arrowbox-grow {
    0% {
        width: 60px
    }

    100% {
        width: 280px
    }
}

@-webkit-keyframes arrowbox-shrink {
    0% {
        width: 280px
    }

    100% {
        width: 60px
    }
}

@keyframes arrowbox-shrink {
    0% {
        width: 280px
    }

    100% {
        width: 60px
    }
}

@-webkit-keyframes arrowtext-grow {
    0% {
        -webkit-transform: translateX(0px);
        transform: translateX(0px)
    }

    100% {
        -webkit-transform: translateX(-190px) translateY(-90px);
        transform: translateX(-190px) translateY(-90px)
    }
}

@keyframes arrowtext-grow {
    0% {
        -webkit-transform: translateX(0px);
        transform: translateX(0px)
    }

    100% {
        -webkit-transform: translateX(-190px) translateY(-90px);
        transform: translateX(-190px) translateY(-90px)
    }
}

@-webkit-keyframes arrowtext-shrink {
    0% {
        -webkit-transform: translateX(-190px) translateY(-90px);
        transform: translateX(-190px) translateY(-90px)
    }

    100% {
        -webkit-transform: translateX(0px);
        transform: translateX(0px)
    }
}

@keyframes arrowtext-shrink {
    0% {
        -webkit-transform: translateX(-190px) translateY(-90px);
        transform: translateX(-190px) translateY(-90px)
    }

    100% {
        -webkit-transform: translateX(0px);
        transform: translateX(0px)
    }
}

@-webkit-keyframes arrowparagraph-grow {
    0% {
        right: -5px;
        opacity: 0
    }

    100% {
        right: -30px;
        opacity: 1
    }
}

@keyframes arrowparagraph-grow {
    0% {
        right: -5px;
        opacity: 0
    }

    100% {
        right: -30px;
        opacity: 1
    }
}

@-webkit-keyframes arrowparagraph-shrink {
    0% {
        right: -30px;
        opacity: 1
    }

    100% {
        right: -5px;
        opacity: 0
    }
}

@keyframes arrowparagraph-shrink {
    0% {
        right: -30px;
        opacity: 1
    }

    100% {
        right: -5px;
        opacity: 0
    }
}

@-webkit-keyframes arrow-grow {
    0% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1)
    }

    100% {
        -webkit-transform: scaleX(21) scaleY(4) translateY(5px);
        transform: scaleX(21) scaleY(4) translateY(5px)
    }
}

@keyframes arrow-grow {
    0% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1)
    }

    100% {
        -webkit-transform: scaleX(21) scaleY(4) translateY(5px);
        transform: scaleX(21) scaleY(4) translateY(5px)
    }
}

@-webkit-keyframes arrow-shrink {
    0% {
        -webkit-transform: scaleX(21) scaleY(4) translateY(5px);
        transform: scaleX(21) scaleY(4) translateY(5px)
    }

    100% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1)
    }
}

@keyframes arrow-shrink {
    0% {
        -webkit-transform: scaleX(21) scaleY(4) translateY(5px);
        transform: scaleX(21) scaleY(4) translateY(5px)
    }

    100% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1)
    }
}

#topics-section .topic-tabs-position {
    overflow: hidden
}

#topics-section #topic-tabs.tabs {
    padding-top: 220px
}

#topics-section .topic-tabs-position .tabs-content {
    position: relative;
    top: 40px
}

#content-section .bg-calculated {
    height: 800px;
    top: -120px
}

#content-section .bg-content {
    height: 553px;
    left: -192px;
    max-width: 750px;
    position: relative;
    top: 7px;
    width: 750px;
    background: url("../img/desktop_mit_was_arbeiten.png") no-repeat;
    background-size: 100%
}

#content-section .button-content {
    top: 70px;
    left: 5px;
    padding: 18px 10px
}

.content-box {
    width: 120px;
    cursor: pointer;
    margin-top: 120px;
    float: left;
    position: relative
}

.content-box .text-box {
    overflow: hidden;
    position: absolute;
    top: -100px;
    width: 100px;
    height: 300px
}

.content-box.growQuad .text-box {
    width: 300px
}

.content-box .quad_bg {
    width: 100px;
    height: 100px;
    background: #99af2b;
    -webkit-transform-origin: 50% 50%;
    -ms-transform-origin: 50% 50%;
    transform-origin: 50% 50%;
    outline: 1px solid transparent;
    margin: 0 auto
}

.content-box.growQuad {
    -webkit-animation: quad-grow-box .5s 0s 1 normal;
    animation: quad-grow-box .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.content-box.shrinkQuad {
    -webkit-animation: quad-shrink-box .5s 0s 1 normal;
    animation: quad-shrink-box .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.content-box.growQuad .quad_bg {
    -webkit-animation: quad-grow .5s 0s 1 normal;
    animation: quad-grow .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.content-box.shrinkQuad .quad_bg {
    -webkit-animation: quad-shrink .5s 0s 1 normal;
    animation: quad-shrink .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.content-box h3 {
    display: block;
    position: absolute;
    top: 90px;
    left: 20px;
    width: 60%;
    color: #fff;
    font-size: .7rem;
    z-index: 3;
    -webkit-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out
}

.content-box p {
    display: block;
    position: absolute;
    top: 150px;
    left: 20px;
    opacity: 0;
    width: 10px;
    color: #fff;
    font-size: 1rem;
    z-index: 3;
    -webkit-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out
}

.content-box.growQuad h3 {
    font-size: 1rem;
    top: 0;
    width: 100%
}

.content-box.growQuad p {
    top: 50px;
    width: 260px;
    -webkit-animation: quad-fadein-text .5s .5s 1 normal;
    animation: quad-fadein-text .5s .5s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

@-webkit-keyframes quad-fadein-text {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes quad-fadein-text {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@-webkit-keyframes quad-grow-box {
    from {
        width: 120px
    }

    to {
        width: 300px
    }
}

@keyframes quad-grow-box {
    from {
        width: 120px
    }

    to {
        width: 300px
    }
}

@-webkit-keyframes quad-shrink {
    from {
        width: 300px
    }

    to {
        width: 120px
    }
}

@keyframes quad-shrink {
    from {
        width: 300px
    }

    to {
        width: 120px
    }
}

@-webkit-keyframes quad-grow {
    from {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    to {
        -webkit-transform: scale(3);
        transform: scale(3)
    }
}

@keyframes quad-grow {
    from {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    to {
        -webkit-transform: scale(3);
        transform: scale(3)
    }
}

@-webkit-keyframes quad-shrink {
    from {
        -webkit-transform: scale(3);
        transform: scale(3)
    }

    to {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

@keyframes quad-shrink {
    from {
        -webkit-transform: scale(3);
        transform: scale(3)
    }

    to {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

#references-section .bg-calculated {
    float: right;
    height: 1380px;
    top: -1740px
}

#references-section .bg-references {
    height: 760px;
    left: -260px;
    max-width: 750px;
    position: relative;
    top: 390px;
    width: 760px;
    background: url("../img/desktop_was_man-sieht.png") no-repeat;
    background-size: 100%
}

#references-section .button-references {
    top: 70px;
    left: 340px;
    border-radius: 100px 100px 10px 100px
}

.cis-orbit img {
    width: 800px;
    height: auto
}

.orbit-content ul {
    margin: 0
}

.orbit-content ul li {
    list-style: none
}

#references-section .button.small {
    text-align: left;
    font-size: .8rem;
    padding: .3rem;
    height: 50px;
    width: 130px;
    vertical-align: bottom;
    border-radius: 5px;
    background: #6e7a84;
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto
}

#references-section .button.small.active {
    height: 65px;
    font-weight: bold;
    background: #8a2d6a;
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto
}

#references-section .tabs .button a {
    display: block;
    width: 100%;
    height: 100%;
    color: #fff;
    font-size: .925rem;
    font-weight: normal;
    padding: 0 .5rem;
    outline: 0
}

#references-section .tabs .button span {
    position: absolute;
    bottom: 8px
}

#references-section .orbit-container {
    height: 1080px;
    overflow: hidden;
    cursor: pointer
}

#references-section .orbit-bullets li {
    width: 1rem;
    height: 1rem
}

#references-section .orbit-bullets .active {
    background: #8a2d6a
}

#about-section .bg-white.bg-calculated {
    height: 850px;
    top: -480px
}

#about-section .bg-about {
    height: 612px;
    left: -71px;
    max-width: 505px;
    position: relative;
    top: 23px;
    width: 505px;
    background: url("../img/desktop_wer_wir_sind.png") no-repeat
}

#about-section .bg-new-blue-full.bg-calculated {
    float: right;
    height: 900px;
    top: -1380px
}

#about-section .button-about {
    top: 70px;
    left: 5px;
    border-radius: 100px 100px 100px 10px;
    padding: 20px 20px 0
}

.about-box {
    color: #008ab7;
    cursor: pointer;
    margin-top: 150px;
    width: 240px;
    float: left;
    position: relative
}

.about-box .circle_bg {
    width: 140px;
    height: 140px;
    border-radius: 50% 50%;
    border: 5px solid #B1DDEA;
    background: #fff;
    -webkit-transform-origin: 50% 50%;
    -ms-transform-origin: 50% 50%;
    transform-origin: 50% 50%;
    outline: 1px solid transparent;
    margin: 0 auto
}

.about-box.growCircle {
    -webkit-animation: circle-grow-box .5s 0s 1 normal;
    animation: circle-grow-box .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.about-box.shrinkCircle {
    -webkit-animation: circle-shrink-box .5s 0s 1 normal;
    animation: circle-shrink-box .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.about-box.growCircle .circle_bg {
    -webkit-animation: circle-grow .5s 0s 1 normal;
    animation: circle-grow .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.about-box.shrinkCircle .circle_bg {
    -webkit-animation: circle-shrink .5s 0s 1 normal;
    animation: circle-shrink .5s 0s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.about-box h3 {
    display: block;
    position: absolute;
    top: 45px;
    width: 100%;
    text-align: center;
    color: #008ab7;
    font-size: .7rem;
    z-index: 3;
    -webkit-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out
}

.about-box p {
    display: block;
    position: absolute;
    top: 100px;
    left: 0;
    opacity: 0;
    width: 100%;
    height: 100px;
    overflow: hidden;
    text-align: center;
    font-size: .8rem;
    z-index: 3;
    -webkit-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out
}

.about-box.growCircle h3 {
    top: -110px;
    color: #fff;
    font-size: 1.125rem
}

.about-box.growCircle p {
    top: -50px;
    color: #fff;
    font-size: .8rem;
    height: auto;
    -webkit-animation: circle-fadein-text .5s .5s 1 normal;
    animation: circle-fadein-text .5s .5s 1 normal;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

-webkit-@keyframes circle-fadein-text {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes circle-fadein-text {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@-webkit-keyframes circle-grow-box {
    from {
        width: 240px
    }

    to {
        width: 340px
    }
}

@keyframes circle-grow-box {
    from {
        width: 240px
    }

    to {
        width: 340px
    }
}

@-webkit-keyframes circle-shrink-box {
    from {
        width: 340px
    }

    to {
        width: 240px
    }
}

@keyframes circle-shrink-box {
    from {
        width: 340px
    }

    to {
        width: 240px
    }
}

@-webkit-keyframes circle-grow {
    from {
        -webkit-transform: scale(1);
        transform: scale(1);
        border: 5px solid #B1DDEA;
        background: #fff;
        z-index: 1
    }

    to {
        -webkit-transform: scale(3);
        transform: scale(3);
        background: #008ab7;
        border: 1px solid #008ab7;
        z-index: 2
    }
}

@keyframes circle-grow {
    from {
        -webkit-transform: scale(1);
        transform: scale(1);
        border: 5px solid #B1DDEA;
        background: #fff;
        z-index: 1
    }

    to {
        -webkit-transform: scale(3);
        transform: scale(3);
        background: #008ab7;
        border: 1px solid #008ab7;
        z-index: 2
    }
}

@-webkit-keyframes circle-shrink {
    from {
        -webkit-transform: scale(3);
        transform: scale(3);
        background: #008ab7;
        border: 1px solid #008ab7;
        z-index: 2
    }

    to {
        -webkit-transform: scale(1);
        transform: scale(1);
        border: 5px solid #B1DDEA;
        background: #fff;
        z-index: 1
    }
}

@keyframes circle-shrink {
    from {
        -webkit-transform: scale(3);
        transform: scale(3);
        background: #008ab7;
        border: 1px solid #008ab7;
        z-index: 2
    }

    to {
        -webkit-transform: scale(1);
        transform: scale(1);
        border: 5px solid #B1DDEA;
        background: #fff;
        z-index: 1
    }
}

.list li {
    padding: 0 0 1rem 1rem !important;
    list-style: none;
    margin-left: -1.5rem
}

.about-box a {
    color: #fff;
    display: inline-block;
    font-size: .8rem;
    background: url(../img/arrow_right.svg) no-repeat 0 0;
    background-size: 18px 18px;
    padding-left: 1.5rem;
    margin-bottom: 1rem
}

#contact-section.contact-slide {
    position: fixed;
    right: 0;
    top: 15%;
    background: #fff;
    font-size: .875rem;
    z-index: 15
}

#contact-section.contact-slide label {
    color: #555
}

#contact-section.contact-slide label input,
#contact-section.contact-slide label textarea {
    color: #555;
    font-size: .875rem;
    padding: .3rem
}

#contact-section.contact-slide .close {
    position: absolute;
    top: 10px;
    right: 25px !important;
    width: 20px;
    height: 25px;
    padding: 0 !important
}

#contact-section .form-button {
    width: 125px;
    height: 40px;
    color: #fff;
    padding: .5rem;
    -ms-transform: rotate(270deg);
    -webkit-transform: rotate(270deg);
    transform: rotate(270deg);
    transform-origin: left top 0;
    position: absolute;
    top: 125px;
    left: -40px;
    z-index: 2;
    text-align: center;
    border-radius: 5px;
    font-size: 20px;
    text-transform: uppercase
}

.cis-contact {
    overflow-y: auto
}

.cis-contact button,
.cis-contact button:hover,
.cis-contact button:focus {
    background-color: #153D8A
}

.cis-contact button[type="submit"] {
    margin-right: 20px
}

#input_plz,
.label_plz {
    width: 25%;
    float: left;
    margin-right: 5%
}

#input_ort,
.label_ort {
    width: 70%;
    float: left
}

.mandatory_text {
    position: relative;
    padding: 0 0 0 5px
}

.mandatory_text:before {
    content: "*";
    position: absolute;
    left: 0
}

#footer-section {
    bottom: 0;
    margin: 0 auto;
    max-width: 100;
    position: absolute;
    width: 100%;
    z-index: 10
}

#footer-section,
#footer-section a {
    color: #fff
}

#footer-section .row {
    padding-top: .8rem;
    padding-bottom: .8rem;
    text-align: right
}

#footer-section a {
    display: inline-block;
    margin-right: 40px
}

#contact-section .label {
    padding: 1rem;
    position: absolute;
    top: -30px;
    vertical-align: center;
    font-size: 1.3rem
}

#contact-section .lead {
    font-size: 1.2rem;
    padding: 2rem 0rem .7rem 0rem
}

#contact-section p {
    font-size: 1rem
}

#impressum .columns {
    padding: 0 20px
}

#impressum .label {
    width: 130px;
    height: 40px;
    font-size: 1rem;
    vertical-align: center;
    text-transform: uppercase;
    padding-top: 12px;
    position: relative;
    top: -50px;
    left: 10px
}

#impressum #modal-impressum {
    padding-left: 30px
}

#impressum .lead {
    padding-top: 30px
}

.close {
    width: 50px;
    height: 50px;
    border-radius: 5px;
    color: white !important;
    text-align: center;
    padding: 5px !important
}

#menu-section-phone {
    display: none
}

#form-messages {
    padding: 20px 0;
    font-weight: bold;
    font-size: 1rem
}

#form-messages.error {
    color: #f04124
}

#contact-form .error {
    text-transform: none !important
}