* {
    box-sizing: border-box;
}

body {
    background-color: #f1f4f8;
    font-family: 'PT Sans', sans-serif;
    font-size: 70%;
    color: rgba(47,47,47,0.863);
}

@media screen and (min-width: 375px) {
    body { font-size: 80%; }
}

@media screen and (min-width: 550px) {
    body { font-size: 100%; }
}

img {
    display: block;
    max-width: 100%;
    height: auto;
}

a {
    text-decoration: none;
    color: inherit;
}

.hidden {
    position: absolute;
    top: -999em;
    left: -999em;
}

.button {
    background: #f3771a;
    border-bottom: 3px solid rgba(0,0,0,0.2);
    color: #fff;
    font-weight: bold;
    font-size: 2.5em;
    line-height: 1.4;
    display: inline-block;
    width: 100%;
    text-shadow: 1px 1px 0px rgba(0,0,0,0.2);
    text-align: center;
    padding: .325em .875em;
    
    /*animation: rocking 2s infinite;
    animation-timing-function: cubic-bezier(0, 0, 0.58, 1);*/
    transition: .2s;
}
.button:hover { opacity: .9; }

p {
    line-height: 1.5;
    font-size: 1.5em;
    margin: 0 0 1.5em 0;
}
p:last-child { margin-bottom: 0; }

ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

em {
    font-style: normal;
    font-weight: bold;
}

.row {
    padding: 1em;
}

.container {
    max-width: 1170px;
    margin: 0 auto;
}

.center { text-align: center; }

.site-header {
    background-color: #fff;
    border: 3px solid rgba(0, 0, 0, 0.137);
    border-left: none;
    border-right: none;
    padding: 1.3em;
}

.site-header .container {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.adv {
    position: absolute;
    right: 2em;
    top: 0;
    font-size: 70%;
    color: #999;
}

.site-header .logo { 
    display: block; 
    max-width: 140px;
    margin: 0; 
}

.site-intro {
    padding-top: 3em;
    padding-bottom: 2.5em;
}

.site-intro h1 {
    font-size: 2em;
    line-height: 1.3;
    padding: 0 .75em;
    margin: 0 0 1.3em 0;
}

.facebook-btn {
    background-color: #4267b2;
    border: 1px solid rgba(0,0,0,0.2);
    border-radius: 3px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.2);
    color: #fff;
    font-size: 0.750em;
    font-weight: bold;
    line-height: 1.4;
    display: inline-block;
    padding: .833em 2.083em;
    margin-left: 7em;
}
.facebook-btn:hover { opacity: .85; }

.facebook-btn .fab { margin-right: .7em; }

.bekannt-aus {
    display: flex;
    flex-wrap: wrap; 
    align-items: center;
    font-size: 1.2em;
    margin-left: 3em;
}

.bekannt-aus ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.bekannt-aus p {
    line-height: normal;
    font-size: 1em;
    color: #888;
    letter-spacing: .03em;
    margin: 0 .5em 0 0;
}
@media screen and (min-width: 600px) {
    .bekannt-aus p {
        font-size: 1em;
        margin-right: 0.5em;
        margin-bottom: 0;
    }
}

.bekannt-aus li:not(:last-child) { margin-right: .5em; }

.bekannt-aus figure { margin: 0; }

.bekannt-aus img {
    display: block;
    max-width: 80px;
    opacity: .8;
}

.site-intro .image {
    max-width: 700px;
    margin: 2.3em auto 0 auto;
}

.site-content {
    background-color: #fff;
    border-bottom: 3px solid rgba(47,47,47,0.15);
    border-radius: 10px;
    padding: 2rem 2rem 3rem 2rem;
}

.site-content .image.kommentare {
    margin: 0 0 1em 0;
}

.image.selbsttest { text-align: center; }
.image.selbsttest > a { display: inline-block; }
@media screen and (min-width: 550px) {
    .image.selbsttest img {
        max-width: 30em;
    }
}

.site-content .banner {
    background-color: #015d1b;
    border: 3px solid #f1f4f8;
    border-left: none;
    border-right: none;
    color: #fff;
    font-weight: normal;
    font-size: 3em;
    text-align: center;
    padding: 1em .5em;
    margin: 1em -2rem;
}

.site-content h2 {
    font-size: 3em;
    text-shadow: 1px 1px 1px rgba(0,0,0,0.2);
}

.site-content h3 {
    font-size: 1.625em;
    margin: 1.7em 0 1em 0;
}

.site-content .image.team {
    margin: 0 0 1.5em 0;
}

.site-content .image.team img { margin: 0 auto; }

.presse {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-evenly;
    margin-bottom: 3em;
}

.presse li {
    flex: 0 1 calc(33.333333% - 3%);
}

.presse figure {
    margin: 0;
}

.disclaimer {
    font-size: .95em;
    text-align: center;
    margin-top: 2em;
}

.site-footer {
    font-size: 1em;
    color: rgba(47, 47, 47, 0.541176);
    padding: 3em 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.site-footer p {
    font-size: inherit;
    line-height: normal;
    margin: 0;
}

.site-footer p em {
    font-weight: bold;
}

.site-footer ul {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
}

.site-footer li::before {
    content: '-';
    margin: 0 .3em;
}

.site-footer a:hover { text-decoration: underline; }

.site-content.pre { position: relative; }
.site-content.pre h1 {
    font-size: 1.85em;
    color: #777;
    margin: 0 0 1em 0;
}
.site-content.pre h2 {
    font-size: 1.6em;
    margin: 0 0 .75em 0;
}
.site-content.pre .datum {
    font-size: 1em;
    line-height: normal;
    color: #999;
    margin-top: -1em;
}

.site-content.pre figure {
    margin: 0 0 1em 0;
}

.site-content.pre figcaption {
    font-style: italic;
    line-height: 1.3;
    color: #777;
    padding: 0 0.5em;
    margin-top: 0.5em;
}

.site-content.pre figure img { margin: 0 auto; }

.site-content.pre .ergebnisse {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 2em;
}

.site-content.pre .ergebnisse li {
    background: #dce4e7;
    border-radius: 3px;
    padding: .3em;
    flex: 0 1 calc(50% - .5em);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: .5em;
}
@media screen and (min-width: 48.750em) {
    .site-content.pre .ergebnisse li { flex-basis: calc(25% - .5em); }
}

.site-content.pre .ergebnisse img { max-width: 10.875rem; }

.site-content.pre .ergebnisse + p {
    font-size: 100%;
    text-align: center;
    color: #999;
}

.boni .image {
    text-align: center;
    margin: 0;
}
.boni > .image {

}
.boni > .image::after {
    content: '\f067';
    font-family: 'FontAwesome';
    font-size: 3em;
    display: block;
    text-align: center;
    margin: .5em 0;
}
.boni .image img { display: inline-block; }
.boni { margin-bottom: 2em; }
.boni ul .image img { max-width: 25%; }
.boni ul li { position: relative; }
.boni ul li:not(:last-child)::after {
    content: '\f067';
    font-family: 'FontAwesome';
    font-size: 1.6em;
    font-weight: normal;
    display: block;
    text-align: center;
    margin: .5em 0;
}

.subline {
    color: #888;
    font-size: 1.2em;
    padding-left: 1.5rem;
}
.subline .date {
    border-left: 1px solid #888;
    padding-left: .5em;
    margin-left: .3em;
}
.subline .stars {
    display: block;
    color: orange;
    margin-top: .3em;
}
.site-intro .image {
    margin-left: 0;
}
.site-intro .image figcaption {
    font-style: italic;
    color: #777;
    padding: 0 0.5em;
    margin-top: 0.5em;
}
.hinweis {
    border: 2px solid #fff18b;
    margin-top: 2em;
}
.hinweis h3 {
    background: #fff18b;
    font-size: 2em;
    font-weight: normal;
    color: black;
    padding: 1rem 1.5rem;
    margin: 0;
}
.hinweis p {
    padding: 1.5rem;
}
@media screen and (min-width: 75em) {
    .site-intro .image img {
        border-radius: 10px;
    }
}
.kundenbilder {
    list-style: none;
    padding: .5em;
    margin: -1em 0 2em 0;
    background: #e9e9e9;
    border-radius: 0.2em;
    text-align: center;
}

.kundenbilder li:not(:last-child) {
    margin-bottom: .5em;
}

.kundenbilder figure {
    display: inline-block;
    margin: 0;
}

.review-container {
    background: #fcfcfc;
    border-radius: 6px;
    font-size: 1.125rem;
    padding: 1em;
    box-shadow: 0 10px 20px rgba(102,55,103,.2);
    margin: 2em 0 3em 0;
}
.review {
    overflow: hidden;
    color: rgba(0, 0, 0, 0.7);
    border-bottom: 2px solid rgba(0, 0, 0, 0.08);
    padding: 2em 1em;
    position: relative;
    display: flex;
}
.review:last-child { border: none; }
.review .client {
    height: 100%;
    width: 130px;
    display: block;
    margin-right: 1em;
}
.review .client::before {
    z-index: 3;
    top: 7em;
    left: 6em;
    position: absolute;
    padding: 0.3em 0.6em;
    display: block;
    /*height: 2em;
    width: 2em;*/
    background-color: rgb(111, 194, 56);
    content: '\002714';
    color: white;
    border-radius: 1em;
}
.review .picture {
    float: left;
    height: 120px;
    width: 120px;
    margin: 0 0 0 0;
    opacity: .9;
    overflow: hidden;
}
.review .picture img {
    display: block;
}
.review .quote {
    display: flex;
    flex-direction: column-reverse;
    max-width: 80%;
    border: none;
    padding: 0;
    margin: 0 0 0 0;
    font-size: .95em;
    font-style: italic;
    justify-content: flex-end;
}
.review .quote p {
    margin: 0;
    line-height: 1.4;
    font-size: 1.1em;
}
.review .quote p::before {
    content: '\201C';
    margin-right: 0.2em;
}
.review .quote p::after {
    content: '\201D';
    margin-left: 0.2em;
}
.review .rating {
    display: flex;
    align-items: flex-end;
    height: 2em;
    width: 8em;
    margin-bottom: 1em;
}
.rating .star::after {
    color: rgb(248, 208, 32);
    font-size: 1.5em;
    font-style: normal;
    content: '\2605';
    height: 100%;
    width: 1em;
    display: block;
}
.review .info {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}
.review .name {
    float: left;
    text-align: left;
    display: block;
    font-style: normal;
    font-weight: bold;
    position: relative;
    padding: 10px 0 0;
    bottom: 10px;
    right: 0;
}
.review .name::after {
    margin-left: 1em;
    content: "Verifizierter Kunde";
    color: rgb(111, 194, 56);
    font-weight: 400;
    font-style: italic;
}
@media screen and (max-width: 768px) {
    .review {
        flex-direction: column;
        align-items: center;
    }
    .review .client {
        margin-bottom: 20px;
    }
    .review .quote {
        max-width: 95%;
    }
    .review .client::before {
        top: 7em;
        left: 60%;
    }
    .review .name::after {
        display: block;
        margin: .3em 0 0 0;
    }
}

@media screen and (min-width: 32.500em) {
    .kundenbilder {
        display: flex;
        flex-wrap: wrap;
        max-width: 32rem;
    }

    .kundenbilder li {
        flex: 1;
        display: flex;
        align-items: center;
    }
    .kundenbilder li:not(:last-child) { margin-bottom: 0; }

    .kundenbilder figure { display: block; }
}

@media screen and (min-width: 750px) {
    .site-content.pre figure {
        float: right;
        max-width: 40%;
        margin: .7em 0 1em 1em;
    }

    .site-content.pre figure img { border-radius: 2px; }

    .boni ul {
        display: flex;
        justify-content: space-between;
    }

    .boni ul li:not(:last-child)::after {
        position: absolute;
        right: -.5em;
        top: 40%;
        margin: 0;
    }

    .boni ul .image img { max-width: 50%; }
}

@media screen and (min-width: 992px) {
    .site-content {
        padding-top: 4.5rem;
        padding-left: 7.5rem;
        padding-right: 7.5rem;
    }
    .lang .site-content { padding-top: 3rem; }
    
    .site-content .banner {
        margin-left: -7.5rem;
        margin-right: -7.5rem;
    }

    .site-content.pre .datum {
        position: absolute;
        right: 7.5rem;
        top: 4.5rem;
        margin: 0;
    }
}



.feedback li:not(:last-child) {
    margin-bottom: 2.5em;
}

.feedback .image {
    margin: 0 auto 1em auto !important;
}

.feedback img {
    border: 2px solid rgba(0,0,0,0.15);
    display: block;
    padding: .3em;
    margin: 0 auto;
}

.feedback .text {
    /*background-color: rgba(104, 133, 165, 0.12);
    color: #39587c;
    padding: 1.5em;*/
    font-style: italic;
    text-align: center;
    color: #333;
    margin: 0;
}

.feedback .text p {
    font-size: 1.250em;
}

.feedback cite {
    font-size: 1.5em;
    font-style: normal;
    font-weight: bold;
}

@media screen and (min-width: 800px) {
    .feedback li {
        overflow: hidden;
        display: flex;
        justify-content: space-between;
    }

    .feedback .image {
        flex: 0 0 33.333333%;
        margin-bottom: 0 !important;
    }

    .feedback img { margin: 0; }
}


.kommentare {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    margin: 3em 0;
}

.kommentare li:not(:last-child) {
    margin-bottom: 1em;
}

@media screen and (min-width: 992px) {
    .kommentare li {
        flex: 0 1 calc(50% - 3em);
    }
}


/* Kundenbilder vorher-nachher */
.kundenbilder_vorher_nachher {
    display: flex;
    margin-bottom: 1em;
}

.kundenbilder_vorher_nachher li:not(:last-child) { margin-right: 2em; }

.kundenbilder_vorher_nachher figure { margin: 0; }

.kundenbilder_vorher_nachher figcaption {
    font-size: 1.5em;
    font-weight: bold;
    text-align: center;
    margin-bottom: 0.2em;
}

.kundenbilder_vorher_nachher img {
    border: 2px solid #d9d9d9;
    border-radius: 0.2em;
}

@media screen and (min-width: 46em) {
    /*.kundenbilder_vorher_nachher figcaption { font-size: 1.5em; }*/
}

/*===============================================================*/