html, body {
    margin: 0;
    padding: 0;
    font-family: Arial, sans-serif;
    background-color: #f4f4f4;
    color: #333;
    min-height: 100%;
    width: 100%;
}

header {
    background-color: #333;
    color: white;
    width: 100%;
    position: fixed;
    top: 0;
    z-index: 1000;
    display: flex;
    justify-content: space-between; /* Sorgt für Abstand zwischen den Elementen */
    align-items: center;
    padding: 1vh 2.5%;
}
header h1 {
    font-size: max(2vw, 16px); /* Flexible Schriftgröße mit einem Minimum von 16px */
}
nav ul {
    display: flex; /* Stellt sicher, dass die Navigationslinks nebeneinander angezeigt werden */
    list-style: none;
    margin: 0 5vh;
    padding: 0;
    padding-right: 35px;
}
nav ul li {
    margin: 0 5px;
}

nav ul li a {
    color: white;
    text-decoration: none;
    margin: 0 0;
    padding: 10px 1vw; /* Erhöht den Padding, um die Klickfläche zu vergrößern */
    background-color: #333; /* Definiert einen Hintergrund für die Kacheln */
    border-radius: 5px; /* Optional: Rundet die Ecken der Kacheln ab */
    transition: background-color 0.3s ease, color 0.3s ease; /* Sanfte Übergangseffekte für den Hover-Zustand */
    display: block; /* Stellt sicher, dass der gesamte Bereich der Kachel klickbar ist */
}
nav ul li a:hover, nav ul li a:focus {
    background-color: #555; /* Hintergrund der Kachel wird beim Hover heller */
    color: #fff; /* Optional: Passt die Textfarbe beim Hover an */
}

.hamburger-menu {
    display: none; /* Standardmäßig ausgeblendet */
    cursor: pointer;
    font-size: 2em; /* Größe des Icons */
    margin-left: auto; /* Schiebt alles vor diesem Element nach links und das Element selbst nach rechts */
    margin-right: 30px; /* Abstand von 10px zur rechten Bildschirmgrenze */
}
.banner-wrapper {
    display: flex; /* Aktiviert Flexbox für den Wrapper */
    justify-content: center; /* Zentriert den Inhalt horizontal */
    align-items: center; /* Zentriert den Inhalt vertikal, falls nötig */
    width: 100%; /* Stellt sicher, dass der Wrapper die volle Breite einnimmt */
    height: 30%;
    margin-top: calc(50px + 1%); /* Abstand vom Header, anpassbar */
    overflow: hidden;
}
.banner-image {
    width: auto; /* Passt die Bildbreite an den Wrapper an */
    max-width: 100%; /* Stellt sicher, dass das Bild nie über den Wrapper hinausgeht */
    width: 70vh; /* Behält das Seitenverhältnis des Bildes bei */
    object-fit: cover;
}
main {
    margin-top: 8%; /* Anpassung basierend auf der Höhe des Headers, in Prozent */
    padding: 1% 2.5%;
min-height: 70vh;
}


#registrationForm {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* Zwei Spalten */
    gap: 20px;
    max-width: 600px;
    margin: 0 auto;
    padding: 20px;
}

#registrationForm .form-group {
    display: contents; /* Ermöglicht, dass Label und Felder direkt im Grid-Layout positioniert werden */
}

#registrationForm label {
    grid-column: 1; /* Platziert alle Labels in der ersten Spalte */
}
#registrationForm input,
#registrationForm select,
#registrationForm textarea {
    grid-column: 2; /* Platziert alle Eingabefelder in der zweiten Spalte */
    width: 100%; /* Stellt sicher, dass alle Antwortfelder dieselbe Breite haben */
}
#registrationForm input[type="submit"] {
    grid-column: 1 / -1; /* Spannt den Button über beide Spalten */
    justify-self: center; /* Zentriert den Button */
    width: auto; /* Auto-Breite basierend auf dem Inhalt oder eine spezifische Breite setzen */
    padding: 15px 30px; /* Mehr Höhe und seitliches Padding */
    background-color: #ccc; /* Grauer Hintergrund */
    border: none; /* Entfernt die Border */
    border-radius: 5px; /* Runde Ecken */
    cursor: pointer; /* Cursor als Zeiger */
    font-size: 1rem; /* Schriftgröße anpassen */
}
h2 {
    text-align: center; /* Zentriert den Text der Überschrift */
    width: 100%; /* Stellt sicher, dass die Überschrift die volle Breite einnimmt */
    margin: 0 auto; /* Optional: Zentriert die Überschrift-Box, falls benötigt */
    padding-bottom: 15px;
    padding-top: 10px;
}
h3 {
    text-align: center; /* Zentriert den Text der Überschrift */
    width: 100%; /* Stellt sicher, dass die Überschrift die volle Breite einnimmt */
    margin: 0 auto; /* Optional: Zentriert die Überschrift-Box, falls benötigt */
    padding-bottom: 15px;
    padding-top: 50px;
}

/* Stil des Anmeldebuttons */
#submitBtn {
    background-color: #ccc; /* Grauer Hintergrund */
    color: #333; /* Dunkle Schriftfarbe */
    border: none; /* Keine Randlinie */
    padding: 15px 30px; /* Größeres Padding für die Höhe */
    font-size: 1em;
    cursor: pointer;
    border-radius: 5px;
}
/* Stiländerungen für den Button, wenn er deaktiviert ist */
#submitBtn:disabled {
    background-color: #eee; /* Hellerer Grauton, wenn deaktiviert */
    color: #aaa; /* Hellere Schriftfarbe, wenn deaktiviert */
    cursor: not-allowed; /* Cursor zum "Nicht erlaubt"-Indikator ändern */
}
.consent-group {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.consent-text {
    grid-column: 1 / span 2; /* Nimmt beide Spalten im Grid ein, falls benötigt */
}
#dataProtectionConsent {
    margin-left: 10px; /* Kleiner Abstand zur Beschriftung */
}
/* Container für den Anmeldebutton */
.button-container {
    grid-column: 1 / -1; /* Spannt über beide Spalten */
    display: flex;
    justify-content: center; /* Zentriert den Button */
    padding-top: 20px; /* Abstand zwischen Formularfeldern und Button */
}
.form-submit-button input[type="button"] {
    background-color: grey; /* Grauer Hintergrund */
    color: white;
    padding: 10px 20px; /* Mehr Höhe */
    border: none;
    border-radius: 5px;
    cursor: pointer;
    /* Zentrierung nicht nötig, da Container zentriert */
}

/* Modal- und Button-Styling wie oben beschrieben bleibt bestehen */
.modal-background {
    position: fixed; /* Über den gesamten Bildschirm */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* Schwarz mit Transparenz */
    display: flex;
    justify-content: center; /* Zentriert das Kind-Element (Modal) horizontal */
    align-items: center; /* Zentriert das Kind-Element (Modal) vertikal */
    z-index: 10; /* Stellt sicher, dass es über anderen Inhalten liegt */
}

.modal {
    background-color: white;
    padding: 20px;
    border-radius: 5px;
    border: 2px solid red; /* Roter Rahmen */
    width: 70%; /* Anpassen nach Bedarf */
    z-index: 1051; /* Sicherstellen, dass es über dem Modal-Hintergrund liegt */
}

/* Modal Content */
.modal-content {
    background-color: #fefefe;
    margin: 15% auto; /* 15% vom oberen und unteren Rand, zentriert */
    padding: 20px;
    border: 1px solid red; /* Roter Rahmen */
    width: 70%; /* Breite des Modals */
    z-index: 3;
}
/* Button im Modal */
#consentButton {
    display: inline-block;
    margin-top: 20px;
    background-color: gray; /* Grauer Hintergrund */
    color: white; /* Weiße Textfarbe */
    border: none;
    padding: 10px 20px; /* Größere Höhe */
    text-align: center;
    text-decoration: none;
    font-size: 16px;
    cursor: pointer;
    border-radius: 5px;
}
/* Button deaktiviert Style */
#consentButton:disabled {
    background-color: #ccc;
}
.close {
    color: #aaa;
    float: right;
    font-size: 28px;
    font-weight: bold;
}

.close:hover,
.close:focus {
    color: black;
    text-decoration: none;
    cursor: pointer;
}


/* Stile für den Footer */
footer {
    background-color: #333; /* Setzt die Hintergrundfarbe des Fußbereichs */
    color: white; /* Setzt die Textfarbe im Fußbereich */
    text-align: center; /* Zentriert den Text im Fußbereich */
    height: 10vh; /* Setzt die Höhe des Fußbereichs auf 10% der Viewport-Höhe */
    display: flex; /* Aktiviert Flexbox für die innere Struktur des Fußbereichs */
    justify-content: space-between; /* Verteilt die Inhalte gleichmäßig mit Raum dazwischen */
    align-items: center; /* Zentriert die Inhalte vertikal im Fußbereich */
}

/* Stil für Divs innerhalb des Footer-Bereichs */
footer div {
    margin: 0 10px; /* Setzt den Außenabstand jedes Divs im Fußbereich */
    flex: 1; /* Lässt jedes Div flexibel die verfügbare Breite einnehmen */
    padding: 0 1rem; /* Setzt den Innenabstand jedes Divs im Fußbereich */
}

/* Stil für Links im Footer-Bereich */
footer a {
    color: #ff6666; /* Setzt die Farbe der Links */
    text-decoration: none; /* Entfernt die Unterstreichung der Links */
}

/* Stil für Links im Footer-Bereich beim Hover */
footer a:hover {
    text-decoration: underline; /* Fügt eine Unterstreichung beim Überfahren mit der Maus hinzu */
}

/* Stil für den Copyright-Teil im Footer */
footer #copyright {
    margin-left: auto; /* Schiebt den Inhalt nach rechts */
    font-size: 0.8em; /* Setzt eine kleinere Schriftgröße */
}

/* Stil für den Erfolgsbereich */
.erfolg {
    width: 90%; /* Setzt die Breite auf 90% des Bildschirms */
    margin: 0 auto; /* Zentriert den Bereich horizontal */
    /* Weitere Styling-Optionen nach Bedarf */
    word-wrap: break-word; /* Erlaubt den Umbruch langer Wörter */
    white-space: normal; /* Erlaubt den Umbruch an Leerzeichen */
}
#registrationForm input[type="submit"] {
    height: 50px; /* Spezifische Höhe des Buttons */
    font-size: 1rem; /* Optional: Anpassung der Schriftgröße */
    cursor: pointer;
    background-color: #333;
    color: white;
    border: none;
    border-radius: 5px;
    margin-top: 20px;
    width: auto;
    justify-self: center; /* Zentriert den Button im Grid-Layout */
}

@media screen and (max-width: 600px) {
main {
        margin-top: 8vh; /* Erhöht den oberen Abstand um 5vh zusätzlich */
    }
    .hamburger-menu {
        display: block; /* Zeigt das Hamburger-Menü auf kleinen Bildschirmen an */
    }

    nav ul {
        display: none; /* Versteckt die Navigationslinks auf kleinen Bildschirmen */
        flex-direction: column; /* Stapelt die Links, falls das Menü erweitert wird */
        position: absolute;
        top: 100%;
        right: 0;
        background-color: #333;
        width: 50%; /* Oder eine spezifische Breite, die Sie bevorzugen */
    }
#registrationForm {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* Erstellt zwei gleich große Spalten */
    gap: 20px; /* Abstand zwischen den Spalten und Zeilen */
    max-width: 500px; /* Maximale Breite des Formulars */
    margin: 0 auto; /* Zentriert das Formular */
    padding-left: 10px;
    padding-right: 10px;
}
h2 {
    text-align: center; /* Zentriert den Text der Überschrift */
    width: 100%; /* Stellt sicher, dass die Überschrift die volle Breite einnimmt */
    margin: 0 auto; /* Optional: Zentriert die Überschrift-Box, falls benötigt */
    padding-bottom: 15px;
    padding-top: 10px;
}
    /* Optional: Stile für das erweiterte Hamburger-Menü */
    .hamburger-menu.active + nav ul {
        display: flex; /* Zeigt das Menü an, wenn das Hamburger-Icon aktiv ist */
    }
    .consent-group {
        flex-direction: column;
    }
    .consent-text {
        margin-bottom: 10px;
    }
@media (max-width: 600px) {
    .modal {
        width: 90%; /* Schmaler auf kleinen Bildschirmen */
    }
}
}