/* === FARBEN === */


/*
Dunkelgrau: #6E6E6E
Blau: #2E9AFE
Hellgrau: #D8D8D8
*/


/* === Schriftart === */

@font-face {
    font-family: "Roboto";
    src: url(../webfonts/roboto/Roboto-Regular.ttf) format("truetype");
    font-style: normal;
    font-weight: normal;
    font-display: swap;
}

@font-face {
    font-family: "Roboto";
    src: url(../webfonts/roboto/Roboto-Bold.ttf) format("truetype");
    font-style: normal;
    font-weight: bold;
    font-display: swap;
}

@font-face {
    font-family: "Roboto";
    src: url(../webfonts/roboto/Roboto-Italic.ttf) format("truetype");
    font-style: italic;
    font-weight: normal;
    font-display: swap;
}


/* === GLOBAL === */

body {
    font-family: 'Roboto', sans-serif;
}

:focus {
    outline: none;
    box-shadow: 0 0 2px 2px #2E9AFE, 0 0 10px #2E9AFE;
}

h1 {
    font-size: 2rem;
}


/* === GENERELL === */

.clearfix::after {
    content: "";
    display: block;
    clear: both;
}

.btn-typ-0 {
    color: #fff;
    text-transform: uppercase;
    border: none;
    background-color: #2E9AFE;
    border-radius: .2rem;
    font-size: 1.3rem;
    -webkit-transition-duration: .5s;
    transition-duration: .5s;
}

.btn-typ-1 {
    color: #fff;
    text-transform: uppercase;
    border: none;
    background-color: #2E9AFE;
    border-radius: .2rem;
    font-size: 1.2rem;
    -webkit-transition-duration: .5s;
    transition-duration: .5s;
    width: 65%;
    padding: .5rem;
    min-height: 100px;
}

.btn-typ-0:hover {
    background-color: #6E6E6E;
}

.btn-typ-1:hover {
    background-color: #6E6E6E;
}

input {
    color: #6E6E6E;
    border: none;
    border-radius: .2rem;
    font-size: 1.3rem;
    padding: .2rem;
}


/* === HEADER === */

header {
    background-color: #6E6E6E;
    height: 80px;
}

header .col-8 {
    color: #fff;
    font-size: 2rem;
    line-height: 4.3rem;
}

@media(max-width: 480px) {
    header .col-8 {
        text-align: center;
    }
}

@media(max-width: 385px) {
    header .col-8 {
        font-size: 1.5rem;
    }
}


/* === LOGIN-BEREICH === */

#login-bereich {
    margin-top: 200px;
    width: 20%;
    margin-left: auto;
    margin-right: auto;
}

#login-bereich input {
    background-color: #E6E6E6;
    font-size: 1.8rem;
    width: 100%;
}

#login-bereich .btn-typ-0 {
    font-size: 1.8rem;
    width: 100%;
}

@media(max-width: 1366px) {
    #login-bereich {
        width: 30%;
    }
}

@media(max-width: 980px) {
    #login-bereich {
        width: 40%;
    }
}

@media(max-width: 640px) {
    #login-bereich {
        width: 50%;
        margin-top: 50px;
    }
}

@media(max-width: 480px) {
    #login-bereich {
        width: 70%;
    }
}

@media(max-width: 340px) {
    #login-bereich {
        width: 80%;
    }
}


/* === FOOTER-BEREICH === */

footer {
    height: 80px;
    background-color: #D8D8D8;
    width: 100%;
}

.footer-typ-0 {
    position: absolute;
    bottom: 0;
}

.footer-typ-1 {
    position: relative;
    margin-top: 100px;
}

.footer-typ-2 {
    position: absolute;
    bottom: 0;
}

footer .col-8 {
    font-size: 1.5rem;
    text-align: center;
    line-height: 4.3rem;
    color: #6E6E6E;
}

footer .col-8 span {
    margin-right: .5rem;
}

@media(max-width: 1024px) {
    .footer-typ-2 {
        position: relative;
        margin-top: 100px;
    }
}

@media(max-width: 640px) {
    footer .col-8 {
        font-size: 1rem;
    }
}


/* === BENUTZER-DATEN-BEREICH === */

#benutzer-daten-bereich {
    margin-top: 20px;
    border-bottom: 2px solid #2E9AFE;
    padding-bottom: 20px;
}

#benutzer-daten-bereich .col-4:nth-of-type(2) {
    text-align: right;
}

#btnLogout {
    font-size: 2rem;
    margin-top: .3rem;
}

#btnZurueck {
    font-size: 2rem;
    margin-top: .3rem;
}

@media(max-width: 1024px) {
    #benutzer-daten-bereich .col-4:nth-of-type(2) {
        text-align: left;
    }
    #btnLogout {
        font-size: 1.3rem;
    }
    #btnZurueck {
        font-size: 1.3rem;
    }
}

@media(max-width: 480px) {
    #benutzer-daten-bereich .col-4:nth-of-type(1) {
        text-align: center;
    }
    #benutzer-daten-bereich .col-4:nth-of-type(2) {
        text-align: center;
    }
}


/* === ÜBERSCHRIFT-BEREICH === */

@media(max-width: 768px) {
    #ueberschrift-bereich .col-8 {
        text-align: center;
    }
}


/* === MODULE-BEREICH === */

#module-bereich .col-2 {
    text-align: center;
}

#module-bereich .row {
    margin-top: 30px;
}

#module-bereich .row:first-of-type {
    margin-top: 0;
}

@media(max-width: 768px) {
    #module-bereich .row {
        margin-top: 0;
    }
}


/* === PASSWORT-ÄNDERN-BEREICH === */

#passwort-aendern-bereich input {
    background-color: #E6E6E6;
    font-size: 1.8rem;
    width: 100%;
}

#passwort-aendern-bereich .btn-typ-0 {
    font-size: 1.8rem;
    width: 100%;
}

#passwort-aendern-bereich {
    width: 30%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 100px;
}

@media(max-width: 1366px) {
    #passwort-aendern-bereich {
        width: 40%;
    }
}

@media(max-width: 980px) {
    #passwort-aendern-bereich {
        width: 50%;
    }
}

@media(max-width: 640px) {
    #passwort-aendern-bereich {
        width: 60%;
        margin-top: 50px;
    }
}

@media(max-width: 480px) {
    #passwort-aendern-bereich {
        width: 80%;
    }
}

@media(max-width: 340px) {
    #passwort-aendern-bereich {
        width: 90%;
    }
}


/* === MEINE-DATEN-BEREICH === */

#meine-daten-bereich {
    font-size: 1.3rem;
}

#meine-daten-bereich input {
    background-color: #E6E6E6;
    font-size: 1.3rem;
    width: 100%;
}

#meine-daten-bereich .btn-typ-0 {
    font-size: 1.8rem;
    width: 100%;
}

#meine-daten-bereich .col-4:nth-of-type(15) {
    margin-top: 2rem;
}

#meine-daten-bereich .col-4:nth-of-type(16) {
    margin-top: 2rem;
}

@media(max-width: 1024px) {
    #meine-daten-bereich .col-4:nth-of-type(16) {
        margin-top: 0;
    }
}


/* === MEINE-TERMINE-BEREICH === */

#meine-termine-bereich {
    font-size: 1.3rem;
}

#meine-termine-bereich #datePicker {
    background-color: #2E9AFE;
    color: #fff;
}

.termin-standard {
    background-color: #2E9AFE;
    color: #fff;
}

.termin-pause-block {
    background-color: #D8D8D8;
    color: #6E6E6E;
}

#meine-termine-bereich .row:not(:nth-of-type(1)) {
    margin-top: 1.8rem;
}

#meine-termine-bereich .row:nth-of-type(2) {
    margin-top: 4rem;
}

#meine-termine-bereich .col-2 div {
    width: 80%;
    border-radius: .2rem;
    margin-left: auto;
    margin-right: auto;
    padding: .4rem;
    min-height: 9rem;
}

@media(max-width: 768px) {
    #meine-termine-bereich .row:not(:nth-of-type(1)) {
        margin-top: 0;
    }
    #meine-termine-bereich .row:nth-of-type(2) {
        margin-top: 4rem;
    }
}


/* === ABTEILUNG-TERMINE-BEREICH === */

#abteilung-termine-bereich {
    font-size: 1.3rem;
}

#abteilung-termine-bereich #datePicker {
    background-color: #2E9AFE;
    color: #fff;
}

.termin-standard-andere {
    background-color: #A9D0F5;
    color: #fff;
}

.termin-pause-block-andere {
    background-color: #F2F2F2;
    color: #6E6E6E;
}

#abteilung-termine-bereich .row:not(:nth-of-type(1)) {
    margin-top: 1.8rem;
}

#abteilung-termine-bereich .row:nth-of-type(2) {
    margin-top: 4rem;
}

#abteilung-termine-bereich .col-2 div {
    width: 80%;
    border-radius: .2rem;
    margin-left: auto;
    margin-right: auto;
    padding: .4rem;
    min-height: 9rem;
}

@media(max-width: 768px) {
    #abteilung-termine-bereich .row:not(:nth-of-type(1)) {
        margin-top: 0;
    }
    #abteilung-termine-bereich .row:nth-of-type(2) {
        margin-top: 4rem;
    }
}