.nav-panel {
    box-shadow: 0.2rem 0 2rem 0.5rem var(--region);
    box-sizing: border-box;
    background-color: var(--bg);
	display: flex;
	align-items: center;
}

@media only screen and (max-width: 720px) {
	.nav-panel {
		box-shadow: 0 0.2rem 2rem 0.5rem var(--region);
	}
}

.nav-panel .home {
	color: var(--text2);
	font-weight: bold;
	text-decoration: none;
	font-size: 1.25rem;
	padding: 0.5rem 1rem;
}

.nav-panel .spacer {
	flex-grow: 1;
}

.nav-panel .theme-toggle {
	width: 2em;
	height: 1em;
	border-radius: 0.5em;
	background-color: var(--opp);
	cursor: pointer;
	margin: 0.5em 1em;
	position: relative;
	transition: all 0.2s;
}

.nav-panel .theme-toggle::after {
	display: block;
	content: "";
	--factor: 0.8;
	width: calc(var(--factor) * 1em);
	height: calc(var(--factor) * 1em);
	border-radius: calc(var(--factor) * 0.5em);
	position: absolute;
	top: 50%;
	right: calc(50% * (1 + (1 - var(--factor)) / 2));
	background-color: var(--bg);
	transition: all 0.2s;
	transform: translate(calc(var(--side) * 1em), -50%);
}

.light .nav-panel .theme-toggle::after {
	--side: 0;
}
.dark .nav-panel .theme-toggle::after {
	--side: 1;
}
