/* ── Primary Navigation ──────────────────────────────── */
.main-navigation > ul {
	display: flex;
	gap: var(--space-6);
	list-style: none;
	margin: 0;
	padding: 0;
}

.main-navigation a {
	font-size: 1rem;
	font-weight: 500;
	color: var(--color-heading);
	text-decoration: none;
	white-space: nowrap;
	transition: color 0.15s ease;
}

.main-navigation a:hover,
.main-navigation a:focus-visible {
	color: var(--color-primary);
}

.main-navigation > ul > .current-menu-item > a,
.main-navigation > ul > .current-menu-parent > a,
.main-navigation > ul > .current-menu-ancestor > a,
.main-navigation > ul > .current_page_item > a,
.main-navigation > ul > .current_page_parent > a,
.main-navigation > ul > .current_page_ancestor > a {
	font-weight: 700;
	color: var(--color-primary);
}

.main-navigation .sub-menu .current-menu-item > a,
.main-navigation .sub-menu .current-menu-parent > a,
.main-navigation .sub-menu .current-menu-ancestor > a,
.main-navigation .sub-menu .current_page_item > a,
.main-navigation .sub-menu .current_page_parent > a,
.main-navigation .sub-menu .current_page_ancestor > a {
	font-weight: 700;
	color: var(--color-primary);
}

/* ── Dropdown ────────────────────────────────────────── */
.main-navigation .menu-item-has-children {
	position: relative;
}
.main-navigation .menu-item-has-children:hover > a,
.main-navigation .menu-item-has-children:focus-within > a {
	color: var(--color-primary);
}

/* Chevron indicator */
.main-navigation .menu-item-has-children > a::after {
	content: '';
	display: inline-block;
	margin-left: 5px;
	width: 14px;
	height: 14px;
	background-color: var(--color-primary);
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6l6-6'/%3E%3C/svg%3E");
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6l6-6'/%3E%3C/svg%3E");
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	vertical-align: middle;
	transition: transform 0.2s ease;
}

.main-navigation .menu-item-has-children:hover > a::after,
.main-navigation .menu-item-has-children:focus-within > a::after {
	transform: rotate(180deg);
}

/* Dropdown panel */
.main-navigation .sub-menu {
	position: absolute;
	top: calc(100% + 10px);
	left: 0;
	background: var(--color-bg);
	border: none;
	border-radius: var(--radius-md);
	min-width: 210px;
	padding: var(--space-2) 0;
	list-style: none;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px);
	transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s linear 0.2s;
	z-index: 200;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.13);
}
.main-navigation .sub-menu:before {
	content: '';
	display: block;
	position: absolute;
	top: -10px;
	height:10px;
	width: 100%;
	background: transparent;
}

.main-navigation .menu-item-has-children:hover > .sub-menu,
.main-navigation .menu-item-has-children:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	transition: opacity 0.5s ease, max-height 0.5s ease, visibility 0s;
}

.main-navigation .sub-menu a {
	display: block;
	padding: var(--space-2) var(--space-5);
	font-size: 0.9rem;
	white-space: nowrap;
}

.main-navigation .sub-menu a:hover {
	/* background: var(--color-surface); */
	color: var(--color-primary);
}

.main-navigation .submenu-toggle {
	display: none;
}

@media ( min-width: 769px) and (max-width: 900px ) {
	#primary-menu > li:first-child {
		display: none; /* hide home on smaller screens */
	}
}

/* ── Mobile navigation ───────────────────────────────── */
@media ( max-width: 768px ) {
	.main-navigation {
		width: 100%;
	}

	.main-navigation > ul {
		flex-direction: column;
		gap: 0;
	}

	.main-navigation > ul > li > a {
		display: block;
		padding: var(--space-2) 0;
		/* border-bottom: 1px solid var(--color-border); */
		font-size: 1.1rem;
		font-weight: 500;
	}

	.main-navigation .menu-item-has-children > a {
		display: flex;
		align-items: center;
		gap: var(--space-2);
	}

	.main-navigation .menu-item-has-children {
		display: grid;
		grid-template-columns: 1fr auto;
		align-items: center;
		column-gap: var(--space-2);
	}

	.main-navigation .menu-item-has-children > a {
		min-width: 0;
	}

	.main-navigation .menu-item-has-children > a::after {
		display: none;
	}

	.main-navigation .submenu-toggle {
		width: 32px;
		height: 32px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		border: 0;
		padding: 0;
		margin: 0;
		background: transparent;
		color: var(--color-primary);
		cursor: pointer;
		transition: background-color 0.2s ease;
		border: 1px solid var(--color-border);
	}
	.main-navigation .submenu-toggle:hover {
		transform: unset;
	}

	.main-navigation .submenu-toggle::before {
		content: '';
		display: block;
		width: 14px;
		height: 14px;
		background-color: currentColor;
		-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6l6-6'/%3E%3C/svg%3E");
		-webkit-mask-repeat: no-repeat;
		-webkit-mask-position: center;
		-webkit-mask-size: contain;
		mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6l6-6'/%3E%3C/svg%3E");
		mask-repeat: no-repeat;
		mask-position: center;
		mask-size: contain;
		transition: transform 0.2s ease;
	}

	.main-navigation .submenu-toggle:hover,
	.main-navigation .submenu-toggle:focus-visible {
		border-color: var(--color-primary);
		outline: 1px solid var(--color-primary)
	}

	.main-navigation .sub-menu {
		grid-column: 1 / -1;
		position: static;
		opacity: 0;
		visibility: hidden;
		transform: none;
		box-shadow: none;
		border: none;
		border-radius: 0;
		padding: 0 0 0 var(--space-4);
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
		border-left: 2px solid var(--color-primary);
		/* margin-bottom: var(--space-3); */
	}

	.main-navigation .sub-menu:before {
		content: unset;
	}

	.main-navigation .menu-item-has-children.is-expanded > .sub-menu {
		opacity: 1;
		visibility: visible;
		margin-bottom: var(--space-3);
	}

	.main-navigation .sub-menu a {
		padding: var(--space-2) 0;
		font-size: 1rem;
		/* border-bottom: 1px solid var(--color-border); */
	}

	.main-navigation .menu-item-has-children.is-expanded > .submenu-toggle::before {
		transform: rotate(180deg);
	}
}