/* === Layout-Grundstruktur für festen Footer === */

html, body {

  height: 100%;

  margin: 0;

  padding: 0;

}

body {

  display: flex;

  flex-direction: column;

  font-family: 'Segoe UI', sans-serif;

  background-color: #111;

  color: #eee;

}

/* Header */

header {

  background-color: #222;

  padding: 50px;

  display: flex;

  align-items: center;

  justify-content: space-between;

  flex-wrap: wrap;

}

header img {

  height: 50px;

  max-width: 150px;

}

.menu-toggle {

  display: none;

  font-size: 38px;

  cursor: pointer;

  color: white;

}

nav {

  display: flex;

  gap: 20px;

}

nav a {

  color: white;

  text-decoration: none;

  font-weight: bold;

  font-size: 1rem;

}

/* Hauptinhalt */

main {

  flex: 1;

  padding: 20px;

  max-width: 900px;

  margin: auto;

}

section {

  margin-bottom: 40px;

}

h1, h2 {

  color: #fff;

  font-size: 1.8rem;

  margin-bottom: 10px;

}

p {

  font-size: 1rem;

  margin-bottom: 10px;

}

/* Audio Player */

audio {

  width: 100%;

  max-width: 600px;

  margin-top: 20px;

}

/* Footer */

footer {

  background-color: #222;

  color: #ccc;

  text-align: center;

  padding: 15px 20px;

  font-size: 0.9em;

  border-top: 1px solid #444;

}

/* Mobile */

@media (max-width: 768px) {

  header {

    flex-direction: column;

    align-items: flex-start;

  }

  .menu-toggle {

    display: block;

    margin-top: 10px;

  }

  nav {

    display: none;

    flex-direction: column;

    width: 100%;

    background-color: #333;

    padding: 10px 0;

  }

  nav.active {

    display: flex;

  }

  nav a {

    padding: 10px 20px;

    border-top: 1px solid #444;

  }

  main {

    padding: 15px;

  }

  h1, h2 {

    font-size: 1.5rem;

  }

  p {

    font-size: 0.95rem;

  }

}