/**
 * 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-wrapper {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  transform: translateY(-100%);
  pointer-events: none;
  transition: transform 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  z-index: 9999;
  /* clip-path: circle(0% at 50% 50%); */
}

#nav-wrapper.impmenu-active {
  transform: translateY(0);
  pointer-events: all;
  /* clip-path: circle(70.7% at 50% 50%); */
}

#main-nav {
  z-index: 9999;
  transition: all 0.5s ease 0s;
  --menu-items-padding: 70px;
  padding: 0;
  transition: all 0.5s ease 0s !important;
  position: fixed;
  left: 0;
  width: 100%;
  height: 100%;
  top: 0;
  pointer-events: all;
}

#menu-wrapper {
  height: 100%;
  display: flex;
  align-items: center;
  position: relative;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  overflow: hidden;
  padding-left: calc(var(--gap-xl) * 2);
}

#menu-wrapper ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

nav#main-nav li.menu-item a {
  text-decoration: none;
  position: relative;
}

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: center;
    gap: var(--gap-l);
    width: fit-content;
  }
}

#menu-hauptmenu > .menu-item > a {
  font-family: var(--mainfont);
  font-size: 33px;
  font-weight: 800;
  color: var(--ast-global-color-0) !important;
  letter-spacing: -0.015em;
  display: flex;
  line-height: 1.1;
  padding: 0;
}

#menu-hauptmenu > .menu-item.imp-sub-active > a,
#menu-hauptmenu > .menu-item.imp-sub-active > a span {
  color: var(--ast-global-color-4) !important;
}

#menu-hauptmenu > .menu-item.imp-sub-active > .menu-link {
  color: var(--ast-global-color-4) !important;
}

.imp-nav-target {
  display: flex;
  justify-content: space-between;
  width: 100%;
  z-index: 9;
  align-items: center;
  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: 400;
  color: var(--ast-global-color-0);
  letter-spacing: 0.08em;
  font-size: 1.15rem;
}

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-color: var(--ast-global-color-0);
}

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;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  z-index: 9;
  gap: var(--gap-m);
}

.menu-item.sub-back-btn {
  margin-top: 4.2vh;
}

.menu-item.sub-back-btn span {
  display: flex;
  align-items: center;
}

.menu-item.sub-back-btn span::before {
  content: "";
  display: block;
  height: 1.1em;
  width: calc(1.1em / 2);
  background-image: url(/wp-content/themes/astra-impuls-child/img/nav-arrow.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  margin-right: 0.6em;
  margin-top: 0em;
  transition: all 0.5s ease 0s;
  rotate: 180deg;
}

#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: 90vw;
  margin: 0;
}

/**special menu*/
.special-submenu-title-item {
  white-space: nowrap;
  display: grid;
  grid-template-columns: auto auto;
  /* gap: var(--gap-m);*/
}

/*
.special-submenu-icon {
  display: block;
  --my-size: 105px;
  height: var(--my-size);
  width: var(--my-size);
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
}

.special-submenu-title-item:nth-child(1) .special-submenu-icon {
  background-image: url("../../img/icon-marken-konzept.svg");
}

.special-submenu-title-item:nth-child(2) .special-submenu-icon {
  background-image: url("../../img/icon-marketing-target.svg");
}

.special-submenu-title-item:nth-child(3) .special-submenu-icon {
  background-image: url("../../img/icon-marken-entwicklung.svg");
}

.special-submenu-title-item:nth-child(4) .special-submenu-icon {
  background-image: url("../../img/icon-marken-kommunikation.svg");
}

*/
.special-submenu-wrapper {
  display: grid;
  gap: calc(var(--gap-s) / 2);
}

span.special-submenu-title {
  font-family: var(--mainfont);
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: 1.48;
  letter-spacing: 0;
  color: var(--ast-global-color-2);
}

ul.special-submenu-depth-1 {
  display: flex;
  gap: var(--gap-l);
}

a.special-submenu-title-link.menu-link {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
}

a.btn.special-menu-btn.menu-link {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mainfont) !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1.22 !important;
  height: auto;
  transition: all 0.5s ease 0s;
  color: var(--ast-global-color-2) !important;
}

a.btn.special-menu-btn.menu-link::before,
#menu-hauptmenu
  .menu-link-about
  .sub-menu
  li
  a.menu-link
  .imp-nav-target-txt::before,
a.special-submenu-title-link.menu-link::before {
  content: "";
  display: inline-block;
  --my-size: 0.7em;
  width: calc(var(--my-size) / 1.6955);
  height: var(--my-size);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transition: all 0.5s ease 0s;
  background-image: url(../../../img/button-arrow.svg);
}

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;
}

.menu-hauptmenu-container
  ul#menu-hauptmenu
  li:nth-child(3)
  .special-submenu-depth-1 {
  gap: var(--gap-s);
  flex-direction: column;
  padding: var(--gap-s) 0 0 var(--gap-l) !important;
}

@media (min-width: 1025px) {
  #menu-hauptmenu > .menu-item {
    max-height: 100vh;
    display: flex;
    justify-content: flex-start;
    position: relative;
  }

  #menu-wrapper ul.sub-menu {
    max-height: 0;
    transition: all 0.6s ease-in-out 0s;
    overflow: hidden;
    transition-delay: 0.1s, 0.1s;
    transition-property: transform, max-height;
    position: absolute;
    left: 100%;
  }

  #menu-wrapper .imp-sub-active ul.sub-menu {
    max-height: 100vh;
    transition-property: transform, max-height;
    transition-delay: 0.5s;
  }

  /**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.5s ease 0s;
    transition-delay: 1s;
  }

  #menu-hauptmenu > .menu-item.imp-sub-active:after {
    width: calc(var(--gap-xl) + var(--gap-m));
    transition-delay: 0s;
  }

  #menu-hauptmenu > li.menu-item-has-children:last-child > ul.sub-menu {
    transform: translateY(-30%);
  }
}

@media (max-width: 1024px) {
  #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 (min-width: 1920px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}

@media (min-width: 1024px) and (max-width: 1600px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}

@media (max-width: 1500px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}

@media (max-width: 1200px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}

@media (max-width: 990px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}

@media (max-width: 768px) {
}

@media (max-width: 576px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}

@media (max-width: 435px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}

@media (max-width: 320px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}
