/**
 * Mobile slide-out navigation (≤767px) — toggle left of logo, panel slides from left.
 */

@media screen and (max-width: 1024px) {
	/* Header: hamburger | logo */
	.header .container.spr-header-container,
	.header .container {
		display: grid;
		grid-template-columns: auto 1fr;
		grid-template-areas:
			"nav logo"
			"extras extras";
		align-items: center;
		column-gap: 12px;
		padding-left: 12px;
		padding-right: 12px;
	}

	.header .heder-rightside {
		display: contents;
	}

	.header #navigation {
		grid-area: nav;
		width: auto !important;
		max-width: none !important;
		float: none !important;
		text-align: left;
		padding-top: 0 !important;
	}

	.header .logo {
		grid-area: logo;
		float: none !important;
		width: auto !important;
		max-width: 100%;
		min-width: 0;
		text-align: left;
		padding: 10px 0 !important;
		margin: 0;
	}

	.header .header-right-infos {
		grid-area: extras;
		width: 100%;
		margin-top: 0 !important;
	}

	.header .main-navigation,
	.header .main-navigation.toggled {
		width: auto !important;
		display: block !important;
		position: static !important;
		box-shadow: none !important;
		background: transparent !important;
	}

	.header #navigation {
		text-align: left !important;
	}

	.header .main-navigation.toggled ul li {
		background-color: #bce8ff !important;
	}

	/* Hamburger: white border + bars, rounded corners */
	.header .main-navigation button.menu-toggle,
	.header .main-navigation.toggled button.menu-toggle {
		position: relative;
		display: block;
		width: 44px;
		height: 44px;
		margin: 0 0 0 10px !important;
		padding: 0 !important;
		top: auto !important;
		left: auto !important;
		right: auto !important;
		float: none !important;
		text-align: center !important;
		background: transparent !important;
		border: 2px solid #fff !important;
		border-radius: 10px !important;
		box-shadow: none !important;
		box-sizing: border-box;
		z-index: 100002;
	}

	.header .main-navigation button.menu-toggle:hover,
	.header .main-navigation button.menu-toggle:focus {
		background: rgba(255, 255, 255, 0.12) !important;
		border-color: #fff !important;
		outline: none !important;
		box-shadow: none !important;
	}

	.header .main-navigation button.menu-toggle span {
		display: block;
		position: absolute;
		left: 50% !important;
		width: 24px;
		height: 3px;
		margin: 0 !important;
		background: #fff !important;
		border: none !important;
		transform: translateX(-50%);
		transition: transform 0.25s ease, opacity 0.25s ease, top 0.25s ease;
	}

	.header .main-navigation button.menu-toggle span:nth-of-type(1) {
		top: 13px;
	}

	.header .main-navigation button.menu-toggle span:nth-of-type(2) {
		top: 20px;
	}

	.header .main-navigation button.menu-toggle span:nth-of-type(3) {
		top: 27px;
	}

	.header .main-navigation.toggled button.menu-toggle span:nth-of-type(1) {
		top: 20px;
		transform: translateX(-50%) rotate(45deg);
	}

	.header .main-navigation.toggled button.menu-toggle span:nth-of-type(2) {
		opacity: 0;
		transform: translateX(-50%);
	}

	.header .main-navigation.toggled button.menu-toggle span:nth-of-type(3) {
		top: 20px;
		transform: translateX(-50%) rotate(-45deg);
	}

	/* Slide-in panel (override parent .toggled ul li { background:#111 }) */
	.header .main-navigation > ul#primary-menu,
	.header .main-navigation.toggled > ul#primary-menu {
		background: #fff !important;
		color: #333 !important;
	}

	.header .main-navigation > ul#primary-menu {
		-webkit-tap-highlight-color: transparent;
		position: fixed !important;
		top: 0 !important;
		left: 0 !important;
		right: auto !important;
		bottom: 0 !important;
		width: min(320px, 88vw) !important;
		max-width: none !important;
		height: 100vh !important;
		height: 100dvh !important;
		margin: 0 !important;
		padding: 72px 0 24px !important;
		overflow-x: hidden;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		z-index: 100001;
		transform: translateX(-100%);
		transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
		display: block !important;
		box-shadow: 4px 0 24px rgba(0, 0, 0, 0.15);
	}

	.header .main-navigation:not(.toggled) > ul#primary-menu {
		pointer-events: none;
		visibility: hidden;
	}

	.header .main-navigation.toggled > ul#primary-menu {
		visibility: visible;
		transform: translateX(0);
		pointer-events: auto;
	}

	.header .main-navigation.toggled > ul#primary-menu > li,
	.header .main-navigation.toggled ul.sub-menu li {
		width: 100% !important;
		float: none !important;
		display: block !important;
		background-color: #fff !important;
	}

	.header .main-navigation.toggled ul.sub-menu li a {
		color: #333 !important;
	}

	/* Submenus: collapsed by default; parent theme forces display:block + hover/focus open */
	.header .main-navigation.toggled ul ul,
	.header .main-navigation.toggled ul ul ul,
	.header .main-navigation.toggled ul.sub-menu {
		position: relative !important;
		top: auto !important;
		left: 0 !important;
		width: 100% !important;
		float: none !important;
		transform: none !important;
		display: none !important;
		opacity: 1 !important;
		height: auto !important;
		min-width: 0 !important;
		box-shadow: none !important;
		margin: 0 !important;
		padding: 0 !important;
		border-left: 3px solid #14a4e2;
		background: #f8f9fa !important;
		overflow: hidden;
	}

	.header .main-navigation.toggled li:hover > ul,
	.header .main-navigation.toggled li:focus > ul,
	.header .main-navigation.toggled li.focus > ul,
	.header .main-navigation.toggled li:hover > ul ul,
	.header .main-navigation.toggled li:focus > ul ul,
	.header .main-navigation.toggled li.focus > ul ul {
		display: none !important;
	}

	.header .main-navigation.toggled li.spr-submenu-open > ul,
	.header .main-navigation.toggled li.spr-submenu-open > ul.sub-menu {
		display: block !important;
		visibility: visible !important;
	}

	.header .main-navigation.toggled ul li a {
		padding: 14px 20px !important;
		color: #333 !important;
		background-color: transparent !important;
	}

	/* No light-blue highlight on tap/hover/focus in slide menu */
	.header .main-navigation.toggled ul li a:hover,
	.header .main-navigation.toggled ul li a:focus,
	.header .main-navigation.toggled ul li a:active,
	.header .main-navigation.toggled li.spr-submenu-open > a,
	.header .main-navigation.toggled li.spr-has-submenu > a:hover,
	.header .main-navigation.toggled li.spr-has-submenu > a:focus,
	.header .main-navigation.toggled li.spr-has-submenu > a:active {
		color: #333 !important;
		background-color: transparent !important;
		text-decoration: none !important;
	}

	.header .main-navigation.toggled ul li.current-menu-item > a,
	.header .main-navigation.toggled ul li.current_page_item > a {
		color: #333 !important;
		background-color: transparent !important;
	}

	.header .main-navigation li.spr-has-submenu {
		position: relative;
	}

	.header .main-navigation li.spr-has-submenu > a {
		display: block;
		padding-right: 52px !important;
		cursor: pointer;
	}

	/* Hide theme dropdown arrow; use our toggle button */
	.header .main-navigation li.spr-has-submenu > a:after {
		display: none !important;
	}

	.header .main-navigation .spr-submenu-toggle {
		position: absolute;
		top: 0;
		right: 0;
		z-index: 2;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 48px;
		height: 48px;
		max-height: 48px;
		margin: 0;
		padding: 0;
		border: 0;
		border-left: 1px solid #e8e8e8;
		background: transparent;
		color: #333;
		font-family: inherit;
		font-size: 26px;
		font-weight: 300;
		line-height: 1;
		cursor: pointer;
		-webkit-appearance: none;
		appearance: none;
		-webkit-tap-highlight-color: transparent;
	}

	.header .main-navigation .spr-submenu-toggle::before {
		display: none !important;
		content: none !important;
	}

	.header .main-navigation .spr-submenu-toggle:hover,
	.header .main-navigation .spr-submenu-toggle:focus,
	.header .main-navigation .spr-submenu-toggle:active {
		background: transparent !important;
		color: #333 !important;
		outline: none;
	}

	/* Tablet 768–1024: full-width menu panel; keep toggle on the left */
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		.header .heder-rightside {
			width: auto !important;
			float: none !important;
			text-align: left !important;
		}

		.header #navigation {
			width: auto !important;
			float: none !important;
			padding-top: 0 !important;
		}

		.header .main-navigation > ul#primary-menu,
		.header .main-navigation > ul#primary,
		.header .main-navigation > ul.primary-menu {
			width: 100% !important;
			max-width: none !important;
			left: 0 !important;
			right: 0 !important;
			box-shadow: none !important;
		}
	}
}

/* Dim page behind slide menu; keep header + panel above overlay (header was z-index 999) */
.spr-nav-overlay {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 10050;
	margin: 0;
	padding: 0;
	border: 0;
	background: rgba(0, 0, 0, 0.45);
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
}

body.spr-nav-open {
	overflow: hidden;
}

body.spr-nav-open .spr-nav-overlay {
	display: block;
}

body.spr-nav-open .header {
	position: relative;
	z-index: 10060 !important;
}

body.spr-nav-open .top_line {
	z-index: 10060;
}

/* Never apply mobile menu UI on desktop/tablet */
@media screen and (min-width: 1024px) {
	.spr-nav-overlay {
		display: none !important;
	}

	body.spr-nav-open {
		overflow: auto;
	}

	.header .main-navigation .spr-submenu-toggle {
		display: none !important;
	}
}
