
body, html
{
    margin: 0;
    padding: 0;
    width:100%;
    height:100%;
    min-height: 100%;

    background-color: #ffffff;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;

    overflow: hidden;
}

html {
    box-sizing: border-box;

    scroll-behavior: smooth;
}

*, *:before, *:after {
    font-family: 'Open Sans', sans-serif;
    box-sizing: inherit;
    margin: 0;
}

.CSite
{
    position: absolute;

    left: 0px;
    top: 0px;

    display: none;

    width: 100%;
    min-height: 100vh;

    overflow: hidden;

    background-color: #9cbfbd;
}

.CAnimation{
    -moz-animation-fill-mode: forwards;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;

    -moz-animation-play-state: paused;
    -webkit-animation-play-state: paused;
    animation-play-state: paused;
}

.CBackgroundImageContainer
{
    position: fixed;

    left: 0px;
    top: 0px;

    width: 100%;
    height: 100vh;

    background-position: center center;
    background-repeat: no-repeat;
    background-size: 800px 800px;

    /*
    -moz-animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    -moz-animation-name: CAnimation_ScaleIn;
    -moz-animation-duration: 2.0s;
    -moz-animation-delay: 0.0s;

    -webkit-animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    -webkit-animation-name: CAnimation_ScaleIn;
    -webkit-animation-duration: 2.0s;
    -webkit-animation-delay: 0.0s;

    animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    animation-name: CAnimation_ScaleIn;
    animation-duration: 2.0s;
    animation-delay: 0.0s;

     */
}

@-moz-keyframes CAnimation_Bubble {
    0%      { opacity: 1; -moz-transform: scale(1.4); }
    100%    { opacity: 1; -moz-transform: scale(1); }
}

@-webkit-keyframes CAnimation_Bubble {
    0%      { opacity: 1; -webkit-transform: scale(1.4); }
    100%    { opacity: 1; -webkit-transform: scale(1); }
}

@keyframes CAnimation_Bubble {
    0%      { transform: scale(1); }
    3%      { transform: scale(1.4); }
    6%      { transform: scale(0.8); }
    12%      { transform: scale(1.2); }
    24%     { transform: scale(0.9); }
    48%     { transform: scale(1.05); }
    96%     { transform: scale(1); }
    100%    { transform: scale(1); }
}

/***/

@-moz-keyframes CAnimation_ScaleIn {
    0%      { opacity: 1; -moz-transform: scale(1.4); }
    100%    { opacity: 1; -moz-transform: scale(1); }
}

@-webkit-keyframes CAnimation_ScaleIn {
    0%      { opacity: 1; -webkit-transform: scale(1.4); }
    100%    { opacity: 1; -webkit-transform: scale(1); }
}

@keyframes CAnimation_ScaleIn {
    0%      { opacity: 1; transform: scale(1.4); }
    100%    { opacity: 1; transform: scale(1); }
}

/***/

@-moz-keyframes CAnimation_BottomIn {
    0%      { opacity: 0; -moz-transform: translateY(20px); }
    100%    { opacity: 1; -moz-transform: translateY(0px); }
}

@-webkit-keyframes CAnimation_BottomIn {
    0%      { opacity: 0; -webkit-transform: translateY(20px); }
    100%    { opacity: 1; -webkit-transform: translateY(0px); }
}

@keyframes CAnimation_BottomIn {
    0%      { opacity: 0; transform: translateY(20px); }
    100%    { opacity: 1; transform: translateY(0px); }
}


.CFooter {
    position: absolute;

    left: 0px;
    bottom: 0px;

    width: 100%;
    height: 60px;

    padding: 16px;
}

.CFooter svg {
    fill: #ffffff;
}

.CTeamViewerTT {
    position: absolute;

    fill: #ffffff !important;
}

/*** PANEL ***/

.CPanelContainer {
    position: absolute;

    width: 100%;

    pointer-events: none;

    padding-left: calc((100% - 720px) / 2);
    padding-right: calc((100% - 720px) / 2);

    text-align: center;

    overflow: hidden;
}

.CPanel {
    position: relative;
    display: none;

    text-align: center;

    opacity: 0;

    -moz-transition-property: -moz-transform, opacity;
    -moz-transition-timing-function: ease, ease;
    -moz-transition-duration: 0.5s;

    -webkit-transition-property: -webkit-transform, opacity;
    -webkit-transition-timing-function: ease, ease;
    -webkit-transition-duration: 0.5s;

    transition-property: transform, opacity;
    transition-timing-function: ease, ease;
    transition-duration: 0.5s;
}

.CPanelSubContent {
    position: absolute;

    left: calc((100vw - 720px) / -2);
    top: calc(100vh - 72px);

    width: 100vw;
    height: 100%;
    background-color: #ffffff;
}

.CPanelTextContainer {
    padding: 40px;
}

/*** PANEL ***/

/*** Bubble ***/

.CInfoBubbleScrollWrapper
{
    position: relative;

    pointer-events: all;

    left: 0px;
    top: 0px;

    width: 100%;
    max-height: calc(50vh - 40px);

    overflow-x: hidden;
}

.CInfoBubbleContext
{
    position: relative;

    pointer-events: all;

    left: 0px;
    top: 0px;

    width: 100%;
    padding-right: 20px;
}

.CInfoBubble {
    position: absolute;

    pointer-events: all;

    display: block;
    opacity: 0;

    left: 50%;
    top: 50%;

    width: calc(50vw - 35vh);
    max-width: 600px;
    max-height: 50vh;

    padding-right: 20px;

    color: #ffffff;

    -moz-transition-property: opacity;
    -moz-transition-timing-function: ease;
    -moz-transition-duration: 0.5s;

    -webkit-transition-property: opacity;
    -webkit-transition-timing-function: ease;
    -webkit-transition-duration: 0.5s;

    transition-property: opacity;
    transition-timing-function: ease;
    transition-duration: 0.5s;


    -moz-transform: translateX(calc(-100% - 25vh)) translateY(calc(-50% + 36px));
    -webkit-transform: translateX(calc(-100% - 25vh)) translateY(calc(-50% + 36px));
    transform: translateX(calc(-100% - 25vh)) translateY(calc(-50% + 36px));
}

.CInfoBubble:before {
    position: absolute;

    display: block;

    content: "";

    right: -22px;
    top: 50%;

    width: 20px;
    height: 2px;

    background-color: #ffffff;
}

.CInfoBubble:after {
    position: absolute;

    display: block;

    content: "";

    right: -2px;
    top: 0px;

    width: 2px;
    height: 100%;

    background-color: #ffffff;
}

.CInfoBubbleCloseButton {
    display: none;
}

.CInfoBubbleShowButton {
    display: none;

    -moz-animation-timing-function: ease;
    -moz-animation-iteration-count: infinite;
    -moz-animation-name: CAnimation_Bubble;
    -moz-animation-duration: 5.0s;
    -moz-animation-delay: 0.0s;

    -webkit-animation-timing-function: ease;
    -webkit-animation-iteration-count: infinite;
    -webkit-animation-name: CAnimation_Bubble;
    -webkit-animation-duration: 5.0s;
    -webkit-animation-delay: 0.0s;

    animation-timing-function: ease;
    animation-iteration-count: infinite;
    animation-name: CAnimation_Bubble;
    animation-duration: 5.0s;
    animation-delay: 0.0s;
}

.CInfoBubble p {
    position: relative;

    color: #ffffff;
}

/*** Bubble ***/


/*** TEXT ***/

h1 {
    position: relative;

    font-family: proxima-nova, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 24px;

    opacity: 0;

    text-transform: uppercase;
    line-height: 1;

    color: #ffffff;

    -moz-animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    -moz-animation-name: CAnimation_BottomIn;
    -moz-animation-duration: 1.0s;
    -moz-animation-fill-mode: forwards;
    -moz-animation-delay: 0.0s;

    -webkit-animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    -webkit-animation-name: CAnimation_BottomIn;
    -webkit-animation-duration: 1.0s;
    -webkit-animation-fill-mode: forwards;
    -webkit-animation-delay: 0.0s;

    animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    animation-name: CAnimation_BottomIn;
    animation-duration: 1.0s;
    animation-fill-mode: forwards;
    animation-delay: 0.0s;
}

h2 {
    position: relative;

    font-family: proxima-nova, sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: 40px;

    opacity: 0;

    line-height: 1;

    color: #ffffff;

    -moz-animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    -moz-animation-name: CAnimation_BottomIn;
    -moz-animation-duration: 1.0s;
    -moz-animation-fill-mode: forwards;
    -moz-animation-delay: 0.1s;

    -webkit-animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    -webkit-animation-name: CAnimation_BottomIn;
    -webkit-animation-duration: 1.0s;
    -webkit-animation-fill-mode: forwards;
    -webkit-animation-delay: 0.1s;

    animation-timing-function: cubic-bezier(0.140, 0.895, 0.555, 0.985);
    animation-name: CAnimation_BottomIn;
    animation-duration: 1.0s;
    animation-fill-mode: forwards;
    animation-delay: 0.1s;
}

h3 {
    position: relative;

    font-family: proxima-nova, sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: 18px;

    line-height: 1;

    color: #333333;

    margin-top: 20px;
    margin-bottom: 20px;

    text-align: left !important;
}

h4 {
    position: relative;

    font-family: proxima-nova, sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: 18px;

    line-height: 1;

    color: #ffffff;

    margin-top: 20px;
    margin-bottom: 10px;

    text-align: left !important;
}

p {
    position: relative;

    font-family: proxima-nova, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 18px;

    text-align: left !important;

    line-height: 1.6;

    color: #333333;
}

a, a:link, a:active, a:visited {
    position: relative;

    pointer-events: all;

    font-family: proxima-nova, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: inherit;

    text-align: left !important;

    line-height: 1.6;

    color: #ffffff;
}

a:hover {
    text-decoration: none;
}

.CInfoBoxNavigationItem {
    display: inline-block;
    width: 100%;
    font-size: 18px !important;
    left: 30px;
}

.CInfoBoxNavigationItem:before {
    position: absolute;

    left: -30px;
    top: 1px;

    content: url("../resources/images/arrow.svg");

    display: block;
}

li {
    position: relative;

    font-family: proxima-nova, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 18px;

    text-align: left !important;

    line-height: 1.6;

    color: #333333;
}

.CButton {
    position: relative;

    cursor: pointer;
    pointer-events: all;

    display: inline-block;

    margin-top: 20px;

    padding: 20px;
    padding-top: 8px;
    padding-bottom: 8px;

    background-color: #ffffff;

    -moz-border: #004680 2px solid;
    -webkit-border: #004680 2px solid;
    border: #004680 2px solid;

    -moz-border-radius: 40px;
    -webkit-border-radius: 40px;
    border-radius: 40px;

    font-family: proxima-nova, sans-serif;
    font-weight: 700;
    font-style: normal;
    color: #004680;

    -moz-transition-property: background-color;
    -moz-transition-duration: 0.5s;
    -moz-transition-timing-function: ease;

    -webkit-transition-property: background-color;
    -webkit-transition-duration: 0.5s;
    -webkit-transition-timing-function: ease;

    transition-property: background-color;
    transition-duration: 0.5s;
    transition-timing-function: ease;
}

.CButton:hover {
    background-color: #004680;
    color: #ffffff;
}

.CNextThemeButton {
    position: absolute;

    cursor: pointer;
    pointer-events: all;

    display: inline-block;

    left: 50%;
    bottom: 6vh;

    white-space: nowrap;

    padding: 20px;
    padding-top: 8px;
    padding-bottom: 8px;

    background-color: #ffffff;

    -moz-border: #ffffff 2px solid;
    -webkit-border: #ffffff 2px solid;
    border: #ffffff 2px solid;

    -moz-border-radius: 40px;
    -webkit-border-radius: 40px;
    border-radius: 40px;

    -moz-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);

    font-family: proxima-nova, sans-serif;
    font-weight: 700;
    font-style: normal;
    color: #004680;

    -moz-transition-property: background-color;
    -moz-transition-duration: 0.5s;
    -moz-transition-timing-function: ease;

    -webkit-transition-property: background-color;
    -webkit-transition-duration: 0.5s;
    -webkit-transition-timing-function: ease;

    transition-property: background-color;
    transition-duration: 0.5s;
    transition-timing-function: ease;
}

.CNextThemeButton:hover {


    background-color: #004680;
    color: #ffffff;

    -moz-border: #004680 2px solid;
    -webkit-border: #004680 2px solid;
    border: #004680 2px solid;
}

.CPanelSpacer {
    position: relative;

    width: 100%;
    height: 100vh;
}

/*** TEXT ***/

.CHeaderSpacer {
    position: relative;

    width: 100%;

    height: 10px;
}


/*** VIDEO ***/

.CBackgroundVideoContainer {
    position: absolute;

    left: 0px;
    top: 0px;

    width: 100%;
    height: calc(100%);
}

.CBackgroundVideoContainer video {
    position: absolute;

    left: 50%;
    top: 0px;

    width: auto;
    height: 100%;

    -moz-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

/*** VIDEO ***/

/*** Vertical Navigation ***/

.CNavigation {
    position: absolute;

    right: 50px;
    top: calc(50% - 110px);

    width: 50px;
    height: 360px;

    text-align: center;
    vertical-align: center;
}

.CNavigationItem {
    position: relative;

    display: inline-block;

    cursor: pointer;
    pointer-events: all;

    margin-top: 0px;
    margin-bottom: 0px;

    width: 40px;
    height: 40px;

    text-align: center;
    vertical-align: center;
}

.CNavigationItem:hover > .CNavigationItemGfx {

    -moz-transform: scale(1.4);
    -webkit-transform: scale(1.4);
    transform: scale(1.4);
}

.CNavigationItem:hover > .CNavigationItemLabel {

    opacity: 1;

    -moz-transform: translateX(0px);
    -webkit-transform: translateX(0px);
    transform: translateX(0px);
}



.CNavigationItemActive > .CNavigationItemGfx {
    -moz-transform: scale(1.4) !important;
    -webkit-transform: scale(1.4) !important;
    transform: scale(1.4) !important;
}



.CNavigationItemActive > .CNavigationItemLabel {
    opacity: 1 !important;

    -moz-transform: translateX(0px) !important;
    -webkit-transform: translateX(0px) !important;
    transform: translateX(0px) !important;
}

.CNavigationItemGfx {

    position: absolute;

    pointer-events: none;

    line-height: 21px;
    font-family: proxima-nova, sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: 10px;
    text-align: center;
    vertical-align: center;
    color: #004680;

    left: 10px;
    top: 10px;

    display: inline-block;

    width: 20px;
    height: 20px;

    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    border-radius: 10px;

    -moz-transition-property: -moz-transform;
    -moz-transition-duration: 0.5s;
    -moz-transition-timing-function: ease;

    -webkit-transition-property: -webkit-transform;
    -webkit-transition-duration: 0.5s;
    -webkit-transition-timing-function: ease;

    transition-property: transform;
    transition-duration: 0.5s;
    transition-timing-function: ease;

    background-color: #ffffff;
}

.CNavigationItemLabel {
    position: absolute;

    white-space: nowrap;

    opacity: 0;

    right: 50px;
    top: 8px;

    color: #ffffff;

    -moz-transform: translateX(-20px);
    -webkit-transform: translateX(-20px);
    transform: translateX(-20px);

    -moz-transition-property: -moz-transform, opacity;
    -moz-transition-duration: 0.5s, 0.5s;
    -moz-transition-timing-function: ease, ease;

    -webkit-transition-property: -webkit-transform, opacity;
    -webkit-transition-duration: 0.5s, 0.5s;
    -webkit-transition-timing-function: ease, ease;

    transition-property: transform, opacity;
    transition-duration: 0.5s, 0.5s;
    transition-timing-function: ease, ease;
}

/*** Vertical Navigation ***/

.CDatenschutz {
    position: absolute !important;

    display: block;

    left: 0px;
    bottom: 0px;

    padding: 5px 10px 5px 10px;

    text-decoration: underline;

    color: #ffffff;

    text-transform: uppercase;
    font-size: 10px !important;
}

.CDatenschutz:hover {
    color: #cccccc !important;
}

.CDatenschutz:visited {
    color: #ffffff;
}


@media only screen
and (max-width: 1920px)
{
    h1 {
        font-size: 18px;

    }

    h2 {
        font-size: 32px;
    }

    h4 {
        font-size: 16px;
    }

    p {
        font-size: 16px;
        line-height: 1.6;
    }

    .CInfoBubble p {
        position: relative;
        font-size: 16px;

        color: #ffffff;
    }

    li {
        font-size: 16px;
    }

    .CInfoBoxNavigationItem {
        font-size: 16px !important;
    }
}

@media only screen
and (max-width: 1366px)
{
    h1 {
        font-size: 18px;

    }

    h2 {
        font-size: 32px;
    }

    h4 {
        font-size: 14px;
    }

    p {
        font-size: 14px;
        line-height: 1.6;
    }

    .CInfoBubble p {
        position: relative;
        font-size: 14px;

        color: #ffffff;
    }

    li {
        font-size: 14px;
    }

    .CInfoBoxNavigationItem {
        font-size: 14px !important;
    }

}

@media only screen
and (max-width: 1024px)
{
    h1 {
        font-size: 18px;
    }

    h2 {
        font-size: 24px;
    }

    h4 {
        font-size: 14px;
    }

    p {
        font-size: 14px;
        line-height: 1.6;
    }

    .CInfoBubble p {
        position: relative;
        font-size: 14px;

        color: #ffffff;
    }

    li {
        font-size: 14px;
    }

    .CInfoBoxNavigationItem {
        font-size: 14px !important;
    }

    .CNextThemeButton {
        left: 50%;
        bottom: calc(6vh + 60px);

        box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2);
    }



    .CNavigation {
        right: -5px;
        top: calc(50% - 153px);
    }

    .CNavigationItemLabel {
        display: none;
    }

    .CFooter {
        bottom: auto;

        height: 40px;
        padding: 10px;
    }

    .CFooter svg {
        width: 80px;
        height: 20px;
    }

    .CInfoBubble {

        left: 20px;
        top: 50%;

        width: calc(100% - 40px);
        max-height: 50vh;

        padding: 20px;
        padding-right: 40px;

        -moz-transform: translateY(calc(-50% - 6px));
        -webkit-transform: translateY(calc(-50% - 6px));
        transform: translateY(calc(-50% - 6px));

        background-color: rgba(0, 0, 0, 0.75);

        -moz-border-radius: 20px;
        -webkit-border-radius: 20px;
        border-radius: 20px;
    }

    .CInfoBubble:before { display: none; }
    .CInfoBubble:after { display: none; }

    .CInfoBubbleCloseButton {
        position: absolute;

        display: block;

        right : 0px;
        top: 0px;

        width: 40px;
        height: 40px;

        -moz-border-radius: 20px;
        -webkit-border-radius: 20px;
        border-radius: 20px;

        padding: 12px;

        color: #ffffff;
    }

    .CInfoBubbleShowButton {
        position: absolute;

        display: block;

        opacity: 0;

        left : 20px;
        top: 32%;

        width: 40px;
        height: 40px;

        -moz-border-radius: 20px;
        -webkit-border-radius: 20px;
        border-radius: 20px;

        padding: 3px;

        background-color: #ffffff;

        text-align: center;

        -moz-transition-property: opacity;
        -moz-transition-duration: 0.5s;
        -moz-transition-timing-function: ease;

        -webkit-transition-property: opacity;
        -webkit-transition-duration: 0.5s;
        -webkit-transition-timing-function: ease;

        transition-property: opacity;
        transition-duration: 0.5s;
        transition-timing-function: ease;


        font-family: proxima-nova, sans-serif;
        font-weight: 700;
        font-style: normal;
        font-size: 24px;
        vertical-align: center;
        color: #004680;
    }

}