/* custom_nav_main_partial.html - global */
.navigation {
	--surface-mobile-nav: var(--asm-sw-white);
	--surface-highlight: var(--asm-sw-grey-ultra-light);
	--text: var(--asm-text-on-primary);
	--text-alt: var(--asm-sw-black);
	--nav-text-mobile: var(--asm-ftw-semi-bold) var(--asm-fts-md)/var(--asm-ftl-open) var(--asm-font-family);
	--nav-item-desktop: var(--asm-ftw-medium) var(--asm-fts-sm)/var(--asm-ftl-dense) var(--asm-font-family);
	--nav-item-desktop-large: var(--asm-ftw-medium) var(--asm-fts-md)/var(--asm-ftl-dense) var(--asm-font-family);
}

.panel-header.theme_2 .navigation {
	--text: var(--asm-sw-white);
}

.contentRender_name_plugins_nav_main,
.contentRender_name_plugins_nav_main_dropdown {
	order: -1;
}

.nav-container {
	display: flex;
	justify-content: flex-end;
	height: 100%;
}

.navigation a {
	display: flex;
	align-items: center;
	padding-block: var(--space-3);
	width: 100%;
	font-size: var(--asm-fts-body);
	line-height: var(--leading-tight);
	color: inherit;
	text-decoration: none;
}

.navigation.desktop a {
	white-space: nowrap;
}

.navigation a:hover {
	color: inherit;
}

.navigation a:focus {
	text-decoration: underline;
	outline: none;
}

.navigation .nav-item .nav-item-control {
	display: flex;
	justify-content: space-between;
	color: var(--text-alt);
	transition: background-color 100ms cubic-bezier(0,0,0.3,1);
	align-items: center;
}

.navigation .nav-item .dropdown-toggle {
	position: relative;
	margin: 0;
	color: inherit;
	background-color: transparent;
	transition: background-color 100ms cubic-bezier(0, 0, 0.3, 1);
	height: 18px;
	width: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid var(--asm-sw-black);
	border-radius: var(--rounded-full);
}

.navigation .nav-item .dropdown-toggle::before {
	content: "";
	position: absolute;
	inset: -10px;
	border-radius: inherit;
}

.icon-toggle {
	font-size: 18px;
}

.navigation .nav-item .dropdown-toggle:focus {
	outline: none;
}

.navigation .nav-item button.dropdown-toggle:focus-visible {
	outline: 3px solid var(--asm-sw-black);
}

.navigation .nav-item.level-2 .dropdown-toggle .icon-toggle,
.navigation .nav-item.level-3 .dropdown-toggle .icon-toggle {
	color: var(--asm-sw-grey-dark);
}

/* menu toggle */
.nav-container .menu-toggle {
	display: block;
	margin: 0;
	padding: 0;
	background: none;
	cursor: pointer;
}

@media (min-width: 64em) {
	.nav-container .menu-toggle {
		display: none;
	}	
}

.nav-container .menu-toggle .hamburger-inner {
	position: relative;
}

.nav-container .menu-toggle .hamburger-inner {
	display: block;
	width: 46px;
	height: 35px;
	background-image: url('/includes/client_public/assets/shared/hamburger-menu.svg');
	background-size: cover;
}

.dark-text-on-primary .panel-header:not(.theme_2) .nav-container .menu-toggle .hamburger-inner {
	background-image: url('/includes/client_public/assets/shared/hamburger-menu-black.svg');
}

.nav-container .menu-toggle.active .hamburger-inner {
	width: 47px;
	height: 35px;
	background-image: url('/includes/client_public/assets/shared/hamburger-menu-close.svg');
	background-size: cover;
}

.dark-text-on-primary .panel-header:not(.theme_2) .nav-container .menu-toggle.active .hamburger-inner {
	background-image: url('/includes/client_public/assets/shared/hamburger-menu-black-close.svg');
}

/* custom_nav_main_partial.html - mobile */
.navigation.mobile {
	background-color: var(--surface-mobile-nav);
}

.navigation.mobile a {
	padding-block: 14px;
}

.navigation.mobile .nav-item:hover > .nav-item-control {
	background-color: transparent;
}

.navigation.mobile .nav-item.main {
	margin-inline-end: var(--space-1);
}

.navigation.mobile .nav-item.level-1:first-of-type .nav-item-control > .nav-link {
	padding-block-start: 0;
}

.navigation.mobile .nav-item.open > .nav-item-control {
	background-color: transparent;
	align-items: center;
}

.navigation.mobile .nav-item .dropdown-toggle:hover {
	background-color: transparent;
}

.navigation.mobile .nav-item .dropdown-toggle .icon-toggle {
	transform-origin: 50% 51%;
	transition: transform 300ms cubic-bezier(0,0,0.3,1);
	font-weight: 900;
	font-size: 11px;
	line-height: 0;
}

.navigation.mobile .nav-item.open > .nav-item-control .dropdown-toggle .icon-toggle {
	transform: rotate(360deg);
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	will-change: transform;
}

.navigation.mobile .nav-item.open>.nav-item-control .dropdown-toggle .icon-toggle.fa-plus {
	transform: rotate(180deg);
}

.navigation.mobile .nav-item .dropdown-menu {
	max-height: 0;
	overflow: hidden;
	transition: max-height 300ms ease-out;
	background-color: transparent;
}

.navigation.mobile .nav-item .dropdown-menu.open {
	display: block;
}

.navigation.mobile .nav-item .dropdown-menu a {
	font-size: var(--asm-fts-body);
}

.navigation.mobile .nav-item.level-2 .nav-item-control a,
.navigation.mobile .nav-item.level-3 .nav-item-control a {
	color: var(--asm-sw-grey-dark);
}

.navigation.mobile .nav-item.level-2 .nav-item-control a {
	margin-inline-start: var(--space-4);
}

.navigation.mobile .nav-item.level-3 .nav-item-control a {
	margin-inline-start: var(--space-8);
}

.navigation.mobile .nav-item.level-4 .nav-item-control a {
	margin-inline-start: var(--space-12);
}

/* custom_nav_main_partial.html - desktop */
.navigation.desktop {
	position: relative;
	display: none;
	justify-content: flex-end;
	height: 100%;
}

@media (min-width: 64em) {
	.navigation.desktop {
		display: flex;
		gap: var(--space-6);
	}
}

.navigation.desktop .dropdown-menu {
	opacity: 0;
	pointer-events: none;
	transition: opacity 100ms cubic-bezier(0,0,0.3,1);
	z-index: 30;
	padding-block: var(--space-12);
}

.navigation.desktop .dropdown-menu.open {
	opacity: 1;
	display: block;
}

.navigation.desktop .nav-item .dropdown-toggle {
	display: none;
}

.navigation.desktop .nav-item.open > .nav-item-control {
	background-image: url(/includes/client_public/assets/shared/dropdown-polygon.svg);
	background-position: 50% 115%;
    background-repeat: no-repeat;
}

.navigation.desktop .level-1.nav-item > .nav-item-control {
	align-items: center;
	height: 100%;
	color: var(--text);
}

.navigation.desktop .nav-item.level-2 > .nav-item-control a {
	padding-block: var(--space-3);
	padding-inline: 52px;
	font-size: var(--asm-fts-body);
}

.navigation.desktop .nav-item.level-1 > .nav-item-control > a {
	position: relative;
}

.navigation.desktop .nav-item.level-1 > .nav-item-control > a::after {
	content: '';
    position: absolute;
    bottom: 5px;
    width: 0;
    height: 2px;
    background-color: var(--asm-text-on-primary);
}

.theme_2 .navigation.desktop .nav-item.level-1 > .nav-item-control > a::after {
	background-color: var(--surface-mobile-nav);
}

.navigation.desktop .nav-item.level-1:not(.open) > .nav-item-control > a:hover::after,
.navigation.desktop .nav-item.level-1 > .nav-item-control > a:focus::after {
	left: -10px;
	width: calc(100% + var(--space-5)); /* Extend the underline on hover/focus */
}

.navigation.desktop .nav-item:not(.level-1) > .nav-item-control:hover,
.navigation.desktop .nav-item:not(.level-1) > .nav-item-control:focus-within {
	text-underline-offset: 2px;
    text-decoration-line: underline;
    text-decoration-color: var(--asm-sw-black);
}

.navigation.desktop .level-1.nav-item > .nav-item-control > .dropdown-toggle {
	margin: 0;
	padding-block: var(--space-3);
	padding-inline: var(--space-2);
}

.navigation .nav-item.level-1 .nav-item-control a,
.navigation .nav-item.level-2 .nav-item-control a,
.navigation .nav-item.level-3 .nav-item-control a {
	font: var(--nav-text-mobile);
	text-decoration: none; /*reboot.css override*/
}

@media (min-width: 64em) {
	.navigation .nav-item.level-1 .nav-item-control a,
	.navigation .nav-item.level-2 .nav-item-control a,
	.navigation .nav-item.level-3 .nav-item-control a {
		font: var(--nav-item-desktop);
	}
}

.navigation:not(.desktop) .nav-item.level-1 .nav-item-control a:focus-visible,
.navigation:not(.desktop) .nav-item.level-2 .nav-item-control a:focus-visible,
.navigation:not(.desktop) .nav-item.level-3 .nav-item-control a:focus-visible {
	text-decoration: underline;
}

@media (min-width: 1200px) {
	.navigation .nav-item.level-1 .nav-item-control a,
	.navigation .nav-item.level-2 .nav-item-control a,
	.navigation .nav-item.level-3 .nav-item-control a {
		font: var(--nav-item-desktop-large);
	}
}

/*prevents text overflow in non-level-1 nav items*/
.navigation .nav-item.level-2 .nav-item-control a,
.navigation .nav-item.level-3 .nav-item-control a {
	white-space: unset;
}
