*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html, body{
    font-family: 'Glacial-Indifference', sans-serif;
    max-width: 100%;
    overflow-x: hidden;
}

/* Hero */
.hero-section{
    position: relative;
    width: 100vw;
    height: 100vh;
    background-color: #d10a14;
}

.hero-text{
    font-family: 'Dela Gothic One', sans-serif;
    color: #fff2eb;
    text-transform: uppercase;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.hero-title{
    position: absolute;
    text-align: center;
    z-index: 10;
    text-shadow: 1px 1px 10px black;
}

.hero-subtitle{
    position: absolute;
    color: transparent;
    -webkit-text-stroke: 1px #fff2eb;
}

#hero-3d{
    position: absolute;
    max-width: 150%;
    animation: animateHeroImage 200s linear infinite;
}

#hero-wolke{
    max-width: 150%;
}

.stars-scene{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;   
}

.stars-scene i{
    position: absolute;
    background-color: #fff;
    border-radius: 50%;
    animation: animateStars linear infinite;
    opacity: 0;
}

/* Leistung-Section */
.leistung-section{
    color: #fff2eb;
    background-color: #191919;
    overflow: hidden;
    position: relative;
}

.leistung-banner{
    font-family: 'Dela Gothic One', cursive;
    font-size: 2rem;
    color: transparent;
    -webkit-text-stroke: 0.5px #fff2eb;
    overflow: hidden;
    min-width: max-content;
    position: relative;
    display: flex;
    word-wrap: normal;
    justify-content: stretch;
   
}

.leistung-banner-top > div{
	animation: slideLeft 40s linear infinite;
}

.leistung-banner-bottom > div{
	animation: slideRight 40s linear infinite;
}

.leistung-section h3{
    font-family: 'Dela Gothic One', sans-serif;
    font-size: 1.5rem;
}

.leistung-section p{
    font-family: 'Glacial-Indifference', sans-serif;
    font-size: 1.2rem;
    padding-top: 1em;
    line-height: 1.4;
}

.leistung-einleitung{
    position: relative;
    margin-top: 3em;
    padding: 0px 20px;
    z-index: 1;
}

.leistung-block{
    margin-top: 2em;
}

/* .leistung-desktop-wrapper{
    display: none;
} */

#leistung-img1{
    position: absolute;
    top: 0;
    right: 0;
    max-width: 30%;
    z-index: 5;
    animation: moveImage1 3s ease-in-out infinite;
}

#leistung-img2{
    position: absolute;
    top: 680px;
    left: -7%;
    max-width: 20%;
    z-index: 5;
    animation: moveImage2 10s ease-in-out infinite;
}

#leistung-img3{
    position: absolute;
    top: 1265px;
    right: 10px;
    max-width: 20%;
    z-index: 20;
    animation: moveImage3 25s ease-in-out infinite;
}

#leistung-img4{
    position: absolute;
    top: 1450px;
    left: 0px;
    max-width: 10%;
    z-index: 15;
    animation: moveImage4 10s ease-in-out infinite;
}

#leistung-img5{
    position: absolute;
    top: 94.5%;
    left: 80px;
    max-width: 40%;
    z-index: 5;
    animation: moveImage5 7s ease-in-out infinite;
}

/* Die 3 Punkte als Accordion */
.accordion-container{
    position: relative;
    margin-top: 4em;
    padding: 0px 20px;
    z-index: 2;
}

.ac{
    border: none;
    margin-top: 1.5em;
}

.ac .ac-header{
    padding-bottom: 10px;
}

.ac-header{
    background-color: #191919;
    border-bottom: 1px solid #d10a14;
}

.ac .ac-trigger{
    font: unset;
    font-size: 1.3rem;
    font-family: 'Dela Gothic One', sans-serif;
    text-transform: uppercase;
    color: #d10a14;
    padding: unset;
}

.ac-trigger > span{
    font-size: 2.5rem;
    color: #fff2eb;
}

.ac .ac-panel .ac-text{
    font: unset;
    font-family: 'Glacial-Indifference', sans-serif;
    font-size: 1.2rem;
    line-height: 1.4;
    color: #fff2eb;
    background-color: #191919;
    padding: unset;
    padding-top: .75em;
}

/* .touchcard{
    position: relative;
    background-color: transparent;
    width: 90vw;
    margin-top: 2em;
    padding: 2em;
    border: 1px solid #fff2eb;
    border-radius: 2px;
    z-index: 3;
}

.touchcard p:first-child{
    font-family: 'Dela Gothic One', cursive;
    font-size: 3.75rem;
    color: #fff2eb;
}

.touchcard h3{
    font-size: 1.65rem;
    color: #d10a14;
    margin-bottom: 1em;
}

.touchcard-text{
    font-family: 'Montserrat', sans-serif;
    font-size: 1.5rem !important;
    color: #fff2eb;
    opacity: 0;
    transform: translateY(15px);
    transition-duration: .2s;
}

.touchcard-text-active{
    opacity: 1;
    transform: translateY(0px);
    transition-duration: .2s;
} */

/* .touchcard-text-active-1{
    height: 15em;
}

.touchcard-text-active-2{
    height: 15em;
}

.touchcard-text-active-3{
    height: 15em;
} */

/* .touchcard-finger-img{
    position: absolute;
    padding: 20%;
    left: 50%;
    top: 45%;
    transform: translateX(-50%);
    transition-duration: .2s;
    opacity: 1;
}

.touchcard-btn-inactive{
    opacity: 0;
    transform: translateX(-50%) translateY(15px);
    transition-duration: .2s;
} */

/* CTA */
.cta-section{
    padding: 3em 20px;
}

/* Starscene */
.leistung-section-star-scene{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;   
}

.leistung-section-star-scene i{
    position: absolute;
    background-color: #d10a14;
    border-radius: 50%;
    animation: animateRedStars linear infinite;
    opacity: 0;
    z-index: 99;
}


/* Keyframes */

@keyframes animateHeroImage{

    0%{
        transform: rotate(0deg);
    }

    50%{
        transform: rotate(360deg);
    }

    100%{
        transform: rotate(0deg);
    }

}

@keyframes animateStars{

    0%{
        opacity: 0;
        transform: translateY(0);
    }

    10%,90%{
        opacity: .5;
    }

    100%{
        opacity: 0;
        transform: translateY(-100px);
    }

}

@keyframes animateRedStars{

    0%{
        opacity: 0;
        transform: translateY(0);
    }

    10%,90%{
        opacity: 1;
    }

    100%{
        opacity: 0;
        transform: translateY(-100px);
    }

}

@keyframes slideLeft{

    0%{
        transform: translateX(0%);
    }

    100%{
        transform: translateX(-100%);
    }

}

@keyframes slideRight{

    0%{
        transform: translateX(-100%);
    }

    100%{
        transform: translateX(0%);
    }

}

@keyframes moveImage1{

    0%{
        transform: translateY(0);
    }

    50%{
        transform: translateY(10px);
    }

    100%{
        transform: translateY(0);
    }

}

@keyframes moveImage2{

    0%{
        transform: translateY(0) rotate(0deg);
    }

    50%{
        transform: translateY(20px) rotate(-10deg);
    }

    100%{
        transform: translateY(0) rotate(0deg);
    }

}

@keyframes moveImage3{

    0%{
        transform: translateY(0);
    }

    50%{
        transform: translateY(-50px) translateX(90%);
    }

    100%{
        transform: translateY(0) translateX(0);
    }

}


@keyframes moveImage4{

    0%{
        transform: translateY(0) rotate(0deg);
    }

    50%{
        transform: translateY(50px) translateX(15px);
    }

    100%{
        transform: translateY(0) rotate(0deg);
    }

}



@keyframes moveImage5{

    0%{
        transform: translateY(0) scale(100%);
    }

    50%{
        transform: translateY(20px) scale(80%);
    }

    100%{
        transform: translateY(0) scale(100%);
    }

}

/* ----- Mediaqueries ----- */

/* Ganz kleine Größen wie z.B. iPhone 4 */
@media (max-width: 320px){

    .hero-text{
        padding-top: 2em;
    }

    .hero-title h1{
        font-size: 1.75rem;
    }

    .hero-subtitle h2{
        font-size: 2.5rem;
    }

    .touchcard h3{
        font-size: 1rem;
    }

    .touchcard-text{
        font-size: 1rem !important;
    }

    /* .touchcard-text-active-1{
        height: 15em;
    }

    .touchcard-text-active-2{
        height: 15em;
    }

    .touchcard-text-active-3{
        height: 15em;
    } */

}

/* Größer als Standardgröße */

@media (min-width: 380px){

    /* .touchcard-finger-img{
        padding: 15%;
    } */

    #leistung-img2 {
        top: 500px;
        animation: moveImage2 15s ease-in-out infinite;
    }

   /*  .touchcard-text-active-1 {
        height: 12.5em;
    }

    .touchcard-text-active-2 {
        height: 12.5em;
    }

    .touchcard-text-active-3 {
        height: 13.5em;
    } */

    @keyframes moveImage2{

        0%{
            transform: translateY(0) rotate(0deg);
        }
    
        50%{
            transform: translateY(60px) rotate(-10deg);
        }
    
        100%{
            transform: translateY(0) rotate(0deg);
        }
    
    }

}

@media (min-width: 650px){

   .leistung-einleitung{
        padding: 0px 2.5em;
    }

    .accordion-container {
        padding: 0px 2.5em;
    }

    #leistung-img1{
        max-width: 25%;
    }

    #leistung-img2 {
        top: 450px;
    }

    #leistung-img3{
        top: 1250px;
        max-width: 20%;
    }

    #leistung-img4{
        left: -20px;
    }

    .cta-section{
        padding: 2em 40px;
    }

    @keyframes moveImage4{

        0%{
            transform: translateY(0) rotate(0deg);
        }
    
        50%{
            transform: translateY(10px) translateX(1px);
        }
    
        100%{
            transform: translateY(0) rotate(0deg);
        }
    
    }
}

@media (min-width: 768px){

    .hero-title{
        text-shadow: 2px 2px 10px black;
    }

    .leistung-banner{
        font-size: 3rem;
    }

    .leistung-einleitung {
        padding: 0px 3em;
    }

    .leistung-section h3{
        font-size: 3rem;
    }

    .leistung-section p{
        font-size: 1.35rem;
        line-height: 1.5;
    }

    .accordion-container {
        padding: 0px 3em;
    }

    .ac {
        margin-top: 2em;
    }

    .ac .ac-trigger{
        font-size: 1.4rem;
    }

    .ac-trigger > span {
        font-size: 48px;
    }

    #leistung-img2{
        left: -10%;
        max-width: 20%;
    }

    #leistung-img4{
        left: -10%;
        max-width: 15%;
    }

    #leistung-img5{
        top: 92%;
    }

    .cta-section{
        padding: 2em 48px;
    }

    @keyframes moveImage2{

        0%{
            transform: translateX(0px) translateY(0) rotate(0deg);
        }
    
        50%{
            transform: translateX(-20%) translateY(60px) rotate(-10deg);
        }
    
        100%{
            transform: translateX(0px) translateY(0) rotate(0deg);
        }
    
    }

}

@media (min-width: 992px){


    #hero-3d{
        max-width: 110%;
    }

    .leistung-section h3{
        font-size: 3.5rem;
    }

    .leistung-section p{
        font-size: 1.5rem;
        padding-top: .5em;
    }

    .leistung-banner{
        font-size: 4rem;
    }

    .leistung-einleitung{
        margin-top: 5em;
        padding: 0 5em;
    }

    .leistung-banner-top > div {
        animation: slideLeft 100s linear infinite;
    }

    .leistung-banner-bottom > div {
        animation: slideRight 100s linear infinite;
    }

    .leistung-block{
        margin-top: 3em;
    }

    .accordion-container {
        padding: 0px 5em;
    }

    .ac {
        margin-top: 3em;
    }

    .ac .ac-trigger{
        font-size: 1.5rem;
    }

    .ac-trigger > span {
        font-size: 65px;
    }
    
    #leistung-img5 {
        top: 90%;
        max-width: 30%;
    }

    .cta-section{
        padding: 3em 80px;
    }

}

@media (min-width: 1200px){

    #hero-3d{
        max-width: 1250px;
    }

    .leistung-section h3 {
        font-size: 66px;
    }

    .leistung-section h3{
        font-size: 60px;
        margin-bottom: .5em; /* Evtl. bei kleineren VWs */
    }

    .leistung-section p{
        font-size: 1.75rem;
        padding-top: unset; /* Evtl. bei kleineren VWs */
    }

    .leistung-banner{
        font-size: 5.5rem;
    }

    .leistung-einleitung{
        margin-top: 5em;
        padding: 0 8em;
    }

    .leistung-block {
        margin-top: 3em;
    }

    .wer-wir-sind p{
        padding-right: unset; /* Evtl. bei kleineren VWs */
    }

    .accordion-container {
        padding: 0px 8em;
    }

    .ac {
        margin-top: 2.5em;
    }

    .ac .ac-trigger {
        font-size: 1.6rem;
    }

    .ac-trigger > span {
        font-size: 60px;
    }

    .ac .ac-panel .ac-text {
        font-size: 1.4rem;
    }

    #leistung-img1{
        max-width: 18%;
    }

    #leistung-img3 {
        max-width: 15%;
    }

    #leistung-img4 {
        left: -3%;
        max-width: 10%;
        top: 1652px;
    }

    #leistung-img5 {
        top: 85%;
        max-width: 25%;
        left: 300px;
    }

    .cta-section{
        padding: 4em 128px;
    }
    
    @keyframes moveImage3{

        0%{
            transform: translateY(0);
        }
    
        50%{
            transform: translateY(-50px) translateX(90%);
        }
    
        100%{
            transform: translateY(0) translateX(0);
        }
    
    }

    @keyframes moveImage4{

        0%{
            transform: translateY(0) rotate(0deg);
        }
    
        50%{
            transform: translateY(20px) translateX(3px);
        }
    
        100%{
            transform: translateY(0) rotate(0deg);
        }
    
    }
    
}

@media (min-width: 1400px){

    #hero-wolke{
        width: 110%;
        max-width: 110%;
    }

    .leistung-einleitung{
        margin-top: 0em;
    }

    .leistung-section h3 {
        font-size: 66px;
    }

    .leistung-section p{
        font-size: 1.9rem;
        line-height: 1.7;
        padding-top: 1em;
    }

    .leistung-block{
        margin-top: 6em;
    }

    .wer-wir-sind, .was-wir-machen{
        padding-right: 6em;
    }

    .was-ist-eine-marke{
        text-align: right; /* BKVW */
        padding-left: 6em;
    }

    .accordion-container {
        margin-top: 6em;
        padding: 0px 8em;
    }


    .ac .ac-trigger {
        font-size: 2.2rem;
        padding-bottom: 20px;
        border-bottom: 1px solid #d10a14;
    }

    .ac-trigger > span {
        font-size: 4rem;
    }
    
    .ac .ac-panel .ac-text {
        font-size: 1.9rem;
    }

    .ac {
        margin-top: 3.5em;
    }

    #leistung-img3 {
        max-width: 12%;
    }

    #leistung-img4 {
        top: 1750px;
        left: -5%;
    }

    .cta-section{
        padding: 2em 128px;
    }

}

@media (min-width: 1700px){

    #hero-3d {
        max-width: 1350px;
    }

    .leistung-section h3 {
        font-size: 72px;
    }

    .leistung-section p {
        font-size: 2.4rem;
        line-height: 1.8;
    }

    .leistung-banner {
        font-size: 6rem;
    }

    .leistung-einleitung {
        padding: 0 11em;
    }

    .wer-wir-sind, .was-wir-machen{
        padding-right: 12em;
    }

    .was-ist-eine-marke{
        padding-left: 12em;
    }

    .accordion-container {
        margin-top: 10em;
        padding: 0px 11em; /* BKVW */
    }

    .ac .ac-trigger {
        padding-bottom: 30px;
    }

    .ac-trigger > span {
        font-size: 6rem;
    }

    .ac .ac-trigger::after { /* BKVW */
       /*  content: ""; */
    }

    .ac.is-active>.ac-header .ac-trigger::after { /* BKVW */
       /*  content: ""; */
    }

    .ac .ac-panel .ac-text {
        font-size: 2.4rem;
        padding-right: 5em;
    }

    #leistung-img1 {
        max-width: 15%;
    }

    #leistung-img2 {
        left: -7%;
        max-width: 15%;
    }

    #leistung-img4 {
        top: 2500px;
    }

    .cta-section{
        padding: 3em 176px;
    }

    
}

@media (min-width: 1920px){

    

}