/**
 * Core Navigation Block Styles
 *
 * Custom styles for WordPress core block (core/navigation).
 * Automatically enqueued via wp_enqueue_block_style().
 *
 * @package Smartfire
 */

.wp-block-navigation .wp-block-navigation-item__content {
	font-style: italic;
	font-weight: 800;
	font-size: 20px;
	text-transform: uppercase;
}

.wp-block-navigation__container {

	&::after {
		content: "";
		display: block;
		width: 100%;
		height: 1px;
		position: absolute;
		bottom: 0;
		left: 0;
		background: var(--wp--preset--color--primary-accent);
		transition: transform 0.4s ease;
		transform: scale(0, 1);
		transform-origin: right;
		border-radius: 9999px;
	}

	&:has([aria-expanded="true"])::after,
	&:has(.wp-block-ollie-mega-menu:hover)::after {
		transform: scale(1, 1);
		transform-origin: left;
	}
}

.wp-block-navigation
.wp-block-navigation-item:first-child
.wp-block-navigation-item__content {
	max-width: 170px;
	line-height: 20px;
}

.wp-block-navigation
.wp-block-navigation-item:first-child
.wp-block-navigation-item__content
span:nth-child(1) {
	max-width: 170px;
}

.wp-block-navigation .wp-block-navigation-item {
	padding-block: calc(0.6rem + 1px);

	&::after {
		content: "";
		display: block;
		width: 100%;
		height: 4px;
		position: absolute;
		top: calc(100% - 2px);
		left: 0;
		opacity: 0;
		background: var(--wp--preset--color--primary-alt);
		border-radius: 9999px;
		z-index: 1;
	}
}

.wp-block-navigation-item:has([aria-expanded="true"])::after,
.wp-block-navigation-item.wp-block-ollie-mega-menu:hover::after {
	opacity: 1;
}

/* Desktop Navigation
--------------------------------------------- */

.wp-block-navigation__container > .wp-block-navigation-item.wp-block-ollie-mega-menu {
	height: 61.19px;
}

.wp-block-navigation .has-child .wp-block-navigation__submenu-container {
	display: none;
}

.wp-block-navigation-submenu__toggle[aria-expanded="true"] ~ .wp-block-navigation-submenu,
.wp-block-navigation-submenu__toggle[aria-expanded="true"] ~ .wp-block-navigation__submenu-container {
	display: flex;
}

/* Drop nav */
.wp-block-navigation__responsive-container:not(.is-menu-open)
.wp-block-navigation__submenu-container {
	border: none !important;
	font-size: var(--wp--preset--font-size--small);
	line-height: var(--wp--custom--line-height--snug);
	min-width: 225px !important;
	margin-left: calc(var(--wp--preset--spacing--medium) * -1);
	padding: 0;
	z-index: 20 !important;
	border-radius: 5px;
	box-shadow: var(--wp--preset--shadow--small-light);
}

/* Drop nav submenu */
.wp-block-navigation__responsive-container:not(.is-menu-open)
.wp-block-navigation__submenu-container
.wp-block-navigation__submenu-container {
	margin-left: 0;
	top: 0 !important;
	left: 100%;
}

.wp-block-navigation__responsive-container:not(.is-menu-open)
:where(.wp-block-navigation__submenu-container)
li:first-child {
	padding-top: var(--wp--preset--spacing--small);
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
}

/* Add padding to bottom of drop menu */
.wp-block-navigation__responsive-container:not(.is-menu-open)
:where(.wp-block-navigation__submenu-container)
li:last-child {
	padding-bottom: var(--wp--preset--spacing--small);
	border-bottom-left-radius: 5px;
	border-bottom-right-radius: 5px;
}

/* Drop nav link padding */
.wp-block-navigation__responsive-container:not(.is-menu-open)
:where(.wp-block-navigation__submenu-container)
a,
.wp-block-navigation__responsive-container:not(.is-menu-open)
:where(.wp-block-navigation__submenu-container)
.wp-block-navigation-submenu__toggle {
	padding:
		var(--wp--preset--spacing--small)
		var(--wp--preset--spacing--medium) !important;
}

.wp-block-navigation__responsive-container:not(.is-menu-open)
.wp-block-navigation__container
.current-menu-item > a,
.wp-block-navigation__responsive-container:not(.is-menu-open)
.wp-block-navigation__container
.has-child
button:hover {
	text-decoration: underline;
}

/* Mobile Navigation
--------------------------------------------- */

.wp-block-navigation__responsive-container-content {
	padding-top: var(--wp--preset--spacing--xx-large) !important;
}

.wp-block-navigation__responsive-container.is-menu-open.has-modal-open {
	padding:
		var(--wp--preset--spacing--small)
		var(--wp--preset--spacing--medium);
}

.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-content {
	gap: var(--wp--preset--spacing--medium);
}

.wp-block-navigation__responsive-container.is-menu-open.has-modal-open
.wp-block-navigation__container {
	width: 100%;
	gap: 5px !important;
}

.wp-block-navigation__responsive-container.is-menu-open.has-modal-open
.wp-block-page-list {
	width: 100%;
}

.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-content
.has-child
.wp-block-navigation__submenu-container {
	border-radius: 0;
	margin: 0;
	padding: 5px 0 0 20px;
	align-items: flex-start;
	flex-direction: column;
	gap: 5px;
	width: 100%;
}

.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-content
.wp-block-navigation__submenu-icon {
	display: block;
	position: absolute;
	right: 0;
	top: 5px;
	height: auto;
	width: 60px;
	padding: 15px 0;
	margin: 0;
	z-index: 10;
}

.wp-block-navigation__responsive-container:not(.is-menu-open)
.has-child
.wp-block-navigation__submenu-container
.wp-block-navigation__submenu-icon {
	margin-right: var(--wp--preset--spacing--small);
}

body.rtl
.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-content
.wp-block-navigation__submenu-icon {
	left: 0;
	right: auto;
}

.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-content
.wp-block-navigation__submenu-icon
svg {
	height: 16px;
	margin: 0;
}

.wp-block-navigation__responsive-container.is-menu-open.has-modal-open
.wp-block-navigation__container
li:not(.wp-social-link) {
	width: 100%;
	padding: 0 0;
	position: relative;
}

/* Mobile menu links */
.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-content
.wp-block-navigation-item__content {
	width: 100%;
	font-size: var(--wp--preset--font-size--base);
	padding: 15px 60px 15px 15px;
	border-radius: 5px;
}

.wp-block-navigation > .wp-block-navigation-item > .wp-block-navigation-item__content:hover {
	text-decoration: none;
}

.wp-block-navigation__container
.wp-block-navigation-item:has(.wp-block-navigation__submenu-container:hover) > .wp-block-navigation-item__content {
	background: transparent;
}

.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__container
.current-menu-item > .wp-block-navigation-item__content {
	transition: 0.25s ease;
	text-decoration: none;
	background: color-mix(in srgb, currentcolor, transparent 97%);
	-webkit-tap-highlight-color: transparent;
}

body.rtl
.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-content
.wp-block-navigation-item__content {
	padding: 15px 15px 15px 60px;
}

.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__container
.wp-block-navigation-item:hover > .wp-block-navigation-item__content {
	transition: 0.25s ease;
	text-decoration: none;
	background: color-mix(in srgb, currentcolor, transparent 97%);
	-webkit-tap-highlight-color: transparent;
}

.wp-block-navigation__responsive-container-close {
	right: auto;
	left: 0;
}

/* Mobile menu open button */
.wp-block-navigation__responsive-container-close,
.wp-block-navigation__responsive-container-open {
	aspect-ratio: 1;
	padding: calc(0.6em + 1px);
	border: solid 2px var(--wp--preset--color--primary-accent);
	background-color: transparent;
	color: currentcolor;
	transition-duration: 0.25s;
	transition-timing-function: ease;

	&:hover {
		transform: scale(1.05);
	}

	&:active {
		transform: scale(0.97);
		box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
		transition-duration: 0.1s;
	}
}

.wp-block-navigation__responsive-container-close.liquid-glass,
.wp-block-navigation__responsive-container-open.liquid-glass {
	border: 2px solid transparent;
}

/* Custom theme */
.wp-block-navigation__responsive-container {
	margin-top: 0 !important;
}

.wp-block-navigation.has-mobile-menu {
	z-index: 1;
}

.wp-block-navigation.has-mobile-menu ~ * {
	position: relative;
	z-index: 1;
}

.wp-block-navigation__mobile-menu-content {
	padding-top: var(--wp--preset--spacing--medium) !important;
	border-top: solid 1px var(--wp--preset--color--primary-alt-accent);
}
