/* === Font-Import === */
@font-face {
  font-family: 'Battambang-Thin';
  src: url('fonts/Battambang-Thin.ttf') format('truetype');
}

@font-face {
  font-family: 'Battambang-Light';
  src: url('fonts/Battambang-Light.ttf') format('truetype');
}

@font-face {
  font-family: 'Battambang-Regular';
  src: url('fonts/Battambang-Regular.ttf') format('truetype');
}

@font-face {
  font-family: 'Battambang-Bold';
  src: url('fonts/Battambang-Bold.ttf') format('truetype');
}

@font-face {
  font-family: 'Battambang-Black';
  src: url('fonts/Battambang-Black.ttf') format('truetype');
}

@font-face {
  font-family: 'KaiseiTokumin-Regular';
  src: url('fonts/KaiseiTokumin-Regular.ttf') format('truetype'),
       url('fonts/KaiseiTokumin-Regular.woff') format('woff'),
       url('fonts/KaiseiTokumin-Regular.woff2') format('woff2'),
       url('fonts/KaiseiTokumin-Regular.eot') format('eot');
}

@font-face {
  font-family: 'KaiseiTokumin-Medium';
  src: url('fonts/KaiseiTokumin-Medium.ttf') format('truetype'),
       url('fonts/KaiseiTokumin-Medium.woff') format('woff'),
       url('fonts/KaiseiTokumin-Medium.woff2') format('woff2'),
       url('fonts/KaiseiTokumin-Medium.eot') format('eot');
}

@font-face {
  font-family: 'KaiseiTokumin-Bold';
  src: url('fonts/KaiseiTokumin-Bold.ttf') format('truetype'),
       url('fonts/KaiseiTokumin-Bold.woff') format('woff'),
       url('fonts/KaiseiTokumin-Bold.woff2') format('woff2'),
       url('fonts/KaiseiTokumin-Bold.eot') format('eot');
}

@font-face {
  font-family: 'KaiseiTokumin-ExtraBold';
  src: url('fonts/KaiseiTokumin-ExtraBold.ttf') format('truetype'),
       url('fonts/KaiseiTokumin-ExtraBold.woff') format('woff'),
       url('fonts/KaiseiTokumin-ExtraBold.woff2') format('woff2'),
       url('fonts/KaiseiTokumin-ExtraBold.eot') format('eot');
}

/* === Reset & Grundlayout === */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box; /* Setzt einheitliches Box-Modell, sodass Padding und Border die Breite nicht beeinflussen */
}

html {
  font-size: 16px; /* Basis-Schriftgröße für die gesamte Seite */
}

body {
  max-width: 100vw;
  overflow-x: hidden; /* Verhindert horizontales Scrollen auf der Seite */
  font-family: 'Battambang-Regular', sans-serif ; /* Schriftart für den gesamten Text */
  background: #111; /* Dunkler Hintergrund */
  color: white; /* Weiße Textfarbe */
}

/* === Navigation & Header Bereich === */
.Navigation {
  position: relative;
  display: flex;
  flex-direction: column; /* Anordnung der Elemente in einer Spalte */
  align-items: flex-start; /* Elemente nach links ausrichten */
  gap: 1rem; /* Abstand zwischen den Elementen */
  min-height: 20vh; /* Minimale Höhe von 20% der Viewport-Höhe */
  background: linear-gradient(rgba(151, 71, 255, 1), rgba(7, 7, 8, 1)); /* Farbverlauf von Schwarz zu Lila */
  padding: 1rem;
  margin: 0;
  overflow: hidden; /* Verhindert das Überlaufen von Inhalt */
}

/* === Styling für den Button in der Navigation === */
.navbutton {
  display: flex;
  height: 2.5rem; /* Höhe des Buttons */
  padding: 0rem 1.25rem; /* Innenabstand des Buttons */
  justify-content: center; /* Text horizontal zentrieren */
  align-items: center; /* Text vertikal zentrieren */
  border: 1px solid #252232; /* Border in einem dunklen Farbton */
  background: #101015; /* Hintergrund des Buttons */
  color: #b6b3b2; /* Textfarbe des Buttons */
  text-align: center; /* Text zentriert ausrichten */
  font-family:  'Battambang-Regular', sans-serif; /* Schriftart des Textes */
  font-size: 1rem; /* Schriftgröße */
  font-style: normal;
  font-weight: 400;
  line-height: 100%; /* Keine zusätzliche Zeilenhöhe */
  transition: background 0.2s ease, color 0.2s ease; /* Sanfte Übergänge bei Farbänderungen */
  margin-top: -1.25vh; /* Abstand nach oben */
  border-radius: 5px; /* Abgerundete Ecken */
  cursor: pointer; /* Cursor als Zeiger anzeigen */
}

/* === Desktop-Navigation === */
.Nav-leiste {
  position: fixed; /* Fixiert die Navigation oben */
  top: 3rem;
  right: 2.5rem; /* Position von rechts */
  display: flex;
  gap: 2rem; /* Abstand zwischen den Links */
  z-index: 10; /* Sicherstellt, dass die Navigation über anderen Inhalten liegt */
  font-size: 1.12rem; /* Schriftgröße der Links */
}

.Nav-leiste a {
  color: #bebebb; /* Textfarbe für Links */
  font-family:  'Battambang-Regular', sans-serif; /* Schriftart */
  font-size: 1rem; /* Schriftgröße */
  font-weight: 400; /* Schriftgewicht */
  line-height: 100%; /* Keine zusätzliche Zeilenhöhe */
  transition: color 0.2s ease; /* Übergangseffekt bei der Farbänderung */
  text-decoration: none; /* Entfernt die Unterstreichung */
}

/* === Dekoratives Element im Header === */
.Art {
  position: absolute; /* Absolut positioniert */
  top: 35%; 
  left: 50%; /* Zentriert das Element */
  transform: translate(-45%, -55%) rotate(-25.716deg); /* Zentriert und dreht das Element */
  width: 40vw; /* Breite des dekorativen Elements */
  height: 25vw; /* Höhe des dekorativen Elements */
  min-height: 15vw; /* Minimale Höhe */
  border-radius: 40rem 0 60rem 40rem; /* Abgerundete Ecken */
  background: rgba(0, 0, 0, 0.63); /* Dunkler Hintergrund mit Transparenz */
  z-index: 0; /* Setzt das Element hinter andere Inhalte */
}

/* === Zentrale Logo-Darstellung === */
.Logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); /* Zentriert das Logo */
  display: flex;
  flex-direction: column; /* Anordnung der Elemente in einer Spalte */
  align-items: center;
  gap: 1rem; /* Abstand zwischen den Elementen */
  z-index: 1; /* Setzt das Logo vor das dekorative Element */
}

/* Entfernt Standard-Link-Stile */
.Logo a {
  text-decoration: none; /* Entfernt die Unterstreichung */
  display: inline-flex; /* Flexbox für den Link */
  flex-direction: column; /* Bilder übereinander stapeln */
  align-items: center; /* Bilder horizontal zentrieren */
}

.Logo img:first-child {
  width: 4vw; /* Breite des ersten Logos */
  max-width: 6rem; /* Maximale Breite */
}

.Logo img:last-child {
  width: 15vw; /* Breite des zweiten Logos */
  max-width: 20rem; /* Maximale Breite */
}

/* === Hamburger-Menü === */
.hamburger {
  position: fixed; /* Fixiert den Hamburger Button oben rechts */
  top: 1rem;
  right: 1rem;
  display: none; /* Nur bei kleineren Bildschirmgrößen sichtbar */
  flex-direction: column; /* Anordnung der Balken als Spalte */
  gap: 5px; /* Abstand zwischen den Balken */
  background: none;
  border: none;
  z-index: 1001; /* Über allen anderen Elementen */
  cursor: pointer; /* Cursor als Zeiger anzeigen */
}

.hamburger span {
  width: 30px; /* Breite des Balkens */
  height: 3px; /* Höhe des Balkens */
  background: rgba(151, 71, 255, 1); /* Farbe des Hamburger-Menüs */
  border-radius: 2px; /* Abgerundete Ecken für die Balken */
  display: none; /* Balken sind zunächst unsichtbar */
}

/* === Mobiles Overlay-Menü mit Transparenz === */
.mobile-nav {
  position: fixed; /* Fixiert das Menü */
  top: 0;
  right: -100vw; /* Menü startet außerhalb des Bildschirms */
  width: 250px; /* Breite des mobilen Menüs */
  height: 100vh; /* Höhe des Bildschirms */
  background: rgba(26, 26, 31, 0.7); /* Hintergrund mit Transparenz */
  transition: right 0.4s ease; /* Sanfte Animation für das Einblenden */
  z-index: 999; /* Über allen anderen Elementen */
  flex-direction: column; /* Anordnung der Links vertikal */
  justify-content: center; /* Zentrierung der Links */
  align-items: center;
  display: none; /* Menü ist standardmäßig unsichtbar */
  padding-bottom: 30vh; /* Abstand nach unten */
}

.mobile-nav.open {
  display: flex; /* Menü wird angezeigt, wenn die Klasse "open" hinzugefügt wird */
  right: 0; /* Menü kommt von rechts */
}

.mobile-nav a {
  text-decoration: none; /* Entfernt die Unterstreichung */
  color: rgba(151, 71, 255, 1); /* Textfarbe für Links */
  background: #1a1a1a; /* Hintergrundfarbe der Links */
  padding: 1rem 2rem; /* Innenabstand */
  border-radius: 1.5rem; /* Abgerundete Ecken für Links */
  margin: 1rem 0; /* Abstand zwischen den Links */
  font-size: 1.2rem; /* Schriftgröße der Links */
  transition: background 0.3s ease; /* Übergangseffekt bei der Hintergrundfarbe */
}

.mobile-nav a:hover {
  background: #333; /* Hintergrundfarbe bei Hover-Effekt */
}

/* === Schließen-Button im Overlay-Menü === */
.close-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  font-size: 2rem;
  color: rgba(151, 71, 255, 1); /* Farbe des Schließen-Buttons */
  cursor: pointer; /* Mauszeiger als Zeiger anzeigen */
}

/* === Hauptinhalt === */
main {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 4rem 1rem;
  background-color: black; 
  color: white;
  font-family: 'Battambang-Regular', sans-serif;
}

main h1 {
  font-family: 'KaiseiTokumin-Regular', sans-serif;
  font-size: 2.8rem;
  margin-bottom: 3rem;
  color: #9747FF;
  text-align: center;
}

form {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 700px;
  gap: 1.5rem;
  background-color: black;
  padding: 2rem;
  border-radius: 1rem;
  box-shadow: 0 0 10px rgba(151, 71, 255, 0.3); /* Schatteneffekt */
  border: 1px solid #2c2c2c;
}

.row {
  display: flex;
  flex-direction: row;
  gap: 1rem;
}

.form-group {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.form-group.full-width {
  width: 100%;
}

label {
  font-size: 0.95rem;
  margin-bottom: 0.4rem;
  color: #ccc; /* Helle Schriftfarbe für Labels */
}

input,
select,
textarea {
  padding: 0.75rem 1rem;
  border: 1px solid #9747FF;
  border-radius: 8px;
  background-color: black; /* Hintergrundfarbe für Formulareingaben */
  color: white;
  font-size: 1rem;
  font-family: 'Battambang-Regular', sans-serif;
}

input::placeholder,
textarea::placeholder {
  color: #bbb; /* Placeholder in einem hellen Grau */
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  box-shadow: 0 0 0 2px #9747FF; /* Fokus-Effekt */
}

select {
  appearance: none;
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
}

textarea {
  min-height: 120px;
  resize: vertical; /* Textarea kann vertikal vergrößert werden */
}

button[type="submit"] {
  background-color: #9747FF;
  border: none;
  padding: 1rem;
  border-radius: 8px;
  color: white;
  font-weight: bold;
  font-size: 1rem;
  cursor: pointer;
  transition: background 0.3s ease; /* Übergangseffekt für Hintergrundfarbe */
}

button[type="submit"]:hover {
  background-color: #b88eff; /* Hellerer Farbton bei Hover */
}

/* === Footer Bereich === */
.footer {
  display: flex;
  flex-wrap: wrap; /* Ermöglicht flexibles Layout mit Umbruch */
  justify-content: space-between; /* Verteilt die Spalten gleichmäßig */
  gap: 2rem;
  padding: 2rem;
  background: #1A1B1F; /* Dunkler Hintergrund für den Footer */
  box-sizing: border-box; /* Stellt sicher, dass Padding und Border in der Breite berücksichtigt werden */
  max-width: 100vw;
  margin: 0 auto;
}

.footer-column {
  flex: 1 1 200px;
  color: rgba(184, 183, 183, 1);
  display: flex;
  flex-direction: column; /* Anordnung der Spaltenelemente vertikal */
  gap: 0.75rem; /* Abstand zwischen den Elementen */
}

.Footer-Logo {
  width: 4vw;
  max-width: 6rem;
  padding-bottom: 1.5rem; /* Abstand nach unten */
}

.Linkcolumn a {
  color: rgba(184, 183, 183, 1);
  text-decoration: none; /* Entfernt die Unterstreichung */
}

.Linkcolumn a:hover {
  color: white; /* Textfarbe bei Hover-Effekt */
}

#toast-container {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.toast {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #222;
  color: white;
  padding: 1rem 1.5rem;
  border-radius: 8px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
  min-width: 250px;
  max-width: 400px;
  animation: fadeInOut 6s ease forwards;
}

.toast.success {
  background-color: rgba(151, 71, 255, 1);
}

.toast.error {
  background-color: #f44336;
}

.toast button {
  background: none;
  border: none;
  color: white;
  font-size: 1.25rem;
  cursor: pointer;
  margin-left: 1rem;
}

@keyframes fadeInOut {
  0% {
    opacity: 0;
    transform: translateY(-10%);
  }
  10% {
    opacity: 1;
    transform: translateY(0);
  }
  90% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translateY(-10%);
  }
}


/* === Media Queries für Responsive Verhalten === */
@media (max-width: 768px) {
  .footer {
    flex-direction: column;
    align-items: flex-start; /* Fügt eine Spaltenstruktur für den Footer hinzu */
  }

  .footer-column {
    flex: 1 1 100%; /* Spalten sind nun 100% breit */
  }

  .Footer-Logo {
    width: 40%;
  }
}

.heading1 {
  color: #9747FF;
  text-align: center;
  font-family: Manrope;
  font-size: 3.75rem;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: -0.075rem;
}

/* Für Geräte mit einer maximalen Breite von 1025px (Tablets und mittlere Bildschirme) */
@media (max-width: 1025px) {
  /* --- Navigation --- */
  .Nav-leiste {
    display: none; /* Desktop-Menü ausblenden */
  }

  .hamburger {
    display: flex; /* Hamburger-Menü einblenden */
  }

  .hamburger span {
    display: flex; /* Hamburger-Balken sichtbar */
  }

  /* --- Header-Elemente (Dekoration & Logo) --- */
  .Art {
    width: 80vw;
    height: 60vw;
    top: 30%;
    border-radius: 40rem 0 60rem 40rem;
    transform: translate(-45%, -55%) rotate(-25.716deg);
  }

  .Logo {
    top: 45%;
    gap: 0.5rem;
  }

  .Logo img:first-child {
    width: 10vw;
    max-width: 4rem;
  }

  .Logo img:last-child {
    width: 40vw;
    max-width: 12rem;
  }

  .Navigation {
    padding: 0.5rem;
    gap: 0.5rem;
  }

  /* --- Footer Sektion: 4 Spalten nebeneinander --- */
  .footer {
    display: flex;
    flex-direction: row;         /* Spalten nebeneinander */
    flex-wrap: wrap;             /* Umbruch wenn nötig */
    justify-content: space-between;
    align-items: flex-start;
    gap: 2rem;
    padding: 2rem 2rem;
    text-align: left;
  }

  .footer-column {
    flex: 1 1 20%;               /* Jede Spalte nimmt ca. ein Viertel */
    min-width: 160px;            /* Mindestbreite für mobile Stabilität */
  }

  .Footer-Logo {
    width: 60px;
    max-width: 100%;
    padding-bottom: 1rem;
  }

  .Linkcolumn p {
    margin-bottom: 0.5rem;
    font-weight: 600;
  }

  .Linkcolumn a {
    font-size: 0.95rem;
    margin: 0.25rem 0;
  }
}

/* === Responsive Anpassungen === */
@media (max-width: 600px) {
  .row {
    flex-direction: column; /* Spaltenanordnung auf mobilen Geräten */
  }

  main h1 {
    font-size: 2.2rem; /* Kleinere Schriftgröße für kleine Bildschirme */
  }

  form {
    gap: 1rem;
    padding: 1.5rem; /* Reduziertes Padding */
  }
}

/* Für Geräte mit einer Bildschirmbreite bis 1280px (z. B. kleinere Laptops, Tablets im Querformat) */
@media (max-width: 1280px) {
  /* --- Allgemeines Layout --- */

  /* --- Footer-Bereich --- */
  .footer {
    padding: 2rem;
    gap: 1.5rem;
  }

  .footer-column {
    flex: 1 1 22%;
    min-width: 150px;
  }

  .Footer-Logo {
    width: 50px;
  }

  .Linkcolumn a {
    font-size: 0.95rem;
  }
}
