.navigation__container{
	flex: 1;
	gap: var(--gap);
	align-items: center;
}

button.mobile{
	display: none;
	font-size: 1.4rem;
}
button.mobile[data-toggle="true"]{
	color: var(--primary);
}


nav ul{
	display: flex;
	list-style: none;
	gap: 2rem;
}
nav li{
	position: relative;
}
nav a{
	color: var(--link);
}
nav a:hover,
nav [class*="current"] > div > a{
	color: var(--hover);
	text-decoration: none;
}
nav.align-right{
	gap: var(--gap);
	margin-left: auto;
}

/* --Main Level*/
nav [data-level="0"]{
	display: flex;
	align-items: center;
	gap: 5px;
}
nav [data-level="0"] > a{
	font-weight: 500;
}

button.caret{
	font-size: .6rem;
}

@media( min-width: 1024px ){
	nav li:hover ul.sub-menu{
		display: flex;
	}

	nav [data-level="0"] > a{
		position: relative;
	}
	nav [data-level="0"] > a:hover::after,
	nav [class*="current"] [data-level="0"] > a::after{
		transform: scaleX(1);
		transform-origin: left center;
	}
	nav [data-level="0"] > a::after{
		content: '';
		position: absolute;
		background: currentColor;
		height: 1px;
		width: 100%;
		left: 0;
		bottom: 0;
		transform: scaleX(0);
		transform-origin: right center;
		transition: transform .4s;
	}
}

/* --Sub Level 1*/
nav ul.sub-menu{
	display: none;
	flex-direction: column;
	gap: 5px;
	background: #fff;
	padding: 0.5rem 1rem;
	border-radius: 6px;
	min-width: 14rem;
	box-shadow: 0 0 10px #00000017;
	position: absolute;
	z-index: 9;
}

nav [data-level="1"] > a{
	font-size: 0.95em;
}

@media( max-width: 1024px ){
	button.mobile.nav-toggle{
		display: flex;
	}

	.navigation__container{
		--padding-block: 1rem;
		--padding-inline: 1.2rem;
		display: flex;
		flex-direction: column;
		align-items: initial;
		position: fixed;
		inset: var(--header-height) auto 0 0;
		background: #fff;
		height: 100%;
		width: min(70vw, 300px);
		translate: -100% 0;
		transition: translate 0.1s ease-out;
		gap: 0;
		z-index: 2;
	}
	.navigation__container[data-visible]{
		translate: 0 0;
	}

	nav.primary{
		overflow: hidden;
	}
	nav.primary > ul[class*="menu"]{
		padding: var(--padding-block) var(--padding-inline);
	}
	nav ul{
		flex-direction: column;
		gap: 1rem;
		position: relative;
	}
	nav li{
		position: initial;
	}

	/* --Level 1*/
	nav ul[data-slide]{
		translate: -100%;
	}
	nav [data-level="0"]{
		justify-content: space-between;
	}

	/* --Level 2*/
	nav ul.sub-menu{
		display: none;
		background: none;
		padding-inline: var(--padding-inline);
		min-width: initial;
		box-shadow: initial;
		gap: 1rem;
		top: 0;
		right: 0;
		translate: 100% 0;
	}
	div.open + ul.sub-menu{
		display: flex;
	}

	button.caret{
		display: grid;
		place-content: center;
		width: 30px;
		aspect-ratio: 1;
		font-size: 1rem;
		rotate: -90deg;
	}
	nav.primary:has(ul[data-slide]) button.mobile.slide-back{
		display: grid;
	}
	button.slide-back{
		place-content: center;
		width: 30px;
		aspect-ratio: 1;
		font-size: 1rem;
		margin: .5rem 0.6rem;
	}
	nav button:active{
		color: var(--primary);
	}

	nav.align-right{
		padding-inline: var(--padding-inline);
		margin-left: initial;
	}
	nav.primary:has( ul[data-slide] ) + nav.align-right{
		display: none;
	}

	#content::before{
		content: '';
		background: #00000020;
		inset: 0;
		position: fixed;
		backdrop-filter: blur(2px);
		display: none;
		z-index: 1;
	}
	header:has(
		.navigation__container[data-visible]
	) + #content::before{
		display: block;
	}
}