/* custom_nav_main_partial.html - global */
.navigation {
	--surface-mobile-nav: var(--primary-color-200);
	--surface-highlight: var(--primary-color-400);
	--text: var(--white);
	--text-alt: var(--dark-blue);
}

.contentRender_name_plugins_nav_main,
.contentRender_name_plugins_nav_main_dropdown {
	order: -1;
}

.nav-container {
	display: flex;
	justify-content: flex-start;
	height: 100%;
}

.navigation a {
	display: flex;
	align-items: center;
	padding: 5px var(--space-2) 7px 0;
	font-size: var(--text-base);
	line-height: var(--leading-tight);
	color: inherit;
	text-decoration: none;
}

.mobile-nav .mobile-main-nav {
	margin: 0 var(--space-5) 26px;
}

.mobile-nav .mobile-secondary-nav {
	margin: 0 var(--space-5);
	padding-top: 32px;
	padding-bottom: 18px;
	border-top: 1px solid var(--grey);
}

.mobile-nav .mobile-main-nav .navigation.primary .nav-item.level-1 a {
	font-size: var(--text-xl-1);
	font-weight: 700;
	color: var(--dark-blue);
	text-transform: uppercase;
}

.mobile-nav .mobile-main-nav .navigation.primary .nav-item:not(.level-1) a {
	font-size: var(--text-sm);
	font-weight: 400;
	padding-left: var(--space-5);
	text-transform: unset;
}

.mobile-nav .mobile-main-nav .navigation.primary .nav-item.level-3 a {
	padding-left: 50px;
}

.mobile-nav .mobile-main-nav .navigation.primary .nav-item.level-4 a {
	padding-left: 80px;
}

.navigation.mobile .dropdown-menu.level-1 {
	margin: var(--space-1) 0;
}

.navigation.mobile .dropdown-menu.level-1.open.rendered {
	margin: var(--space-1) 0 var(--space-4);
}

.navigation.mobile .dropdown-menu:not(.level-1).rendered {
	margin: var(--space-4) 0;
	display: none;
}

.navigation.secondary.mobile .nav-item.level-1 a {
	font-size: var(--text-xl);
	color: var(--dark-grey);
	font-weight: 600;
	padding: 3px var(--space-2) 3px 0;
}

.navigation.secondary.mobile .nav-item:not(.level-1) a {
	font-size: var(--text-sm);
	font-weight: 500;
	padding-left: var(--space-5);
}

.mobile-nav .mobile-footer-nav {
	margin: 0 var(--space-5) var(--space-10);
}

.mobile-nav .mobile-footer-nav a {
	font-size: var(--text-sm);
	color: var(--dark-grey);
	font-weight: 600;
	padding: 3px var(--space-2) 3px 0;
}

.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: flex-start;
	color: var(--text-alt);
	transition: background-color 100ms cubic-bezier(0,0,0.3,1);
}

.navigation.desktop .nav-item .nav-item-control:not(.level-1) {
	gap: var(--space-2-10);
}

.navigation .nav-item .dropdown-toggle {
	margin: 0;
	padding: 0;
	color: inherit;
	display: inline-flex;
	transition: background-color 100ms cubic-bezier(0,0,0.3,1);
	align-items: center;
	justify-content: center;
	padding-bottom: 7px;
}

.navigation.desktop .nav-item .dropdown-toggle {
	padding-bottom: 2px;
}

.navigation .nav-item .dropdown-toggle:hover {
	background-color: var(--white);
}

.navigation .nav-item .dropdown-toggle:focus {
	outline: 1px dashed var(--sw-light-focus-color);
	outline-offset: 0;
}

/* menu toggle */
.nav-container .menu-toggle {
	display: block;
	margin: 0;
	padding: 0;
	background: none;
	cursor: pointer;
}

.nav-container .menu-toggle .menu-button::before {
	content: '';
	width: 43px;
	height: 43px;
	display: block;
	background: url('/includes/public/assets/shared/menu.svg') no-repeat;
}

.hamburger-open .nav-container .menu-toggle .menu-button::before {
	content: '';
	width: 43px;
	height: 43px;
	display: block;
	background: url('/includes/public/assets/shared/close-icon.svg') no-repeat;
}


@media (min-width: 64em) {
	.nav-container .menu-toggle {
		display: none;
	}	
}

.nav-container .menu-toggle .hamburger-inner {
	position: relative;
}

.nav-container .menu-toggle .hamburger-inner::after,
.nav-container .menu-toggle .hamburger-inner::before {
	position: absolute;
}

.nav-container .menu-toggle .hamburger-inner,
.nav-container .menu-toggle .hamburger-inner::after,
.nav-container .menu-toggle .hamburger-inner::before {
	display: block;
	width: 28px;
	height: 2px;
	background-color: var(--white);
	transition: transform 0.075s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.nav-container .menu-toggle .hamburger-inner::before {
	content: "";
	top: -7px;
	transition: top 0.075s 0.12s ease, opacity 0.075s ease;
}

.nav-container .menu-toggle .hamburger-inner::after {
	content: "";
	bottom: -7px;
	transition: bottom 0.075s 0.12s ease, transform 0.075s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.nav-container .menu-toggle.active .hamburger-inner {
	transform: rotate(45deg);
	transition-delay: 0.12s;
	transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

.nav-container .menu-toggle.active .hamburger-inner::before {
	top: 0;
	opacity: 0;
	transition: top 0.075s ease, opacity 0.075s 0.12s ease;
}

.nav-container .menu-toggle.active .hamburger-inner::after {
	bottom: 0;
	transform: rotate(-90deg);
	transition: bottom 0.075s ease, transform 0.075s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/* custom_nav_main_partial.html - mobile */
.navigation.mobile {
	background-color: var(--surface-mobile-nav);
}

.navigation .nav-item .dropdown-toggle .icon-toggle {
	transform-origin: center;
	transition: transform 300ms cubic-bezier(0,0,0.3,1);
	display: inline-flex;
	width: 15px;
	height: 15px;
	align-items: center;
	justify-content: center;
	background: var(--grey);
	color: var(--white);
	border-radius: var(--rounded-circle);
	font-size: 7px;

}

.navigation .nav-item.open > .nav-item-control .dropdown-toggle .icon-toggle {
	transform: rotate(-180deg);
	background: var(--yellow);
}

.navigation .nav-item.open > .nav-item-control .dropdown-toggle .icon-toggle::before {
	content: '\f068';
	width: 7px;
	display: inline-flex;
	font-size: 7px;
	align-items: center;
	justify-content: center;
	padding-bottom: 0;
}

.navigation .nav-item .dropdown-menu a {
	font-size: var(--text-base);
}

/* 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: 15px;
	}

	.navigation a {
		padding: 2px 0;
	}

	.navigation .nav-item .dropdown-toggle {
		padding-bottom: 2px;
	}
}

.navigation.desktop .dropdown-menu {
	opacity: 0;
	pointer-events: none;
	transition: opacity 100ms cubic-bezier(0,0,0.3,1);
	z-index: 30;
	padding: 21px 20px 26px 19px;
}

.navigation.desktop .level-1.nav-item > .nav-item-control .icon-toggle {
	display: none;
}

.navigation.desktop .dropdown-menu.open {
	display: block !important;
}

.navigation.desktop .level-1.nav-item > .nav-item-control {
	align-items: center;
	height: 100%;
	color: var(--text);
	position: relative;
}

.navigation.desktop .nav-item.level-1 > .nav-item-control > a {
	border-top: 2px solid transparent;
	border-bottom: 2px solid transparent;
}

.navigation.desktop .nav-item.level-1 > .nav-item-control > a:focus {
	border-bottom-color: var(--surface-mobile-nav);
}

.navigation.desktop .nav-item:not(.level-1) > .nav-item-control:focus-within {
	background-color: var(--surface-highlight);
}

.navigation.desktop .nav-item.level-1 > .nav-item-control > a:focus,
.navigation.desktop .nav-item.level-1 > .nav-item-control > a:hover {
	border-bottom-color: var(--surface-mobile-nav);
}

.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 {
	text-decoration: none; /*reboot.css override*/
}

/*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;
}

.navigation.desktop .level-1.nav-item > .nav-item-control > .dropdown-toggle {
	margin: 0;
	padding: 0;
}

.navigation.desktop .level-1.nav-item > .nav-item-control::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	height: 2px;
	width: 100%;
	background: var(--white);
	opacity: 0;
	z-index: 1;
}

.navigation.desktop .level-1.nav-item.open > .nav-item-control::after {
	opacity: 1;
}
