/* Einbindung der Schriftart */
@font-face {
  font-family: 'CustomFont';
  src: url('../fonts/InstrumentSans-Regular.woff') format('woff'), url('../fonts/InstrumentSans-Regular.woff2') format('woff2');
}

/* Basis Einstellungen */
html {
  font-size: 18px; /* Schriftgröße auf 18px gesetzt */
  line-height: 130%;
  letter-spacing: 0.02rem;
}

body, html {
  margin: 0;
  padding: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  font-family: 'CustomFont', sans-serif;
  font-size: 1rem; /* Basis Schriftgröße */
  box-sizing: border-box;
}

/* Scrollbar verstecken */
* {
  scrollbar-width: none; /* Firefox */
}

*::-webkit-scrollbar {
  display: none; /* Webkit */
}

#grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(50px, 1fr));
  gap: 4px;
  height: 100%;
  justify-content: center;
  align-items: center;
  margin: 4px 0px 0px 4px;
  
}

.flipper {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  overflow: hidden;
}

#grid.inactive {
  pointer-events: none;
}

.flipper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Menü Einstellungen */
#menu {
  position: fixed;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(243, 243, 243, 0.7);
  border-radius: 15px;
  box-shadow: 0 12px 14px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(10px);
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1000;
  width: 100px;
  height: 50px;
  overflow: hidden;
  transition: height 0.3s ease-in-out, width 0.5s ease-in-out;
}

@media (min-width: 601px) {
  #menu:hover {
    height: calc(50px + 20px); /* Höher bei Hover */
  }
}

#menu.open {
  width: 500px;
  height: calc(100vh - 20px);
  overflow: hidden;
}

/* Burger-Wrapper */
#burger-wrapper {
  position: fixed;
  top: 0;
  left: 50%;
  margin-top: 16px; /* Margin-Top für das Burger-Icon */
  transform: translateX(-50%);
  z-index: 1100;
  transition: top 0.3s ease; /* Smooth movement */
}

/* Menu-Content Einstellungen */
#menu-content {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 500px; /* Finale Breite des Menüs */
  height: calc(100vh - 50px); /* Höhe des Menüs abzüglich Höhe des Containers */
  overflow-y: auto; /* Scrollen ermöglichen */
  box-sizing: border-box;
  padding: 80px 30px 60px;
  transform: translateY(0%);
  transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out, transform 0.5s ease-in-out;
}

#menu-content.closed {
  opacity: 0;
  transform: translateY(5%);
  pointer-events: none; /* Klicks deaktivieren */
}

/* h2 Styles */
h2 {
  font-size: 1rem; /* Gleiche Schriftgröße wie restlicher Text */
  text-align: center; /* Zentriert */
  font-weight: 400;
}


/* Button Styles */
.btn {
  text-decoration: none;
  color: black;
  background-color: #fff;
  padding: 6px 40px;
  border-radius: 10px;
  display: inline-block;
  text-align: center;
  width: auto; /* Breite abhängig vom Inhalt und Padding */
  transition: background-color 0.3s ease; /* Weicher Übergang */
}

.btn:hover {
  background-color: #ffffffbb; /* Dunkleres Grau bei Hover */
}

/* Impressum-Container bleibt unten */
.impress-container {
  display: flex;
  flex-direction: column;
  gap: 4px; /* Abstand zwischen Buttons */
  width: 440px; /* Maximale Breite */
  padding: 20px 30px; /* Innenabstand */
  position: fixed; /* Fixiert den Container am unteren Rand */
  bottom: 0; /* Am unteren Rand des Containers */
  transition: opacity 0.5s ease, visibility 0.1s ease, transform 0.3s ease; /* Animation für Sichtbarkeit */
  opacity: 1; /* Sichtbar im offenen Zustand */
  visibility: visible; /* Sichtbar im offenen Zustand */
  transform: translateY(0); /* Keine Verschiebung im offenen Zustand */
}

.impress-container.closed{
  opacity: 0;
  visibility: hidden;
}

/* Weniger Deckkraft beim Scrollen */
.impress-container.scrolled {
  opacity: 0.5 !important;  /* Reduzierte Sichtbarkeit */
}

.impress{
  gap: 4px; /* Abstand zwischen Buttons */
  display: flex;
  flex-direction: row;
}

/* Impressum-Container im geschlossenen Zustand */
#menu.closed .impress-container {
  opacity: 0; /* Unsichtbar */
  visibility: hidden; /* Nicht sichtbar */
  transform: translateY(20px); /* Leicht verschoben */
}

.impress-btn {
  text-decoration: none; /* Kein Unterstrich */
  color: #000; /* Weißer Text */
  background-color: #fff; /* Schwarzer Hintergrund */
  padding: 6px 40px;
  border-radius: 8px; /* Abgerundete Ecken */
  text-align: center; /* Zentrierter Text */
  width: 100%; /* Volle Breite des Containers */
  font-size: 1rem; /* Einheitliche Schriftgröße */
  box-sizing: border-box; /* Padding und Border werden berücksichtigt */
  transition: background-color 0.3s ease; /* Weicher Übergang */
}

.impress-btn:hover {
  background-color: #ffffffbb; /* Dunkleres Grau bei Hover */
}

/* Neue section Styles */
.content-section {
  width: 100%; /* Maximale Breite des übergeordneten Containers */
  max-width: 500px; /* Beschränkung auf die Breite des Menüs */
  margin-bottom: 40px;
  display: flex;
  flex-direction: column;
}

/* Standard-Margin für alle Elemente entfernen */
.content-section > * {
  margin: 0;
  margin-bottom: 1rem; /* Entfernt jeglichen Standard-Margin */
  padding: 0; /* Entfernt zusätzlichen Padding, falls vorhanden */
}

/* Abstand zwischen p und Mail-Link */
p + .btn {
  margin-top: 16px;
}
