/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/

.menu,
.sub-menu {
	list-style: none;
	padding: 0;
	margin: 0;
}

.site-header-main {
	position: relative;	
}

.main-navigation .sub-menu {
	position: absolute;
	top: -9999em;
	left: -9999em;
	width: 100%;
	visibility: hidden;
	transition: transform 0.25s ease-out;
	transform: scale(0);
	transform-origin: top right;	
}

.main-navigation li.toggled-on-load > .sub-menu,
.main-navigation li.toggled > .sub-menu {
	position: static;
}

/* Menu toggle button */
.menu-toggle {
	background: none;
	border: none;
	background-color: transparent; 
	border-radius: 0;
	position: absolute;
	top: 50%;
	right: var(--gutter-width);
	width: 32px;
	height: 32px;
	padding: 0 2px;
	transform: translateY(-50%);
	z-index: 12;
}

.menu-toggle-bar {
	display: block;
	height: 4px;
	margin: 4px 0;
	border-radius: 4px;
	background-color: var(--color-primary-500);	
}

.toggled > .hamburger-middle {
	opacity: 0;
}

.toggled > .hamburger-top {
	transform: translateY(8px) rotate(-45deg);
}

.toggled > .hamburger-bottom {
	transform: translateY(-8px) rotate(45deg);
}

/* Main Navigation */
.mobile-menu {
	visibility: hidden;
	position: absolute;
	top: -9999em;
	left: -9999em;
	background-color: var(--color-surface);
	box-shadow: var(--box-shadow);
	width: 100%;
	padding: var(--space-large) 0;
	transform: scale(0);
	transform-origin: top right;
	transition: transform 0.25s ease-out;
	z-index: 10;
}

.mobile-menu.toggled {
	visibility: visible;
	top: 100%;
	left: auto;
	right: 0;
	transform: scale(1);	
}


.main-navigation .menu li {
	padding: var(--space-small) var(--gutter-width);
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}

.main-navigation .menu > li.toggled {
	padding-bottom: 0;
}

.main-navigation .sub-menu-toggle {
	margin-left: auto;
	padding: 0;
	width: 30px;
	font-size: 1.25em;
	background-color: transparent;
	color: inherit;
	align-self: center;
}

.sub-menu-toggle::after {
	font-family: icon !important;
	font-style: normal;
	font-weight: 400;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.sub-menu-toggle[aria-expanded="false"]::after {
	content: var(--icon-ftm-angle-down);
}

.sub-menu-toggle[aria-expanded="true"]::after {
	content: var(--icon-ftm-angle-up);
}

.main-navigation a:not(.button) {
	text-decoration: none;
	color: inherit;	
}

.menu-item-has-children > a {
	max-width: calc(100% - 50px);	
}

.main-navigation .toggled-on-load > .sub-menu,
.main-navigation .toggled > .sub-menu {
	visibility: visible;
	transform: scale(1);
}

.main-navigation .sub-menu li {
	padding-right: 0;	
}

