/* BASIC STYLES */

body {
    font-family: 'Roboto', sans-serif;
    font-weight: 200;
    height: 100vH;
    background: #fff;
    padding: 0;
    margin: 0;
    outline: none;
}

h1 {
    display: flex;
    font-size: 1.6rem;
    font-weight: 100;
    letter-spacing: 5px;
    text-transform: uppercase;
    margin: 0;
}

h2 {
    font-size: 1.25rem;
    font-weight: 400;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin: 0;
    padding: 1em 0;
    /*color: #e50064;*/
    text-align: left;
}

h2.alt {
    color: #e50064;
}

h3 {
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin: 1em 0;
    padding: 0;
}

h4 {
    font-weight: 400;
    letter-spacing: 1px;
    /*color: #d0005b;*/
}

p {
    font-weight: 300;
    padding: 0;
    margin: 0;
    line-height: 1.6rem;
}

a {
    text-decoration: none;
    color: #d0005b;
    font-weight: 500;
}

hr {
    display: block;
    border: none;
    height: 1px;
    width: 50%;
    background-color: rgba(255, 255, 255, 0.75);
    margin: 2em auto;
}

.link {
    font-weight: 400;
}


.container {
    display: flex;
    overflow: hidden;
    flex-direction: column;
    width: 90%;
    max-width: 900px;
    margin: 2em auto 2em;
}


.head {
    position: relative;
    height: 20vH;
    background-image: url(../images/banner2.jpg);
    background-color: #fff;
    background-size: cover;
    background-position: center;
    outline: none;
}


.linie {
    padding: 5px;
    background: linear-gradient(-185deg, #e50064 1%, #f280b2 98%);
    color: #fff;
    border: none;
}

.linie-small {
    padding: 1px 5px;
    background: linear-gradient(-185deg, #e50064 1%, #f280b2 98%);
    color: #fff;
    margin: 1em 0;
}

.linie-bottom {
    padding: 1em 0;
    background: linear-gradient(-185deg, #e50064 1%, #f280b2 98%);
    color: #fff;
    border: none;
    margin: -3em 0 0 0;
}

.m0 {
    margin: 0;
}

p strong,
p.strong,
p.strong .highlight {
    font-weight: 400;
}

/* NAVIGATION */

.sub-head {
    display: flex;
    overflow: hidden;
    width: 90%;
    max-width: 900px;
    margin: 1em auto;
    align-items: center;
    justify-content: space-between;
}

.logo-container {
    margin: 0;
    position: absolute;
    width: 200px;
    margin-bottom: 60px;
}

.logo {
    width: 100%;
}

.nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    width: 100%;
}

.nav ul {
    display: flex;
    margin: 0;
    padding: 0;
}

nav ul li {
    padding: 0 1em;
    list-style: none;
    flex-direction: column;
}

nav ul li a {
    display: flex;
    align-items: center;
    font-size: 1rem;
    font-weight: 300;
    letter-spacing: 2px;
    transition: color 0.4s;
    color: #e50064;
}

nav ul li a:hover {
    color: #ec408b;
    transition: color 0.4s;
}

.active {
    color: #ec408b;
    font-weight: 500;
}

.contact {
    margin: 1em 0;
    display: flex;
    align-items: center;
}

.contact-phone {
    font-size: 1.2rem;
    font-weight: 400;
    letter-spacing: 2px;
    justify-content: center;
    padding: 1em;
    transition: background 0.4s ease-in-out;
    background: #e50064;
    color: #fff;
    height: 1em;
    display: flex;
    align-items: center;
    margin: 0 1em 0 0;
}

.contact-phone:hover {
    background: #f280b2;
    transition: 0.2s ease-in-out;
}

.contact-mail {
    font-size: 1.2rem;
    font-weight: 400;
    letter-spacing: 2px;
    justify-content: center;
    padding: 1em;
    transition: background 0.4s ease-in-out;
    background: #e50064;
    color: #fff;
    height: 1em;
    display: flex;
    align-items: center;
    text-align: center;
}

.contact-mail:hover {
    background: #f280b2;
    transition: 0.2s ease-in-out;
}

.signature {
    display: flex;
    justify-content: flex-end;
    margin: 1em 0;
}

.signature span {
    font-weight: 700;
    text-transform: uppercase;
}

.register {
    background: rgb(229 0 100 / 5%);
    margin: -2em 0;
}

.register-title {
    margin: 0 0 1em 0;
}

.form {
    display: flex;
    align-items: center;
}

.form.agreement {
    align-items: flex-start;
    margin: 1em 0;
}

.form.agreement label {
    font-weight: 300;
}

.form-text {
    display: flex;
    letter-spacing: 1px;
    width: 10em;
}

.form-field {
    display: flex;
    margin: 0.5em 0;
    border: 1px solid;
    border-color: rgb(229 0 100 / 5%);
    width: 34em;
    color: #e92078;
    font-family: 'Roboto', sans-serif;
    font-size: 1em;
    font-weight: 400;
    padding: 1em;
}

.form-field.error {
    border-color: unset;
}

.telefon {
    display: flex;

}

.form-tel-1 {
    display: flex;
    margin: 0.5em 1em 0.5em 0;
    border: 1px solid;
    border-color: rgb(229 0 100 / 5%);
    width: 10em;
    color: #e92078;
    font-family: 'Roboto', sans-serif;
    font-size: 1em;
    font-weight: 400;
    padding: 1em;
}

.form-tel-2 {
    display: flex;
    margin: 0.5em 1em 0.5em 0;
    border: 1px solid;
    border-color: rgb(229 0 100 / 5%);
    width: 23em;
    color: #e92078;
    font-family: 'Roboto', sans-serif;
    font-size: 1em;
    font-weight: 400;
    padding: 1em;
}

.form-tel-1.error,
.form-tel-2.error {
    border-color: unset;
}

.form input[type='checkbox'] {
    width: 13px !important;
    height: 13px !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    -o-appearance: none;
    appearance: none;
    outline: 1px solid gray;
    box-shadow: none;
    font-size: 0.8em;
    text-align: center;
    line-height: 1em;
    background: white;
    margin-right: 1em;
}

.form input[type='checkbox']:checked:after {
    content: '✔';
    color: #e50064;
}

.form input[type='checkbox'].error {
    outline: 1px solid #e50064;
}

.mandatory {
    font-size: 0.8em;
    color: #e92078;
    margin: 0em 0 1em 50em;
}

.register-text {
    margin: 1em 0;
}

.btn-container {
    display: flex;
    justify-content: center;
    margin: 2em 0;
}

.btn {
    margin: 1rem;
    padding: 1rem 3rem;
    background: linear-gradient(-185deg, #d0005b 1%, #e92078 98%);
    color: #fff;
    border: 1px solid;
    border-color: rgb(229 0 100 / 5%);
    border-radius: 2rem;
    font-family: 'Roboto';
    font-weight: 300;
    font-size: 1.2rem;
    outline: none;
    cursor: pointer;
}

.btn:hover {
    background: linear-gradient(-185deg, #e92078 1%, #d0005b 98%);
}


/** ANFAHRT **/

ul.list-container {
    padding-left: 1.5rem;
    font-weight: 300;
}

ul.list-container li {
    line-height: 2rem;
}

ul.list-container li strong {
    font-weight: 400;
}

.image-flex-container.center {
    display: flex;
    flex-wrap: wrap;
}

.image-flex-container.center {
    justify-content: center;
}

.image-flex-container.center .bild-1,
.image-flex-container.center .bild-2 {
    width: 50%;
}

.image-flex-container.center .bild-3 {
    width: 100%;
}

.footer {
    background: rgb(229 0 100 / 5%);

}

.back-colour {
    background: rgb(229 0 100 / 5%);
    padding: 5px 10px;
}

.back-colour-link {
    background: rgb(229 0 100 / 5%);
    padding: 5px 10px;
    font-weight: 400;
}

.parking {
    font-size: 0.8em;
    color: #e92078;
}


/** IMPRESSUM **/

.highlight {
    font-weight: 400;
    letter-spacing: 2px;
}

.highlight.alt {
    color: #e50064;
}

.picture-0 {
    position: relative;
    height: 500px;
    background-image: url(../images/Startseite.jpg);
    background-color: #fff;
    background-size: cover;
    background-position: center;
    outline: none;
}

.picture-1 {
    position: relative;
    height: 500px;
    background-image: url(../images/Impressum.jpg);
    background-color: #fff;
    background-size: cover;
    background-position: center;
    outline: none;
}


/** DATENSCHUTZ **/

.picture-2 {
    position: relative;
    height: 500px;
    background-image: url(../images/Datenschutz.jpg);
    background-color: #fff;
    background-size: cover;
    background-position: center;
    outline: none;
}



/** MOBILE **/

@media only screen and (max-width: 800px) {

    h2 {
        letter-spacing: 1px;
    }


    .sub-head {
        flex-direction: column;
    }

    .logo-container {
        margin-bottom: 1em;
        position: static;
    }

    .container {
        margin: 1em auto 2em;
    }

    .nav {
        justify-content: center;
    }

    nav ul li a {
        font-size: 0.8rem;
        letter-spacing: 0;
    }

    .contact {
        flex-direction: column;
    }

    .contact-phone {
        margin: 0 0 1em 0;
        width: 100%;
        font-size: 1rem;
    }

    .contact-mail {
        margin: 0 0 1em 0;
        width: 100%;
        font-size: 1rem;
    }


    .signature {
        margin: 0;
    }

    .register {
        margin: 0;
    }


    .form {
        display: flex;
        align-items: flex-start;
        flex-direction: column;
    }

    .form-text {
        display: flex;
        letter-spacing: 1px;
        margin-bottom: -0.5em;
        font-size: 0.8rem;
    }

    .form-field {
        width: 100%;
        margin-bottom: 1em;
    }

    .telefon {
        width: 100%;
        justify-content: space-between;
    }

    .form-tel-1 {
        width: 35%;
    }

    .form-tel-2 {
        width: 60%;
        margin: 0.5em 0 0.5em 0;
    }

    .mandatory {
        margin: 0;
        text-align: end;
    }

    .image-flex-container.center .bild-1,
    .image-flex-container.center .bild-2,
    .image-flex-container.center .bild-3 {
        width: 100%;
    }
}