/* SMX Navigation – Globale CSS */
/* ====================================== */

/* Sticky Header mit flexbasiertem Layout */
.smx-header {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  padding: 0;
  background: var(--color-white);
  z-index: var(--z-nav-header);
}

#header-trigger {
  position: relative;
  height: 0rem;
}

.smx-header-inner {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  min-height: var(--nav-header-height);
  transition: min-height var(--transition-default) ease,
              height var(--transition-default) ease;
}

@media (max-width: 1199.98px) {
  .smx-header-inner {
    min-height: var(--nav-header-height-mobile);
    height: var(--nav-header-height-mobile);
  }
}

@media (max-width: 460.98px) {
  .smx-header-inner {
    min-height: var(--nav-header-height-mobile-sm);
    height: var(--nav-header-height-mobile-sm);
  }
}


.hasScrolled.smx-header {
  background: var(--color-white);
  box-shadow: 0 2px 4px var(--smx-header-shadow, rgb(var(--color-black-rgb) / 0.18));
}

.hasScrolled .smx-header-inner {
  min-height: var(--nav-header-height-compact);
  height: var(--nav-header-height-compact);
}

@media (max-width: 1199.98px) {
  .hasScrolled .smx-header-inner {
    min-height: var(--nav-header-height-mobile);
    height: var(--nav-header-height-mobile);
  }
}

@media (max-width: 460.98px) {
  .hasScrolled .smx-header-inner {
    min-height: var(--nav-header-height-mobile-sm);
    height: var(--nav-header-height-mobile-sm);
  }
}


.site-logo {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: var(--nav-logo-width);
  height: var(--nav-logo-height);
  z-index: var(--z-nav-logo);
  background-image: url("./img/Rectangle_Logo.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: top center;
}

.site-logo a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  outline: none;
}

.logo-nav-wrapper {
  position: relative;
  z-index: var(--z-nav-wrapper);
}

/* Logo-Bild anpassen */
.site-logo img {
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -60%);
  width: var(--nav-logo-image-width);
  height: auto;
  object-fit: contain;
  z-index: 1;
}


@media (max-width: 1199.98px) {
  .site-logo {
    left: calc(var(--space-lg) * -2);
    transform: translateX(0);
    width: var(--nav-logo-width-mobile);
    height: var(--nav-logo-height-mobile);
  }

  .site-logo img {
    width: var(--nav-logo-image-width-mobile);
  }
}

@media (max-width: 767.98px) {
  .site-logo {
    left: calc(var(--space-lg) * -2);
    transform: translateX(0);
    width: var(--nav-logo-width-mobile-sm);
    height: var(--nav-logo-height-mobile-sm);
  }

  .site-logo img {
    width: var(--nav-logo-image-width);
  }
}

/* Wrapper für Desktop-Navigation */
.smx-nav-desktop-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}

@media (max-width: 1199.98px) {
  .smx-nav-desktop-wrapper {
    display: none;
  }
}


/* Hauptnavigation Desktop */
.smx-nav-desktop {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  list-style: none;
  padding: 0 var(--space-xl);
  margin: 0;
}

.smx-nav-desktop > li {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 var(--nav-item-width);
  margin: 0 var(--nav-item-gap);
  padding-bottom: 0;
  cursor: pointer;
}

@media (min-width: 1200px) {
  .smx-nav-desktop > li:nth-child(2) {
    margin-right: var(--nav-item-offset);
  }
}

/* Dropdown-Pfeil für Menüpunkte mit Submenü */
.smx-nav-desktop > li.menu-item-has-children > a::after {
  content: "";
  display: block;
  width: 0.8rem;
  height: 0.6rem;
  background-image: url(img/dropdown-arrow.svg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  flex-shrink: 0;
  transition: transform var(--transition-default) ease;
}


/* Link-Stil Hauptnavigation */
.smx-nav-desktop > li > a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--nav-link-gap);
  width: 100%;
  text-decoration: none;
  font-size: var(--nav-link-font-size);
  color: var(--nav-link-color);
  background: var(--nav-bg);
  padding: var(--space-xs) var(--space-lg);
}

/* Hover-Effekt für Navigation */
.smx-nav-desktop > li > a:hover {
  color: var(--color-secondary);
}

/* Dropdown-Menü */
.smx-nav-desktop .sub-menu {
  position: absolute;
  top: calc(100% - var(--space-2xs));
  left: 0;
  display: flex;
  flex-direction: column;
  min-width: var(--nav-submenu-min-width);
  padding: var(--space-xs) 0 0;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(var(--space-sm));
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s linear 0.25s;
}


/* Sub-Menüeintrag */
.smx-nav-desktop .sub-menu li {
  display: block;
  width: 100%;
  padding: 0.1rem 0;
  margin: 0;
}

/* Sub-Menülink */
.smx-nav-desktop .sub-menu li a {
  display: block;
  font-size: var(--nav-submenu-font-size);
  color: var(--color-white);
  background: var(--nav-submenu-bg);
  border-radius: var(--space-xl);
  padding: var(--space-md) calc(var(--space-lg) + var(--space-2xs));
  transition: background-color var(--transition-fast) ease-in-out,
              color var(--transition-fast) ease-in-out,
              padding-left var(--transition-fast) ease-in-out;
}

/* Hover-Farbe für Submenü */
.smx-nav-desktop .sub-menu li a:hover {
  background: var(--nav-submenu-hover);
  color: var(--color-white);
  padding-left: calc(var(--space-xl) + var(--space-2xs));
}

/* Pfeil drehen beim Hover */
.smx-nav-desktop > li.menu-item-has-children:hover > a::after {
  transform: rotate(180deg);
}
/* Dropdown sichtbar machen */

.smx-nav-desktop li:hover .sub-menu {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
  z-index: var(--z-nav-dropdown);
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s;
}

/* Dropdown Animation anwenden */
.smx-nav-desktop li:hover .sub-menu li {
  animation: slideInLeft 0.3s ease-in-out backwards;
}

/* Slide-in Animation */
@keyframes slideInLeft {
  from {
    transform: translate(-25%, 0);
    opacity: 0;
  }

  to {
    transform: translate(0, 0);
    opacity: 1;
  }
}


/* Mobiles Overlay-Menü initial */
.smx-mobile-menu {
  position: fixed;
  z-index: var(--z-nav-mobile);
  left: 0;
  width: 100%;
  background: var(--color-white);
  transition: var(--transition-default);

  /* WICHTIG: nicht über height:0 verstecken */
  top: 0;
  height: 100dvh;
  transform: translateY(-110%);
  opacity: 0;

  overflow: hidden;
  pointer-events: none;
  visibility: hidden;
}


/* OPEN */
body.show-mobile-navigation .smx-mobile-menu {
  transform: translateY(0);
  opacity: 1;

  overflow-y: auto;
  pointer-events: auto;
  visibility: visible;
}

.smx-mobile-menu {
  height: 100vh;
}

@supports (height: 100dvh) {
  .smx-mobile-menu {
    height: 100dvh;
  }
}

/* Liste für mobiles Menü */
.smx-nav-mobile {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0;
  padding: var(--nav-mobile-padding-y) var(--nav-mobile-padding-x);
  padding-top: var(--nav-mobile-padding-top);
  list-style: none;
}

@media (max-width: 767.98px) {
  .smx-nav-mobile {
    padding: var(--space-2xl);
    padding-top: var(--nav-mobile-padding-top);
  }
}

/* Menüpunkt mobil */
.smx-nav-mobile li {
  position: relative;
  width: 100%;
  cursor: pointer;
  background: transparent;
  margin-bottom: var(--space-2xs);
  list-style: none;
}

/* Linkstil mobil */
.smx-nav-mobile li a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  padding: var(--space-lg) var(--space-xl);
  font-size: var(--nav-mobile-font-size);
  color: var(--color-primary-alt);
  text-decoration: none;
  border-bottom: 2px solid var(--color-primary-alt);
  font-weight: bold;
}

@media (max-width: 767.98px) {
  .smx-nav-mobile li a {
    font-size: var(--nav-mobile-font-size-sm);
  }
}

.smx-nav-mobile li a:hover,
.smx-nav-mobile li.submenu-open > a {
  color: var(--color-secondary-alt);
}

/* Icon für Dropdown mobil */
.smx-nav-mobile .submenu-toggle {
  position: absolute;
  top: var(--space-sm);
  right: 0rem;
  width: var(--space-2xl);
  height: auto;
  display: flex;
  text-align: right;
  color: var(--color-primary);
  cursor: pointer;
  z-index: var(--z-ui);
}

/* Plus-Symbol (Standard) */
.smx-nav-mobile .submenu-toggle::before {
  content: "";
  display: block;
  width: var(--space-2xl);
  height: var(--space-2xl);

  background-color: var(--color-primary-alt);

  -webkit-mask-image: url("../../img/select.svg");
  mask-image: url("../../img/select.svg");

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;

  -webkit-mask-position: center;
  mask-position: center;

  -webkit-mask-size: contain;
  mask-size: contain;
  transition: transform var(--transition-fast) ease-in-out,
              background-color var(--transition-fast) ease-in-out;

}


/* Minus-Symbol, wenn geöffnet */
.smx-nav-mobile .menu-item-has-children.expand-menu-button .submenu-toggle::before {
  transform: rotate(180deg);
  background-color: var(--color-secondary);
}




/* Submenü mobil initial versteckt */
.smx-nav-mobile .sub-menu {
  display: block;
  width: 100%;
  padding-left: 0rem;
  padding-right: 0rem;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transition: max-height 0.5s ease, opacity 0.4s ease, visibility 0.4s ease;
}

/* Submenü geöffnet */
.smx-nav-mobile .sub-menu.open-submenu {
  max-height: 100rem;
  opacity: 1;
  visibility: visible;
}


/* Submenüeintrag mobil */
.smx-nav-mobile .sub-menu li {
  display: flex;
  justify-content: flex-start;
  width: 100%;
  background: transparent;
  padding-right: 0rem;
  margin: 0;
  border: 0;
}

.smx-nav-mobile .sub-menu li a {
  display: inline-block;
  width: 90%;
  margin-left: 5%;
  margin-top: var(--space-2xs);
  padding: var(--space-lg) var(--space-xl);
  border-radius: var(--space-2xl);
  font-size: var(--nav-mobile-submenu-font-size);
  color: var(--color-text);
  background: var(--color-tertiary);
  border-bottom: 0;
  transition: background-color var(--transition-fast) ease-in-out,
              color var(--transition-fast) ease-in-out;
}

.smx-nav-mobile .sub-menu li:first-child a {
  margin-top: var(--space-sm);
}

@media (max-width: 767.98px) {
  .smx-nav-mobile .sub-menu li a {
    font-size: var(--nav-mobile-submenu-font-size-sm);
  }
}


.smx-nav-mobile .sub-menu li a:hover {
  background: var(--color-primary-alt);
}







/* Toggle Button Wrapper (mobil sichtbar) */
.smx-toggle-wrapper {
  position: absolute;
  display: none;
  top: 0;
  right: 0;
  z-index: var(--z-header);
}

@media (max-width: 1199.98px) {
  .smx-toggle-wrapper {
    display: block;
  }
}


/* Burger Button */
.smx-burger-button {
  --burger-width: var(--nav-burger-width);
  --burger-gap: var(--nav-burger-gap);
  position: relative;
  width: var(--nav-burger-button-size);
  height: var(--nav-burger-button-size);
  margin-right: var(--space-sm);
  border: 0.2rem solid transparent;
  background: transparent;
  cursor: pointer;
}

@media (max-width: 460.98px) {
  .smx-burger-button {
    width: var(--nav-burger-button-size-sm);
    height: var(--nav-burger-button-size-sm);
  }
}

@media (max-width: 460.98px) {
  .smx-burger-button {
    --burger-width: 3rem;
    --burger-gap: var(--space-sm);
  }
}

/* Linien des Burger Icons */
.smx-burger-icon,
.smx-burger-icon::before,
.smx-burger-icon::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 2px;
  background: var(--color-primary);
  transition: transform var(--transition-fast),
              background-color var(--transition-fast),
              opacity var(--transition-fast);
}

.smx-burger-icon {
  top: 50%;
  left: 50%;
  width: var(--burger-width);
  transform: translate(-50%, -50%);
}

.smx-burger-icon::before {
  top: calc(var(--burger-gap) * -1);
  left: 0;
}

.smx-burger-icon::after {
  top: var(--burger-gap);
  left: 0;
}

.smx-burger-button.is-active .smx-burger-icon {
  background: transparent;
}

.smx-burger-button.is-active .smx-burger-icon::before {
  top: 0;
  transform: rotate(45deg);
}

.smx-burger-button.is-active .smx-burger-icon::after {
  top: 0;
  transform: rotate(-45deg);
}