/*!
 * Amvionlie CMS
 * Menu Manager Public Menu Functional CSS
 * File: amvionlie_phoenix/addons/menu_manager/assets/css/public_menu.css
 * Version: v0.0001 Alpha
 * Updated: 2026-04-27
 * Author: K-Tech Industries, Engineering Team
 * Purpose: Provides Menu Manager-owned menu behavior mechanics without theme identity styling.
 */
.amv-public-nav,
.amv-public-nav * {
  box-sizing: border-box;
}

.amv-public-nav {
  position: relative;
  z-index: 11000;
  color: inherit;
  font: inherit;
  --amv-menu-gap: 0.75rem;
  --amv-menu-sub-gap: 0.35rem;
  --amv-menu-link-block: 0.35rem;
  --amv-menu-link-inline: 0;
  --amv-menu-panel-gap: 0.65rem;
  --amv-menu-panel-offset: 0.55rem;
  --amv-menu-panel-radius: 0.85rem;
  --amv-menu-item-radius: 0.6rem;
  --amv-menu-motion: 0.18s ease;
}

.amv-public-region:has(.amv-public-nav),
.amv-generated-template .amv-region:has(.amv-public-nav),
.amv-generated-template .amv-layout-row:has(.amv-public-nav),
.amv-generated-template .amv-block:has(.amv-public-nav),
.amv-generated-template .amv-block__body:has(.amv-public-nav),
.amv-generated-template .amv-element:has(.amv-public-nav) {
  overflow: visible;
  position: relative;
  z-index: 11000;
}

.amv-public-nav ul,
.amv-public-nav li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.amv-public-nav__list {
  display: flex;
  align-items: center;
  column-gap: var(--amv-menu-gap);
  row-gap: var(--amv-menu-sub-gap);
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}

.amv-public-nav__item {
  position: relative;
}

.amv-public-nav__item.has-children,
.amv-public-nav__item.is-open {
  z-index: 11010;
}

.amv-public-nav.is-dropdown .amv-public-nav__item.has-children::after,
.amv-public-nav.is-horizontal .amv-public-nav__item.has-children::after,
.amv-public-nav.is-mega .amv-public-nav__item.has-children::after {
  content: "";
  display: none;
  position: absolute;
  inset-block-start: 100%;
  inset-inline: -0.35rem;
  block-size: calc(var(--amv-menu-panel-offset) + 0.15rem);
}

.amv-public-nav.is-dropdown .amv-public-nav__item.has-children:hover::after,
.amv-public-nav.is-horizontal .amv-public-nav__item.has-children:hover::after,
.amv-public-nav.is-mega .amv-public-nav__item.has-children:hover::after,
.amv-public-nav.is-dropdown .amv-public-nav__item.is-open::after,
.amv-public-nav.is-horizontal .amv-public-nav__item.is-open::after,
.amv-public-nav.is-mega .amv-public-nav__item.is-open::after {
  display: block;
}

.amv-public-nav__link,
.amv-public-nav__toggle,
.amv-public-nav__drawer-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--amv-menu-link-block) var(--amv-menu-link-inline);
  border: 0;
  border-radius: 0;
  background: none;
  color: inherit;
  font: inherit;
  line-height: inherit;
  text-decoration: none;
  cursor: pointer;
  outline: 0;
  transition:
    background-color var(--amv-menu-motion),
    box-shadow var(--amv-menu-motion),
    color var(--amv-menu-motion),
    opacity var(--amv-menu-motion),
    transform var(--amv-menu-motion);
}

.amv-public-nav__link.is-current {
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.amv-public-nav__link:hover,
.amv-public-nav__link:focus-visible,
.amv-public-nav__toggle:hover,
.amv-public-nav__toggle:focus-visible,
.amv-public-nav__drawer-toggle:hover,
.amv-public-nav__drawer-toggle:focus-visible {
  background: var(--amv-menu-link-hover-background, none);
}

.amv-public-nav__link:focus-visible,
.amv-public-nav__toggle:focus-visible,
.amv-public-nav__drawer-toggle:focus-visible {
  box-shadow: var(--amv-menu-link-focus-shadow, none);
}

.amv-public-nav__toggle,
.amv-public-nav__drawer-toggle {
  appearance: none;
}

.amv-public-nav__branch {
  display: flex;
  align-items: center;
}

.amv-public-nav__branch > .amv-public-nav__link {
  flex: 1 1 auto;
}

.amv-public-nav__toggle {
  flex: 0 0 auto;
}

.amv-public-nav.is-horizontal .amv-public-nav__toggle,
.amv-public-nav.is-dropdown .amv-public-nav__toggle,
.amv-public-nav.is-mega .amv-public-nav__toggle {
  inline-size: auto !important;
  min-inline-size: 0 !important;
  min-block-size: 0 !important;
  padding: 0 0 0 0.15rem !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: none !important;
  color: inherit !important;
}

.amv-public-nav__toggle-label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

.amv-public-nav__toggle::after,
.amv-public-nav__drawer-toggle::after {
  content: "";
  display: inline-block;
  width: 0.45em;
  height: 0.45em;
  margin-inline-start: 0.35em;
  border-inline-end: var(--amv-menu-toggle-arrow-border, 0);
  border-block-end: var(--amv-menu-toggle-arrow-border, 0);
  transform: rotate(45deg);
  transition: transform 0.18s ease;
}

.amv-public-nav__item.is-open > .amv-public-nav__branch > .amv-public-nav__toggle::after,
.amv-public-nav__drawer.is-open > .amv-public-nav__drawer-toggle::after {
  transform: rotate(225deg);
}

.amv-public-nav__panel {
  position: absolute;
  inset-block-start: calc(100% + var(--amv-menu-panel-offset));
  inset-inline-start: 0;
  min-inline-size: max-content;
  border: var(--amv-menu-panel-border, 0);
  border-radius: var(--amv-menu-panel-radius);
  background: var(--amv-menu-panel-background, none);
  box-shadow: var(--amv-menu-panel-shadow, none);
  backdrop-filter: var(--amv-menu-panel-filter, none);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.35rem) scale(0.98);
  transform-origin: top left;
  pointer-events: none;
  z-index: 11020;
  transition:
    opacity var(--amv-menu-motion),
    transform var(--amv-menu-motion),
    visibility var(--amv-menu-motion);
}

.amv-public-nav__item.is-open > .amv-public-nav__panel,
.amv-public-nav[data-interaction-mode="hover_only"] .amv-public-nav__item.has-children:hover > .amv-public-nav__panel,
.amv-public-nav[data-interaction-mode="hover_and_click"] .amv-public-nav__item.has-children:hover > .amv-public-nav__panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.amv-public-nav__sublist {
  display: grid;
  row-gap: var(--amv-menu-sub-gap);
  padding-block: var(--amv-menu-panel-gap);
  color: inherit;
}

.amv-public-nav__sublist .amv-public-nav__link,
.amv-public-nav__sublist .amv-public-nav__toggle {
  justify-content: flex-start;
  inline-size: 100%;
  border-radius: var(--amv-menu-item-radius);
  padding-block: max(0.45rem, var(--amv-menu-link-block));
  padding-inline: max(0.7rem, var(--amv-menu-link-inline));
  text-align: start;
}

.amv-public-nav__sublist .amv-public-nav__link:hover,
.amv-public-nav__sublist .amv-public-nav__link:focus-visible,
.amv-public-nav__sublist .amv-public-nav__toggle:hover,
.amv-public-nav__sublist .amv-public-nav__toggle:focus-visible {
  transform: translateX(0.12rem);
}

.amv-public-nav__sublist .amv-public-nav__panel {
  inset-block-start: 0;
  inset-inline-start: 100%;
}

.amv-public-nav.is-vertical .amv-public-nav__list,
.amv-public-nav.is-accordion .amv-public-nav__list {
  display: grid;
  align-items: stretch;
  row-gap: var(--amv-menu-sub-gap);
}

.amv-public-nav.is-vertical .amv-public-nav__branch,
.amv-public-nav.is-accordion .amv-public-nav__branch {
  inline-size: 100%;
}

.amv-public-nav.is-vertical .amv-public-nav__panel,
.amv-public-nav.is-accordion .amv-public-nav__panel {
  position: static;
  display: block;
  min-inline-size: 0;
  max-block-size: 0;
  overflow: hidden;
  opacity: 1;
  visibility: visible;
  transform: none;
  pointer-events: auto;
  transition: max-block-size 0.24s ease;
}

.amv-public-nav.is-vertical .amv-public-nav__sublist,
.amv-public-nav.is-accordion .amv-public-nav__sublist {
  padding-block: var(--amv-menu-sub-gap) 0;
  padding-inline-start: 1rem;
}

.amv-public-nav.is-dropdown .amv-public-nav__panel,
.amv-public-nav.is-horizontal .amv-public-nav__panel,
.amv-public-nav.is-mega .amv-public-nav__panel {
  padding: var(--amv-menu-panel-gap);
  color: inherit;
}

.amv-public-nav.is-dropdown .amv-public-nav__panel > .amv-public-nav__sublist,
.amv-public-nav.is-horizontal .amv-public-nav__panel > .amv-public-nav__sublist,
.amv-public-nav.is-mega .amv-public-nav__panel > .amv-public-nav__sublist {
  padding-block: 0;
  row-gap: 0.2rem;
}

.amv-public-nav.is-vertical .amv-public-nav__item.is-open > .amv-public-nav__panel,
.amv-public-nav.is-accordion .amv-public-nav__item.is-open > .amv-public-nav__panel,
.amv-public-nav.is-vertical[data-interaction-mode="hover_only"] .amv-public-nav__item.has-children:hover > .amv-public-nav__panel,
.amv-public-nav.is-accordion[data-interaction-mode="hover_only"] .amv-public-nav__item.has-children:hover > .amv-public-nav__panel,
.amv-public-nav.is-vertical[data-interaction-mode="hover_and_click"] .amv-public-nav__item.has-children:hover > .amv-public-nav__panel,
.amv-public-nav.is-accordion[data-interaction-mode="hover_and_click"] .amv-public-nav__item.has-children:hover > .amv-public-nav__panel {
  max-block-size: 60rem;
}

.amv-public-nav.is-mega .amv-public-nav__item[data-depth="0"] {
  position: static;
}

.amv-public-nav.is-mega .amv-public-nav__item[data-depth="0"] > .amv-public-nav__panel {
  inset-inline: 0;
  min-inline-size: min(72rem, calc(100vw - 2rem));
}

.amv-public-nav.is-mega .amv-public-nav__item[data-depth="0"] > .amv-public-nav__panel > .amv-public-nav__sublist {
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  align-items: start;
  column-gap: 1rem;
  row-gap: 0.75rem;
}

.amv-public-nav.is-footer .amv-public-nav__list,
.amv-public-nav.is-utility-account .amv-public-nav__list {
  flex-wrap: wrap;
}

.amv-public-nav.is-utility-account .amv-public-nav__list {
  justify-content: flex-end;
}

.amv-public-nav.is-render-stacked > .amv-public-nav__list,
.amv-public-nav.is-render-stacked .amv-public-nav__sublist {
  display: grid;
  align-items: stretch;
}

.amv-public-nav.is-render-slide .amv-public-nav__panel {
  transform: translateX(-0.6rem);
  transition:
    opacity var(--amv-menu-motion),
    transform 0.24s ease,
    visibility var(--amv-menu-motion),
    max-block-size 0.24s ease;
}

.amv-public-nav.is-render-slide .amv-public-nav__item.is-open > .amv-public-nav__panel,
.amv-public-nav.is-render-slide[data-interaction-mode="hover_only"] .amv-public-nav__item.has-children:hover > .amv-public-nav__panel,
.amv-public-nav.is-render-slide[data-interaction-mode="hover_and_click"] .amv-public-nav__item.has-children:hover > .amv-public-nav__panel {
  transform: translateX(0);
}

.amv-public-nav__drawer-toggle {
  display: none;
}

.amv-public-nav.is-hamburger-mobile > .amv-public-nav__drawer > .amv-public-nav__drawer-toggle {
  display: inline-flex;
}

.amv-public-nav.is-hamburger-mobile > .amv-public-nav__drawer .amv-public-nav__drawer-panel {
  display: grid;
  max-block-size: 0;
  overflow: hidden;
  transition: max-block-size 0.25s ease;
}

.amv-public-nav.is-hamburger-mobile > .amv-public-nav__drawer.is-open .amv-public-nav__drawer-panel {
  max-block-size: 80vh;
}

@media (max-width: 760px) {
  .amv-public-nav:not(.is-footer):not(.is-utility-account) > .amv-public-nav__list {
    display: grid;
    align-items: stretch;
  }

  .amv-public-nav__panel,
  .amv-public-nav__sublist .amv-public-nav__panel {
    position: static;
    min-inline-size: 0;
    max-block-size: 0;
    overflow: hidden;
    opacity: 1;
    visibility: visible;
    transform: none;
    pointer-events: auto;
    transition: max-block-size 0.24s ease;
  }

  .amv-public-nav__item.is-open > .amv-public-nav__panel {
    max-block-size: 60rem;
  }
}
