/* RESET */
nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

nav li {
  position: relative; /* Wichtig für das absolute Positionieren der Submenüs */
}

nav a {
  text-decoration: none;
  padding: 10px;
  display: block;
  color: #000;
}

/* NAVIGATION-CONTAINER */
.main-nav {
  display: flex;
  justify-content: flex-end; /* Menü rechtsbündig */
  align-items: center;
  position: relative;
  z-index: 2000;
}

/* HAUPTMENÜ */
.mainmenu {
  display: flex;
  gap: 20px;
  z-index: 1000;
}

/* HAMBURGER-BUTTON */
.menu-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 2em;
  cursor: pointer;
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2001;
}

/* SUBMENÜ standardmäßig versteckt und absolut positioniert */
.submenu {
  display: none;
  position: absolute;
  top: 0;
  left: 100%; /* Desktop: rechts daneben */
  background: #fff;
  padding: 10px;
  min-width: 200px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
  z-index: 1001;
}

/* Hover-Menü für Geräte mit Maus */
@media (any-hover: hover) and (pointer: fine) {
  .has-submenu:hover > .submenu {
    display: block;
  }
}

/* Submenü per Klick öffnen (JS fügt "open"-Klasse hinzu) */
.has-submenu.open > .submenu {
  display: block;
}

/* RESPONSIVE: unter 768px */
@media (max-width: 768px) {
  /* Hamburger sichtbar machen */
  .menu-toggle {
    display: block;
  }

  /* Hauptmenü im Mobile-Modus ausblenden */
  .mainmenu {
    display: none;
    flex-direction: column;
    background: #fff;
    position: absolute;
    top: 60px;
    right: 0;   /* Menü rechtsbündig */
    width: 100%;
    z-index: 999;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
  }

  /* Menü sichtbar, wenn aktiv */
  .mainmenu.active {
    display: flex;
  }

  /* Submenü im Mobile-Modus links neben Menüpunkt */
  .has-submenu.open > .submenu {
    top: 0;
    left: auto;
    right: 100%; /* links daneben */
    min-width: 180px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
    background: #fff;
    padding: 10px;
    position: absolute;
  }
}

@media (max-width: 768px) {
  .has-submenu.open > .submenu {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    left: auto;
    min-width: 180px;
    background: #fff;
    padding: 10px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
    z-index: 9999;
    transform: translateX(-100%);
    white-space: nowrap;
  }
}