/* custom_nav_main_partial.html - global */
.navigation {
	--surface-mobile-nav: var(--cream-f8);
	--surface-highlight: var(--purple-7e);
	--text: var(--purple-3e);
	--text-alt: var(--white);
}

.nav-container {
	display: flex;
	justify-content: flex-end;
	height: 100%;
}

.navigation a {
	display: flex;
	align-items: center;
	padding: var(--space-3) var(--space-4);
	width: 100%;
	font-size: var(--text-base);
	line-height: var(--leading-tight);
	color: inherit;
	font-weight: 100;
	text-decoration: none;
}

.navigation .open > a {
    font-weight: 600;
}

.navigation :not(.level-1) > a {
	padding: 7px;
}

.navigation .level-1 > a {
	font-family:var(--font-display);
	font-size:28px;
	letter-spacing: 1.5px;
	padding: 5px 20px;
	font-weight: 600;
}

.navigation .level-2 > a {
	padding-left: 40px;
}

.navigation .level-3 > a {
	padding-left: 60px;
}

.navigation .level-4 > a {
	padding-left: 80px;
}

.navigation .dropdown-menu.open {
	padding-top: 8px;
	background-color: var(--white);
	margin-bottom: 12px;
}



.navigation.secondary .level-1 > a {
	font-size: 20px;
	padding: 8.5px 24px 5px;
	text-transform: uppercase;
	letter-spacing: 2px;
}


.navigation.desktop a {
	white-space: nowrap;
}

.navigation.desktop .nav-item:not(.level-1) .nav-item-control:not(.level-1) a {
	white-space: normal;
}

.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);
	transition: background-color 100ms cubic-bezier(0,0,0.3,1);
}

.navigation .nav-item:not(.level-1) .nav-item-control {
	background-color: var(--white)
}

.navigation .nav-item.open:not(.level-1) > .nav-item-control {
	color: var(--text-alt);
}

.navigation .nav-item .dropdown-toggle {
	margin: 0;
	padding: 4px var(--space-4);
	color: inherit;
	background-color: transparent;
	transition: background-color 100ms cubic-bezier(0,0,0.3,1);
}

.navigation .nav-item .dropdown-toggle:focus {
	outline: 1px dashed var(--text-alt);
}

/* menu toggle */
.nav-container .menu-toggle {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin: 0;
	padding: 0;
	background: none;
	cursor: pointer;
}

.nav-container .menu-toggle span {
	color: var(--white);
	font-size: 11px;
	text-transform: uppercase;
	margin-top: 1px;
}

.nav-container .menu-toggle .close-menu-icon {
	width: 25px;
}

.nav-container .menu-toggle .close-menu-icon,
.nav-container .menu-toggle .close-menu-text {
	display: none;
}

.nav-container .menu-toggle.active .close-menu-icon,
.nav-container .menu-toggle.active .close-menu-text {
	display: inline-block;
}

.nav-container .menu-toggle.active .open-menu-icon,
.nav-container .menu-toggle.active .open-menu-text {
	display: none;
}

.mobile-footer-nav .navigation-footer {
	background-color: var(--surface-background);
	padding: 12px 20px 10px;
	font-size: 13px;
	letter-spacing: 0px;
	font-weight: 100;
}

.mobile-footer-nav .navigation-footer a {
	padding: 7px 0;
	display: block;
}



.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-property: 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);
	padding-top: 8px;
	border-bottom: 2px solid var(--purple-d3);
	padding-bottom: 13px;
}

.navigation.mobile.secondary {
	border-bottom: none;
}

.navigation.mobile .nav-item.open:not(.level-1) > .nav-item-control {
	background-color: var(--surface-highlight);
}

.navigation.mobile .nav-item .dropdown-toggle .icon-toggle {
	transform-origin: center;
	transition: transform 300ms cubic-bezier(0,0,0.3,1);
}

.navigation.mobile .nav-item.open > .nav-item-control .dropdown-toggle .icon-toggle {
	transform: rotate(-180deg);
}

.navigation.mobile .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 .dropdown-menu {
	display: block !important;
	opacity: 0;
	pointer-events: none;
	transition: opacity 100ms cubic-bezier(0,0,0.3,1);
	z-index: 30;
	padding-top: var(--space-5);
	padding-bottom: var(--space-5);
}

.navigation.desktop .level-1.nav-item > .nav-item-control {
	align-items: center;
	height: 100%;
	color: var(--text);
}

.navigation.desktop .nav-item.level-1 > .nav-item-control > a {
	border-top: 2px solid transparent;
	border-bottom: 2px solid transparent;
}

@media (hover : hover) {
	.navigation.desktop .nav-item:not(.level-1) > .nav-item-control:hover {
		background-color: var(--surface-highlight);
	}

    .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*/
	}
    .navigation .level-1 > a span {
    	position: relative;
    }
	.navigation .level-1 > a span::after {
	    content: '';
	    pointer-events: none;
	    position: absolute;
	    left: 0;
	    bottom: -5px;
	    /* transform: translate(-50%, -50%); */
	    display: block;
	    width: 100%;
	    height: 4px;
	    background-color: transparent;
	}

	.navigation .open .level-1 > a span::after,
    .navigation .level-1 > a:hover span::after {
	    background-color: var(--green-a6);
	}	
}

.navigation.desktop .level-1.nav-item > .nav-item-control > .dropdown-toggle {
	margin: 0;
	padding: var(--space-3) var(--space-2);
}

@media (min-width: 64em) {
	.nav-container .menu-toggle {
		display: none;
	}	
	.navigation .nav-item .level-1 > .dropdown-toggle {
		display: none;
	}

	.navigation .nav-item:first-of-type .level-1 > a {
	    padding-left: 0;
    }

    .navigation .nav-item:last-of-type .level-1 > a {
	    padding-right: 0;
    }

	.navigation .level-1 > a {
	    font-size:20px;
    }

    .navigation.secondary .level-1 > a {
	    font-size: 16px;
	    padding: 7px 12px 4px;
	   }

    .navigation.desktop .level-1.nav-item > .nav-item-control {
    	color: var(--text-alt);
    	padding-bottom: 6px;
    }

    .panel-header.scrolled .navigation.desktop .level-1.nav-item > .nav-item-control {
    	padding-bottom: 11px;
    }    

    .navigation.desktop.secondary .level-1.nav-item > .nav-item-control {
    	padding-bottom: 0;
    }

    .navigation .nav-item:not(.level-1) > .nav-item-control {
    	color: var(--purple-3e);
    }

    .navigation .nav-item.open:not(.level-1) > .nav-item-control {
    	background-color: var(--purple-7e);
    }

    .navigation .nav-item:not(.level-1) > .nav-item-control:hover {
    	color: var(--text-alt);
    }
    .navigation .level-1 > a span::after {
    	bottom: -15px;
    }

    .panel-header.scrolled .navigation .level-1 > a span::after {
    	bottom: -21px;
    }

    .navigation.secondary .level-1 > a span::after {
    	bottom: -6px;
    }

    .navigation :not(.level-1) > a {
    	font-size: 15px;
    	padding-bottom: 9px;
    	padding-left: 20px;
    }

    .navigation .nav-item:not(.level-1) .nav-item-control {
    	background-color: transparent;
    }
    .navigation.desktop {
		display: flex;
		margin-top: 5px;
	}
}

@media screen and (min-width:1300px) {
	.navigation .level-1 > a {
	    font-size:28px;
	    padding: 0 28px;
	 }

    .navigation.secondary .level-1 > a {
	    font-size: 20px;
	    padding: 7px 24px 4px;
	}
	.navigation .level-1 > a span::after {
    	bottom: -10px
    }
    .navigation.desktop {
		display: flex;
		margin-top: 4px;
	}
	.panel-header.scrolled .navigation.desktop .level-1.nav-item > .nav-item-control {
		padding-bottom: 14px;
	}
	.panel-header.scrolled .navigation .level-1 > a span::after {
		bottom: -18px;
	}
}