@font-face {
    font-family: 'Source Sans Pro';
    font-style: normal;
    font-weight: 300;
    src: url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-300.eot.xhtml?ln=manhattan-layout");
    /* IE9 Compat Modes */
    src: local("Source Sans Pro Light"), local("SourceSansPro-Light"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-300.eot.xhtml?ln=manhattan-layout#iefix") format("embedded-opentype"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-300.woff2.xhtml?ln=manhattan-layout") format("woff2"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-300.woff.xhtml?ln=manhattan-layout") format("woff"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-300.ttf.xhtml?ln=manhattan-layout") format("truetype"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-300.svg.xhtml?ln=manhattan-layout#SourceSansPro") format("svg");
    /* Legacy iOS */
}

/* source-sans-pro-regular - latin-ext_latin */
@font-face {
    font-family: 'Source Sans Pro';
    font-style: normal;
    font-weight: 400;
    src: url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-regular.eot.xhtml?ln=manhattan-layout");
    /* IE9 Compat Modes */
    src: local("Source Sans Pro Regular"), local("SourceSansPro-Regular"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-regular.eot.xhtml?ln=manhattan-layout#iefix") format("embedded-opentype"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-regular.woff2.xhtml?ln=manhattan-layout") format("woff2"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-regular.woff.xhtml?ln=manhattan-layout") format("woff"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-regular.ttf.xhtml?ln=manhattan-layout") format("truetype"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-regular.svg.xhtml?ln=manhattan-layout#SourceSansPro") format("svg");
    /* Legacy iOS */
}

/* source-sans-pro-700 - latin-ext_latin */
@font-face {
    font-family: 'Source Sans Pro';
    font-style: normal;
    font-weight: 700;
    src: url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-700.eot.xhtml?ln=manhattan-layout");
    /* IE9 Compat Modes */
    src: local("Source Sans Pro Bold"), local("SourceSansPro-Bold"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-700.eot.xhtml?ln=manhattan-layout#iefix") format("embedded-opentype"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-700.woff2.xhtml?ln=manhattan-layout") format("woff2"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-700.woff.xhtml?ln=manhattan-layout") format("woff"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-700.ttf.xhtml?ln=manhattan-layout") format("truetype"), url("/reifegrad/javax.faces.resource/fonts/source-sans-pro-v10-latin-ext_latin-700.svg.xhtml?ln=manhattan-layout#SourceSansPro") format("svg");
    /* Legacy iOS */
}

/**********ALLGEMEIN*********/
.landing-body {
    background: #f4f4f4;
    margin: 0;
    padding: 0;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 16px;
    color: #333333
}


.ueberschrift p {
    font-weight: 600;
    font-size: 25px;
    text-align: center;
    color: #70ad47;
}

.text-paragraph p {
    margin-left: 1rem;
    margin-right: 1rem;
    text-align: justify;
    line-height: 1.5rem;
}


.div-width {
    max-width: 90rem;
    margin: auto;
}

#btt {
    position: fixed;
    right: 10px;
    bottom: 50px;
    cursor: pointer;
    width: 50px;
    height: 50px;
    height: 50px;
    z-index: 999;
    /*background-color:#005073;*/
    background-color: #70ad47;
    display: none;
    -webkit-border-radius: 60px;
    -moz-border-radius: 60px;
    border-radius: 60px;
}

#btt span {
    position: absolute;
    top: 8%;
    left: 40%;
    margin-left: -8px;
    margin-top: 0px;
    height: 0;
    width: 0;
    border: 13px solid transparent;
    border-bottom-color: #ffffff;
}

#btt:hover {
    /*background-color:#136a8a;*/
    background-color: #005073;
    opacity: 1;
    filter: "alpha(opacity=100)";
    -ms-filter: "alpha(opacity=100)";
}

.divider {
    display: block;
    border: none;
    color: white;
    height: 2px;
    background: black;
    background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 1000, from(#d9dae3), to(#fff));
}

@media (min-width: 40.64em) and (max-width: 64.063em) {
    .divider {
        background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 700, from(#d9dae3), to(#fff));
    }
}

@media (min-width: 26.5626rem) and (max-width: 40.063em) {
    .divider {
        background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 400, from(#d9dae3), to(#fff));
    }
}

@media (min-width: 0) and (max-width: 26.5625rem) {
    .divider {
        background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 200, from(#d9dae3), to(#fff));
    }
}

/**********Header**********/
.landing-body .landing-menu {
    list-style-type: none;
    margin: 25px 0 0 0;
    padding: 0;
    text-align: center;
}

.landing-body .landing-menu li {
    display: inline-block;
    font-size: 16px;
    margin-left: 36px;
}

.landing-body .landing-menu li:first-child {
    margin-left: 0;
}

.landing-body .landing-menu li a {
    color: #F0F3F5;
    border-bottom: 1px solid transparent;
    transition: border-bottom-color 0.3s;
}

.landing-body .landing-menu li a:hover {
    border-bottom-color: #F0F3F5;
    border-radius: 2px;
}

.landing-body #header {
    /*background-color: #005073;}*/
    /**background-color: #70ad47;*/
    background-color: rgba(112, 173, 71, 0.9);
    border-bottom: 1px solid white;

}

.header-logo {
    height: 4rem;
    max-height: 6rem;
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
    image-rendering: pixelated;
}

@media (min-width: 40.64em) and (max-width: 64.063em) {
    .landing-body .landing-menu li {
    }
}

@media (min-width: 26.5626rem) and (max-width: 40.063em) {
    .landing-body .landing-menu {
        margin: 0;
    }

    .landing-body .landing-menu li {
        margin: 0;
        text-align: right;
        display: block;
    }
}

@media (min-width: 0) and (max-width: 26.5625rem) {
    .landing-body .landing-menu {
        margin-top: 0;
    }

    .landing-body .landing-menu li {
        display: block;
        text-align: right;
        margin-top: 0;
        margin-left: 0;
    }

    .header-logo {
        height: auto;
        width: 100%;
    }
}

.btnDiv {
    padding-top: 20px;
    max-width: 25rem;
    height: 3rem;
    margin: auto;
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    .green-background {
        background-color: rgba(112, 173, 71, 0.9);
        border-top: 2px solid #ed7d31;
    }
}

#heroshot .btnDiv .ui-button {
    background: #ed7d31;
    font-size: 16px;
    width: 100%;
    height: 100%;
    /**box-shadow: 0 1px 2.5px 0 rgba(0, 0, 0, 0.26), 0 1px 5px 0 rgba(0, 0, 0, 0.16); **/
    cursor: pointer;
}

.scrollLink:hover {
    background: #ed7d31;
    color: white;
    transition: 0.4s;
}

#heroshot iframe {
    width: 100%;
    height: 19.6875rem;
}

#heroshot .iframe-wrapper {
    max-width: 35rem;
    margin: 3rem auto;
}

#heroshot .text-paragraph h1 {
    color: #70ad47;
}

@media (min-width: 0) and (max-width: 64.062em) {
    #heroshot .seethrough {
        padding: 0;
    }

    #heroshot .iframe-wrapper {
        margin-top: 0;
    }

    #heroshot .heroshot-logo {
        margin-top: 2rem;
    }
}

/**********Digitalisierung**********/
#digitalisierung {
    padding-top: 0rem;
    padding-bottom: 6rem;
}

#digitalisierung .box {
    background: #ffffff;
    /*border: 0.2rem solid #136a8a;*/
    min-width: 50rem;
}

#digitalisierung .picture {
    width: 90%;
}

#digitalisierung .picture-wrapper {
    text-align: center;
}

#digitalisierung .box .ueberschrift p {
    color: #4E9DC0;
}

@media (min-width: 0) and (max-width: 64.062em) {
    #digitalisierung .picture {
        width: 50%;
    }

    #digitalisierung .box {
        min-width: 0;
    }
}

/**********Reifegrad Beschreibung**********/
#beschreibung {
    background-color: white;
    /*padding-bottom: 1.875rem;*/
    padding-top: 3rem;
    padding-bottom: 6rem;
}

#beschreibung .beschreibung-kasten {
    border: 3px solid darkgrey;
    border-radius: 6px;
    background-color: white;
}

.gestaltungsfeld-card-header-area {
    min-height: 5rem;
    margin-top: 4rem;
}

.dashboard-icon-area {
    background-color: #fff;
    border-radius: 50%;
    width: 7rem;
    height: 7rem;
    border: 3px solid #70ad47;
    margin: auto;
}

.gestaltungsfeld-card-icon-area {
    display: table;
    margin-top: 0.8rem;
    margin-right: auto;
    margin-left: auto;
    text-align: center;
}

.gestaltungsfeld-card-icon {
    font-size: 4.4rem;
    color: #70ad47;
}

/**ALTE KARTEN**/
/*.flip-card {
    background-color: transparent;
    height: 23rem;
    perspective: 1000px;
}

.flip-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    text-align: center;
    transition: transform;
    transition-duration: 1.2s;
    transform-style: preserve-3d;
}

.flip-card:hover .flip-card-inner {
    transform: rotateY(180deg);

}

.flip-card-front, .flip-card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
}

.flip-card-front {
    background-color: #70ad47;
    color: #fff;
}

.flip-card-back {
    background-color: #70ad47;
    color: #333333;
    transform: rotateY(180deg);
}

.flip-card-back-inner {
    margin: 2px;
    background-color: #fff;
    height: 22.75rem;
}*/

/*.flip-card-back p {*/
/*margin: auto;*/
/*padding: 0.7rem;*/
/*}*/

.card-text p {
    margin-left: 1rem;
    margin-right: 1rem;
    text-align: justify;
    line-height: 1.5rem;
    font-size: 14px;
}

.card-text-list p {
    margin: 0;
    padding: 0;
}

.footer-text {
    margin-left: 2.2rem;
    margin-right: 2.2rem;
}

#beschreibung .invisible {
}

@media (min-width: 0) and (max-width: 40.063em) {
    .invisible {
        padding: 0;
    }
}

/**KARTEN FÜR INTERNET EXPLORER**/
.flip-container {
    perspective: 1000px;
    transform-style: preserve-3d;
}

.flip-container:hover .back {
    transform: rotateY(0deg);
}

.flip-container:hover .front {
    transform: rotateY(180deg);
}

.flip-container, .front, .back {
    width: 100%;
    height: 23rem;
}

.flipper {
    transition: 1.2s;
    transform-style: preserve-3d;

    position: relative;
}

.front, .back {
    backface-visibility: hidden;
    transition: 1.2s;
    transform-style: preserve-3d;

    position: absolute;
    top: 0;
    left: 0;
}

.front {
    text-align: center;
    z-index: 2;
    transform: rotateY(0deg);
    background-color: #70ad47;
    color: #fff;
}

.back {
    transform: rotateY(-180deg);
    background-color: #ffffff;
    color: #333333;
    border: 2px solid #70ad47;
    box-sizing: border-box;
}


/**********Roadmap**********/
#roadmap {
    padding-top: 3rem;
    padding-bottom: 6rem;
}

#roadmap .picture-div {
    min-height: 12rem;
    text-align: center;
    background: #ffffff;
    padding-top: 1rem;
}

#roadmap .picture {
    max-width: 8rem;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
}

#roadmap .text-div {
    background: #ffffff;
    padding: 1rem 2rem 1rem 0;
}

#roadmap .text-paragraph h2 {
    color: #70ad47;
}

#roadmap .invisible-div {
}


@media (min-width: 0) and (max-width: 40rem) {
    #roadmap .picture-div {
        min-height: 0;
        background: none;
        margin-bottom: 0;
        padding: 0;
    }

    #roadmap .picture {
        display: none;
    }

    #roadmap .invisible-div {
        display: none;
    }

    #roadmap .text-div {
        padding: 0 2rem 1rem 2rem;
    }
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    #roadmap .picture {
        top: unset;
        transform: none;
    }
}

/**********Referenzen**********/
#referenzen {
    background-color: white;
    padding-top: 3rem;
    padding-bottom: 6rem;
}

.content {
    box-sizing: border-box;
    display: block;
    margin: auto;
    padding: 10px;
    height: 10rem;
    width: auto;
    max-width: 500px;
}

/*@media (min-width: 0) and (max-width: 64.062em) {*/
/*    .content {*/
/*        height: auto;*/
/*        width: 50%;*/
/*    }*/
/*}*/

.ui-galleria-frame {
    margin-right: 20px;
}

@media (min-width: 426px) and (max-width: 925px) {
    .ui-galleria-filmstrip-wrapper {
        width: 90% !important;
    }
    .ui-galleria {
        width: 100% !important;
    }
    .ui-galleria-panel-wrapper, .ui-galleria-panel {
        width: 100% !important;
    }
    .content {
        max-width: 420px;
    }
}

@media (max-width: 425px) {
    .ui-galleria-filmstrip-wrapper, .ui-galleria-filmstrip {
        display: none;
    }
    body .ui-galleria .ui-galleria-nav-prev {
        display: none;
    }
    body .ui-galleria .ui-galleria-nav-next {
        display: none;
    }
    .ui-galleria {
        width: 100% !important;
    }
    .ui-galleria-panel-wrapper, .ui-galleria-panel {
        width: 100% !important;
        height: 100px !important;
    }
    .content {
        max-height: 5rem;
        max-width: 300px;
    }
}



/**********Preisliste**********/
#preisliste {
    text-align: center;
    /*padding-bottom: 1.875rem;*/
    padding-top: 3rem;
    padding-bottom: 6rem;
}

#preisliste > div {
    text-align: center;
}

#preisliste .border {
    border: solid 1px #d9dae3;
    height: 100%;
    width: 75%;
    margin: auto;
    color: #6a6a7d;
    box-sizing: border-box;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
}

#preisliste .border h3 {
    font-size: 18px;
    margin: 0 0 5px 0;
    color: #ffffff;
}

#preisliste .header {
    background-color: #70ad47;
    padding: 30px;
}

#preisliste .header .font {
    color: #c4dfb2;
    font-weight: bold;
}

#preisliste .body {
    padding: 20px 30px;
    background-color: white;
    min-height: 37rem;
}

#preisliste .body ul {
    list-style-type: none;
    min-height: 7rem;
    padding: 0;
    margin: 0;
}

#preisliste .body ul li {
    text-align: justify;
    line-height: 1.5;
}

#preisliste .body ul li h3 {
    color: #6a6a7d;
    text-align: center;
    margin-bottom: 18px;
}

#preisliste .button {
    background-color: #ed7d31;
    color: #ffffff;
    margin-top: 1.5rem;
    width: 75%;
}

#preisliste .product-button {
    width: 100%;
    height: 5rem;
    background-color: #ffffff;
    border-top: solid 1px #d9dae3;
}

#preisliste .button:hover {
    cursor: pointer;
    background-color: #ee8a45;
}

@media (min-width: 0) and (max-width: 375px) {
    #preisliste .border {
        width: 100%;
    }
}


/**********Footer**********/
#home-footer {
    background: #F0F3F5;
    border-top: 1px solid #d9dae3;
}

#home-footer a {
    color: #333333;
    vertical-align: middle;
}

#home-footer a:hover {
    border-bottom-color: #005073;
}

#home-footer .logo {
    width: 10rem;
    vertical-align: middle;
    margin-right: 1.5rem;
    margin-left: 2rem;
    display: inline-block;
    height: 100%;
    padding: 0.2rem;
}

#home-footer .copyright {
    text-align: left;
    margin-top: auto;
    margin-bottom: auto
}

#home-footer .links {
    list-style-type: none;
    text-align: right;
}

#home-footer .links li {
    display: inline-block;
    margin-left: 1rem;
}

#home-footer .border {
    border-top: 1px solid #d9dae3;
}

#home-footer .border1 {
}

#home-footer .border2 {
    border-top: 1px solid #d9dae3;
}

#home-footer ul {
    padding: 0;
    margin-right: 3rem;
}

@media (min-width: 40.064em) and (max-width: 64.062em) {
    #home-footer .links {
        text-align: left;
    }

    #home-footer a {
        margin-left: 24px;
    }
}

@media (min-width: 0) and (max-width: 40.063em) {
    #home-footer .links {
        text-align: left;
    }

    #home-footer .logo {
        margin-left: 0;
        margin-right: 0;
    }

    #home-footer a {
        margin-left: 0;
    }

    #home-footer .links li:first-child {
        margin-left: 0;
    }

}


@media (min-width: 0) and (max-width: 425px) {
    .text-paragraph p {
        padding: 0;
    }
}


/**************Allgemeine Vertragsbedingungen***************/
#allgemeineVertragsbedingungen {
    background-color: #ffffff;
    width: 80%;
    margin: 3rem auto;
    padding: 3rem;
}

/**************Impressum**************/
#impressum {
    background-color: #ffffff;
    width: 80%;
    margin: 3rem auto;
    padding: 3rem;
}

.ui-dialog .ui-dialog-titlebar {
    background: #136a8a !important;
}

/*************Datenschutz*************/
#datenschutz {
    background-color: #ffffff;
    width: 80%;
    margin: 3rem auto;
    padding: 3rem;
}

:root {
    --base:              rgba(112, 173, 71, 0.9);
    --bg-blend:          multiply;
    --blur:              0px;
    --fg-blend:          lighten;
    --foreground:        #090808;
    --opacity:           1.0;
    --spacing:           0px;
}
.img-wrapper {
    background-color:    var(--base);
    display:             flex;
    flex:                1 1 100%;
    height:              100%;
    overflow:            hidden;
    padding:             var(--spacing);
    position:            relative;
}

.img-wrapper img {
    filter:              grayscale(100%) contrast(1) blur(var(--blur));
    flex:                1 0 100%;
    height:              100%;
    max-width:           100%;
    mix-blend-mode:      var(--bg-blend);
    object-fit:          cover;
    opacity:             var(--opacity);
    position:            relative;
    width:               100%;
}

.img-wrapper::before {
    background-color:    var(--foreground);
    bottom:              0;
    content:             '';
    height:              100%;
    left:                0;
    mix-blend-mode:      var(--fg-blend);
    position:            absolute;
    right:               0;
    top:                 0;
    width:               100%;
    z-index:             1;
}

/**********Hero Shot**********/
#heroshot .image {
    background-image: url("/reifegrad/javax.faces.resource/images/home/sewage_plant.svg.xhtml?ln=iww-layout");
    min-height: 45rem;
    width: 100%;
    background-size: cover;
    text-align: center;
    background-position-y: -2rem;
    filter:              grayscale(100%) contrast(1) blur(var(--blur));
    opacity:             var(--opacity);
    mix-blend-mode:      var(--bg-blend);
}

#heroshot .seethrough {
    margin: 7rem 0rem 0rem 0rem;
    min-height: 24rem;
    background-color: rgba(255, 255, 255, 0.0);
    /**background-image: linear-gradient(to right, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.75), rgba(255, 255, 255, 0.3), rgba(255, 255, 255, 0.0)); **/
    padding: 30px 30px 30px 30px;
    /** box-shadow: 0 6px 20px 0 rgba(0, 0, 0, 0.19), 0 8px 17px 0 rgba(0, 0, 0, 0.2); **/
    color: #333333;
    transition: 0.5s;
}

#heroshot .heroshot-logo {
    width: 80%;
    height: auto;
    max-width: 33rem;
}


