/**
 * Theme Navigation Styles
 * 
 * This file contains the base styles for the theme’s navigation (IMP Menu).
 * It includes structure, layout, and animation logic for the main menu.
 * 
 * If additional navigation types or animation variants are added (e.g., 
 * sliding, fading, overlay), they should be moved into dedicated sub-files
 * (e.g., theme_nav-overlay.css, theme_nav-slide.css).
 * 
 * This ensures the base file remains manageable and the structure modular.
 */

nav#main-nav li.menu-item .special-menu-btn.menu-link:hover {
  background-color: var(--ast-global-color-0);
}

/*
nav#main-nav
  li.menu-item
  .special-menu-btn.menu-link:hover
  .imp-nav-target-txt {
  color: var(--ast-global-color-4);
}
  */

.menu-col.col-menu-1 {
  width: 100%;
  display: flex;
  height: 100%;
  align-items: center;
  max-width: 100%;
  max-height: 100%;
  position: relative;
}

.menu-hauptmenu-container {
  height: 100%;
}

@media (min-width: 1025px) {
  #menu-hauptmenu {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 0;
    width: fit-content;
    position: relative;
  }
}

.dropdown-menu-toggle.ast-header-navigation-arrow {
  display: none;
}

#menu-wrapper ul.sub-menu {
  overflow: hidden;
  color: var(--ast-global-color-0);
  display: flex;
  align-items: center;
}

.ast-icon.icon-arrow {
  display: none;
}

#menu-hauptmenu .sub-menu a {
  font-weight: 600;
  color: var(--ast-global-color-0);
  font-size: var(--btn-font-size);
  line-height: 1.36;
  border: 1px solid var(--ast-global-color-0) !important;
  display: block;
  white-space: nowrap;
}

#menu-hauptmenu .sub-menu a .imp-nav-target-txt {
  display: flex;
  gap: 15px;
  align-items: center;
}

#menu-hauptmenu .sub-menu a .imp-nav-target-txt::after {
  content: "" !important;
  display: block !important;
  background-image: url(/wp-content/themes/astra-impuls-child/img/icon-pfeil-button.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  --my-size: 1em;
  width: var(--my-size);
  height: var(--my-size);
}

nav#main-nav .special-format .sub-menu li.menu-item.current-menu-item > a {
  background-color: var(--ast-global-color-0);
  color: var(--ast-global-color-4) !important;
  z-index: 9;
}

nav#main-nav
  ul.sub-menu:not(.special-submenu)
  li.menu-item.current-menu-item
  > a {
  background: var(--ast-global-color-2);
  text-decoration: none;
}

nav#main-nav
  ul.sub-menu:not(.special-submenu)
  li.menu-item.current-menu-item
  .imp-nav-target-txt {
  color: var(--ast-global-color-4);
}

nav#main-nav .sub-menu li.menu-item.current-menu-item > a::after,
.menu-link-about .sub-menu .current-menu-item .imp-nav-target-txt::after,
.menu-link-about .sub-menu .menu-link:hover .imp-nav-target-txt::after {
  background-image: url(../../img/button-arrow-green.svg) !important;
}

#menu-wrapper ul.sub-menu {
  padding-top: 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  z-index: 9;
  gap: 13px;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  width: 30vw;
}

.menu-item.sub-back-btn {
  margin-top: 4.2vh;
}

.menu-item.sub-back-btn span {
  display: flex;
  align-items: center;
}

#menu-hauptmenu .menu-link-about .sub-menu {
  gap: var(--gap-s) !important;
  margin-top: var(--gap-s) !important;
}

#menu-hauptmenu .menu-link-about .sub-menu li a.menu-link {
  font-family: var(--mainfont) !important;
  font-size: var(--btn-font-size) !important;
  font-style: normal;
  font-weight: 500;
  line-height: 100%;
  letter-spacing: 0.01em;
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--ast-global-color-3);
  border-radius: 500px;
  padding: 1.05em 1.8em !important;
}

#menu-hauptmenu .menu-link-about .sub-menu .imp-nav-target-txt {
  display: flex;
  align-items: center;
  gap: 10px;
}

.impmenu-active #nav-icon3 span:nth-child(3) {
  background-color: var(--ast-global-color-5) !important;
  z-index: 1;
}

.impmenu-active #nav-icon3 span:nth-child(2) {
  z-index: 2 !important;
}

/**
 * Theme Navigation Variant 1
 * 
 
 * This file contains styles for a specific navigation layout:
 * - Main menu appears on the left
 * - Submenu opens on the right with animation
 * 
 * Mobile behavior:
 * - Submenu slides in as a separate view
 * - The parent menu title appears as a heading
 * 
 * This variant builds on the base styles defined in `theme_nav.css`.
 * Only layout and animation-specific overrides or additions are included here.
 * 
 * If additional variants are needed, create separate files such as:
 * `theme_nav-variant-2.css`, `theme_nav-fade.css`, etc.
 */

#main-nav {
  background-color: var(--ast-global-color-1);
}

.menu-hauptmenu-container {
  height: 100%;
  width: 100vw;
  margin: 0;
  padding: 11.86vw 0 0 13.14vw;
}

/*
nav#main-nav
  .sub-menu
  li.menu-item.current-menu-item
  > a
  .imp-nav-target-txt::after,
nav#main-nav .sub-menu li.current-menu-item a .special-submenu-title::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: #fff;
}
*/

nav#main-nav .sub-menu li.menu-item.current-menu-item > a .imp-nav-target-txt,
nav#main-nav .sub-menu li.current-menu-item a .special-submenu-title {
  color: var(--ast-global-color-0) !important;
}

nav#main-nav
  .sub-menu
  li.current-menu-item
  a.special-submenu-title-link.menu-link::before,
nav#main-nav
  .special-submenu-depth-1
  li.menu-item.current_page_item
  a.btn.special-menu-btn.menu-link::before {
  background-image: url(../../../img/button-arrow-purple.svg);
}

.menu-hauptmenu-container
  ul#menu-hauptmenu
  li:nth-child(3)
  .special-submenu-depth-1 {
  gap: var(--gap-l);
  flex-direction: row;
  padding: var(--gap-s) 0 0 0 !important;
  /*flex-wrap: wrap;*/
}

/**SUB MENU IMAGE*/

.submenu-image-container {
  top: 0;
  right: 0;
  width: 54.92%;
  height: 100%;
  opacity: 0.35;
  pointer-events: none;
}

.submenu-image-inner {
  position: relative;
  width: 100%;
  height: 100%;
}

.submenu-img {
  position: relative;
  height: 100%;
  width: 100%;
  pointer-events: none;
}

.submenu-img:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    var(--ast-global-color-1) 0%,
    rgba(255, 255, 255, 0) 60%
  );
}

/**animation*/

.submenu-img {
  height: 0;
  opacity: 0;
  transition: opacity 0.8s ease-in-out;
}

.submenu-img.active {
  height: 100%;
  opacity: 1;
  transition-delay: 1s;
  /* einblenden verzögert */
}

.submenu-img:not(.active) {
  transition:
    opacity 0.8s ease-in-out,
    height 0s 0.8s;
  /* height springt erst nach opacity-fade */
}

@media (max-width: 1450px) {
  .menu-hauptmenu-container
    ul#menu-hauptmenu
    li:nth-child(3)
    .special-submenu-depth-1 {
    flex-wrap: wrap;
    gap: var(--gap-s);
  }
  .menu-hauptmenu-container
    ul#menu-hauptmenu
    li:nth-child(3)
    .special-submenu-depth-1
    li:first-of-type {
    margin-right: var(--gap-m);
  }
}

nav#main-nav li.menu-item .sub-menu a:hover span,
.special-submenu-depth-1 a.menu-link:hover .imp-nav-target-txt {
  color: inherit;
}

@media (min-width: 1210px) {
  #menu-wrapper ul.sub-menu {
    transform: translateY(10px);
  }
}

@media (min-width: 1025px) {
  #menu-hauptmenu > .menu-item {
    max-height: 100vh;
    display: flex;
    justify-content: flex-start;
  }
  #menu-hauptmenu > .menu-item:after {
    display: none !important;
  }
  #menu-wrapper ul.sub-menu {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.9s ease-in-out;
    overflow: hidden;
    transition-delay: 0.1s, 0.1s;
    position: absolute;
    left: 100%;
    transform: translateY(2%px);
    width: 35vw;
  }
  #menu-wrapper .imp-sub-active ul.sub-menu {
    transition: opacity 0.9s ease-in-out;
    transition-delay: 0.9s;
    opacity: 1;
    pointer-events: all;
  }
  /**special menu*/
  #menu-hauptmenu > .menu-item:after {
    content: "";
    display: block;
    height: 2px;
    width: 0;
    background-color: var(--ast-global-color-2);
    margin-right: var(--gap-m);
    margin-left: var(--gap-m);
    position: relative;
    top: calc(50% + 2px);
    transition: all 0.9s ease-in-out;
    transition-delay: 1s;
  }
  #menu-hauptmenu > .menu-item.imp-sub-active:after {
    width: calc(var(--gap-xl) + var(--gap-m));
    transition-delay: 0s;
  }
  li.menu-item.sub-back-btn {
    display: none;
  }
  ul.sub-menu.special-submenu {
    top: 50%;
    transform: translateY(-50%);
  }
  #nav-wrapper {
    bottom: 0;
    top: 0;
    background-color: var(--color-2);
  }
  #main-nav {
    height: 100dvh;
  }
  .menu-col.col-menu-1 {
    --menu-width: 100%;
  }
  .menu-col.col-menu-1 {
    flex-direction: column;
  }
  #menu-hauptmenu {
    height: 100%;
    display: flex;
    flex-direction: column;
  }
}

@media (max-width: 1350px) {
  /*   #menu-wrapper {
    padding-left: calc(var(--gap-l) * 2);
  } */
  /*   #menu-hauptmenu > .menu-item > a {
    font-size: 28px;
  } */
  span.special-submenu-title {
    font-size: 16px;
  }
  a.btn.special-menu-btn.menu-link {
    font-size: 14px !important;
  }
}

@media (max-width: 1150px) {
  /*   #menu-hauptmenu > .menu-item > a {
    font-size: 24px;
  } */
  #menu-wrapper ul.sub-menu {
    left: 110%;
  }
  #menu-hauptmenu
    > li.menu-item.menu-item-has-children
    > a
    > .imp-nav-target
    ::after {
    margin-right: 0 !important;
  }
}

@media (max-width: 1025px) and (min-width: 768px) {
  .menu-col.col-menu-1 {
    height: 100dvh !important;
  }
  #header-icons {
    bottom: 20vw !important;
  }
}

/* ---------------------------------- */

/* SHIFT NAV */

@media (max-width: 1025px) {
  #menu-wrapper {
    justify-content: flex-start;
  }
  .menu-col.col-menu-1 {
    display: flex;
    align-items: center;
    position: relative;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-top: calc(
      var(--header-absolute-items-top) + var(--icon-pad-top) * 2 +
        var(--icon-height) + 5vh
    );
    flex-direction: column;
    height: fit-content;
    max-height: 100dvh;
  }
  .menu-hauptmenu-container {
    width: 100%;
  }
  #menu-hauptmenu {
    height: 100%;
    display: flex;
    flex-direction: column;
  }
  /*  #menu-hauptmenu > .menu-item.imp-sub-active > .menu-link {
    border-bottom: 2px solid var(--ast-global-color-0);
    color: #fff;
  } */
  #menu-hauptmenu > .menu-item > a,
  #menu-hauptmenu .sub-menu .menu-item {
    /*padding-left: 5vw;*/
    /* padding-right: 5vw; */
  }
  #menu-wrapper ul.sub-menu {
    max-height: 0;
    overflow: hidden;
    transition: all 0.5s cubic-bezier(0.46, 0.03, 0.52, 0.96);
  }
  #menu-wrapper .imp-sub-active .sub-menu {
    max-height: 100vh;
    transition-delay: 0.6s;
    overflow: hidden;
    /* padding-top: 2.3em !important; */
  }
  /*   #menu-hauptmenu.menu-child-sub-active > .menu-item:not(.imp-sub-active) {
    max-height: 0;
    transform: translateX(-100%);
    transition-delay: 0s;
  } */
  #menu-hauptmenu .sub-menu .menu-item {
    padding-left: 0 !important;
  }
  #menu-hauptmenu > .menu-item {
    max-height: 100vw;
    transition: all 0.5s cubic-bezier(0.46, 0.03, 0.52, 0.96) 0s;
    transition-delay: 0.6s;
    overflow: hidden;
  }
  #menu-hauptmenu > .menu-item.imp-sub-active {
    overflow: visible;
  }
  .menu-item.sub-back-btn span {
    display: flex;
    color: var(--ast-global-color-0);
    font-family: var(--mainfont);
    font-weight: 600;
    gap: 15px;
  }
  .menu-item.sub-back-btn span::before {
    content: "";
    display: block;
    background-image: url(/wp-content/themes/astra-impuls-child/img/pfeil-content.svg);
    --my-size: 1.2em;
    height: var(--my-size);
    width: calc(var(--my-size) / 2.714285714285714);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    filter: brightness(13);
  }
  #menu-hauptmenu > .menu-item > a .imp-nav-target-txt {
    margin-bottom: 0.55em;
  }
  #menu-hauptmenu
    > li.menu-item.menu-item-has-children
    > a
    > .imp-nav-target
    ::after {
    display: none !important;
  }
  #menu-wrapper ul.sub-menu {
    width: 75vw !important;
  }
  #menu-wrapper .imp-sub-active .sub-menu {
    margin-bottom: calc(var(--gap-l) * 1.6);
  }
}

@media (max-width: 890px) {
  #menu-wrapper {
    justify-content: flex-start;
    gap: var(--gap-xxl);
  }
}

@media (max-width: 768px) {
  #header-icons {
    position: unset;
  }
  .submenu-image-container {
    display: none;
  }
  #menu-hauptmenu > .menu-item > a {
    font-size: 1.3rem;
  }
  #menu-hauptmenu .sub-menu a .imp-nav-target-txt::after {
    --my-size: 7.2px;
  }
  #menu-hauptmenu .sub-menu a .imp-nav-target-txt {
    gap: 8px;
  }
}

@media (max-width: 630px) {
  .menu-tel {
    flex-direction: column;
  }
  .menu-tel #header-tel-1 {
    border-bottom: 1px solid var(--ast-global-color-1);
  }
  #header-tel-1 > a a,
  #header-tel-2 > a a {
    display: none;
  }
  ul.special-submenu-depth-1 {
    flex-direction: column;
    gap: 0;
  }
  div#menu-wrapper {
    row-gap: var(--gap-m);
    padding-inline: 2rem 1rem;
  }
  #menu-wrapper ul.sub-menu {
    width: 87vw !important;
  }
  #menu-hauptmenu > .menu-item > a .imp-nav-target-txt {
    margin-bottom: 0.15em;
  }
  #menu-wrapper .imp-sub-active .sub-menu {
    margin-bottom: calc(var(--gap-l) * 1.1);
    margin-top: calc(var(--gap-s) / 1.6);
  }
  .menu-hauptmenu-container {
    padding: 31vw 0 0 0;
  }
  #header-icons {
    padding-left: 0rem !important;
    position: unset;
  }
  #menu-wrapper ul.sub-menu {
    gap: 0.45rem;
  }
  #header-icons {
    /* padding-bottom: 9.8vh; */
  }
}

@media (max-width: 576px) {
  /*   #menu-hauptmenu .sub-menu a {
    margin-bottom: 0.6em;
    font-size: 16px !important;
  } */
  #custom-menu-nav-wrapper p {
    display: none;
  }
  #menu-wrapper {
    padding-left: 0;
  }
  #custom-menu-nav-wrapper {
    max-width: unset;
    width: 100%;
  }
  #custom-menu-nav h4 {
    margin-bottom: 0;
  }
  .sub-menu .menu-item:first-child::before,
  .sub-menu .menu-item::after {
    height: 1px;
  }
  .header-tel-item .textwidget {
    display: flex;
    align-items: center;
    height: 100%;
  }
  .menu-tel {
    padding: 0.5em 0 0.7em 0;
  }
  /*   #menu-hauptmenu > .menu-item > a,
  .special-submenu-wrapper,
  #menu-hauptmenu .sub-menu .menu-item.sub-back-btn {
    padding-left: 46px !important;
    padding-right: 46px;
  } */
  #nav-bar .textwidget {
    flex-direction: column;
    gap: 7px;
  }
  .nav-bar-item {
    width: 100%;
  }
  #nav-bar * {
    font-size: 12px;
    text-align: center;
    justify-content: center;
  }
  /*
  .menu-hauptmenu-container ul#menu-hauptmenu li:nth-child(3) .special-submenu {
    gap: 5px;
  }
  */
  .menu-hauptmenu-container
    ul#menu-hauptmenu
    li:nth-child(3)
    .special-submenu-depth-1 {
    gap: 0;
  }
  a.special-submenu-title-link.menu-link {
    gap: 10px;
  }
  .special-submenu-depth-1 {
    margin-bottom: var(--gap-s) !important;
  }
  .special-submenu-depth-1 .btn .special-menu-btn {
    margin-bottom: 0;
  }
  .special-submenu-depth-1 li.menu-item {
    height: 1.2rem;
  }
  .special-submenu-depth-1 .imp-nav-target-txt {
    font-size: 14px;
  }
  .menu-item.sub-back-btn a span {
    font-kerning: none;
    letter-spacing: 0;
    gap: 5px;
  }
}

@media (max-width: 435px) {
  /*   #menu-hauptmenu > .menu-item > a {
    font-size: 1.15rem;
  }
 */
  #custom-menu-nav-wrapper .custom-menu-nav-item a {
    padding: 1.35em 1.3em 1.15em 1.3em;
  }
  /*   #header-icons {
    padding-bottom: 2.8vh;
    padding-top: 0;
  } */
  #menu-wrapper > #theme-logo > .theme-logo:last-of-type {
    width: 43vw;
    min-width: 175px;
    max-width: 296px;
  }
  a.impmenu-toggle {
    /* margin-left: 24px;*/
  }
  #nav-bar {
    bottom: 14.7vh;
  }
  /* #menu-wrapper .imp-sub-active .sub-menu {
    padding-top: 1em !important;
  } */
  /*   #menu-hauptmenu > .menu-item.imp-sub-active > .menu-link {
    border-bottom: 1px solid var(--ast-global-color-0);
  }
 */
  .menu-col.col-menu-1 {
    padding-top: calc(
      var(--header-absolute-items-top) + var(--icon-pad-top) * 2 +
        var(--icon-height) + 5vh
    );
  }
  .menu-item.sub-back-btn {
    margin-top: 1vh;
  }
  #menu-wrapper .sub-menu.special-submenu {
    gap: var(--gap-s);
  }
}

@media (max-width: 400px) {
  /*   span.special-submenu-title,
    #menu-hauptmenu a.btn.special-menu-btn.menu-link {
      font-size: 16px !important;
    } */
  /*  #menu-hauptmenu > .menu-item > a,
  .special-submenu-wrapper,
  #menu-hauptmenu .sub-menu .menu-item.sub-back-btn {
    padding-left: 25px !important;
  } */
  /*   .menu-item.sub-back-btn {
    margin-top: 2vh;
}*/
  /*   #menu-hauptmenu > .menu-item.imp-sub-active {
    margin-top: -30px;
  } */
}

@media (max-width: 576px) {
  .menu-col:has(#menu-hauptmenu) {
    /*max-height: 60vh;*/
    height: unset !important;
    transition: all 0.5s ease-in-out;
    margin-bottom: var(--gap-l);
  }
  .menu-col:has(#menu-hauptmenu.menu-child-sub-active) {
    /*max-height: 60vh;*/
    /* height: unset !important; */
    /* margin-bottom: calc(var(--gap-xl) * 1.4); */
  }
  #header-icons {
    padding-left: 0 !important;
    align-self: flex-start;
    justify-content: flex-start !important;
  }
}

#menu-hauptmenu .nav-icon {
  width: 0;
}

#menu-hauptmenu {
  width: 30vw;
}

#menu-hauptmenu > li.menu-item.menu-item-has-children > a {
  width: 100%;
}

#menu-hauptmenu > li.menu-item.menu-item-has-children > a > .imp-nav-target {
  display: flex;
  align-items: center;
  width: 100%;
}

#menu-hauptmenu
  > li.menu-item.menu-item-has-children
  > a
  > .imp-nav-target
  ::after {
  content: "";
  display: block;
  height: 1px;
  width: 0;
  background-color: var(--ast-global-color-0);
  margin-right: var(--gap-m);
  margin-left: var(--gap-m);
  position: relative;
  top: calc(50% + 2px);
  transition: all 0.9s ease-in-out;
  transition-delay: 0.5s;
}

#menu-hauptmenu
  > li.menu-item.menu-item-has-children.imp-sub-active
  > a
  > .imp-nav-target
  ::after {
  width: 100%;
}

/* Verhindert ::before und ::after auf Google-Translate-Tags */

font[style*="vertical-align: inherit"]::after,
font[style*="vertical-align: inherit"]::before {
  content: none !important;
  display: none !important;
}

.menu-link .imp-nav-target-txt {
  display: flex;
  white-space: nowrap;
  width: 100%;
  align-items: center;
}

#header.small a.impmenu-toggle #nav-icon3 {
  border: 2px solid var(--ast-global-color-2);
}

#header.small a.impmenu-toggle #nav-icon3 span {
  background-color: var(--ast-global-color-2);
}

@media (max-width: 400px) {
  span.special-submenu-title,
  #menu-hauptmenu a.btn.special-menu-btn.menu-link {
    font-size: 16px !important;
  }
  /*   #menu-hauptmenu > .menu-item > a,
  .special-submenu-wrapper,
  #menu-hauptmenu .sub-menu .menu-item.sub-back-btn {
    padding-left: 25px !important;
  } */
  .menu-item.sub-back-btn {
    margin-top: 2vh;
  }
  #menu-hauptmenu > .menu-item.imp-sub-active {
    margin-top: 0px !important;
  }
  #menu-hauptmenu {
    width: 100%;
  }
}
