@import "../../style/property.pcss";
@import "../../style/display.pcss";
@import "../../style/border.pcss";
@import "../../style/theme.pcss";
@import "../../style/link.pcss";
@import "../../style/popper.pcss";
@import "../../style/control.pcss";
@import "../../style/badge.pcss";
@import '../../style/mixin/button.pcss';
@import '../../style/mixin/typography.pcss';
@import '../../style/mixin/hover.pcss';

:host {
  display: flex;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

[data-monster-role=control] {
  box-sizing: border-box;
  padding: var(--monster-space-1);
  position: relative;
  margin: 0;
  display: flex;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--monster-space-2);
  background: var(--monster-bg-color-primary-1);
  color: var(--monster-color-primary-1);
  border: var(--monster-border-width) solid var(--monster-color-primary-2);
  border-radius: var(--monster-border-radius);
}

#visible-elements {
  display: flex;
  flex-wrap: nowrap;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: var(--monster-space-1);
}

#visible-elements li {
  white-space: nowrap;
  cursor: pointer;
  position: relative;
}

#visible-elements li > a {
  display: block;
  padding: var(--monster-space-2) var(--monster-space-3);
  color: var(--monster-color-primary-1);
  text-decoration: none;
  border-radius: var(--monster-border-radius);
  transition: background-color 0.2s, color 0.2s;
  outline-offset: -2px;
}

#visible-elements li > a:hover {
  color: var(--monster-color-secondary-1);
  background-color: var(--monster-bg-color-secondary-2);
}

#hamburger-button {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: var(--monster-space-2);
  cursor: pointer;
  background: transparent;
  color: var(--monster-color-primary-1);
  border: 1px solid transparent;
  border-radius: var(--monster-border-radius);
  transition: background-color 0.2s, color 0.2s;
  flex-shrink: 0;
  width: auto;
  height: auto;
}

#hamburger-button:hover {
  background: var(--monster-bg-color-secondary-2);
  color: var(--monster-color-secondary-1);
}

#hamburger-button > svg {
  fill: currentColor;
}

[data-monster-role=navigation] {
  flex-grow: 1;
  min-width: 0;
}

[part="hamburger-container"] {
  height: 100%;
  display: flex;
  align-items: center;

}

#hamburger-button {
  height: 100%;
  aspect-ratio: 1 / 1;
}

[part="submenu"],
[part="hamburger-nav"],
[part="mega-menu"] {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--monster-bg-color-primary-1);
  color: var(--monster-color-primary-1);
  border-radius: var(--monster-border-radius);
  border: 1px solid var(--monster-color-primary-2);
  box-shadow: var(--monster-box-shadow-2);
  list-style: none;
  padding: var(--monster-space-1);
  margin: 0;
  z-index: var(--monster-z-index-modal);
  min-width: 220px;
}

[part="submenu"].is-open,
[part="mega-menu"].is-open {
  display: block;
}

[part="submenu"] > li:not(:last-child) {
  margin-bottom: var(--monster-space-1);
}

[part="submenu"] li a,
[part="hamburger-nav"] li a {
  user-select: none;
  display: block;
  padding: var(--monster-space-2) var(--monster-space-3);
  text-decoration: none;
  color: var(--monster-color-primary-1);
  border-radius: var(--monster-border-radius);
  white-space: nowrap;
  outline-offset: -2px;
  transition: background-color 0.2s, color 0.2s;
}

[part="submenu"] li a:hover,
[part="hamburger-nav"] li a:hover {
  background-color: var(--monster-bg-color-secondary-2);
  color: var(--monster-color-secondary-1);
}

[part="hamburger-nav"] [part="hidden-list"] {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--monster-space-1);
}

[part="hamburger-nav"] [part="submenu"],
[part="hamburger-nav"] [part="mega-menu"] {
  box-sizing: border-box;
  position: relative;
  width: 100%;
  margin-top: var(--monster-space-3);
  padding: var(--monster-space-3) 0 0 var(--monster-space-4);
  background-color: transparent;
  border: none;
  box-shadow: none;
  min-width: unset;
  top: auto;
  left: auto;
}

[part="hamburger-nav"] [part="submenu"]::before,
[part="hamburger-nav"] [part="mega-menu"]::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background-color: var(--monster-color-primary-2);
}

[part="mega-menu"] {
  padding: var(--monster-space-4);
  min-width: 400px;
}

.mega-menu-columns {
  flex-wrap: wrap;
  gap: var(--monster-space-2);
}

.column {
  flex: 1;
}

[part="hamburger-header"] {
  display: none;
}

@media (max-width: 768px) {
  [part="hamburger-nav"][style*="display: block"] {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh; /* KORRIGIERT */
    padding: var(--monster-space-4);
    box-sizing: border-box;
    overflow-y: auto;
    border-radius: 0;
    border: none;
    z-index: var(--monster-z-index-overlay);
  }

  [part="hamburger-nav"] [part="hidden-list"] {
    flex-grow: 1;
  }

  [part="hamburger-header"] {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding-bottom: var(--monster-space-3);
    margin-bottom: var(--monster-space-3);
    border-bottom: 1px solid var(--monster-color-primary-2);
  }

  [part="hamburger-close-button"] {
    background: transparent;
    border: none;
    color: var(--monster-color-primary-1);
    cursor: pointer;
    padding: var(--monster-space-1);
  }

  [part="hamburger-close-button"]:hover {
    color: var(--monster-color-secondary-1);
  }

  :global(body.monster-navigation-open) {
    overflow: hidden;
  }
}
