#nav-panel,
#side-nav-panel {
	box-sizing: border-box;
}

:where(#nav-panel.wpei-orion-mobile-nav-panel, #side-nav-panel.wpei-orion-mobile-side-panel) :where(.mobile-menu, .accordion-menu) a {
	font-family: var(--wpei-orion-mobile-menu-font-family, inherit);
	font-size: var(--wpei-orion-mobile-menu-font-size, 14px);
	font-weight: var(--wpei-orion-mobile-menu-font-weight, 500);
	text-transform: var(--wpei-orion-mobile-menu-text-transform, uppercase);
	line-height: var(--wpei-orion-mobile-menu-line-height, 1.4);
	letter-spacing: var(--wpei-orion-mobile-menu-letter-spacing, 0.04em);
}

#nav-panel.wpei-orion-mobile-nav-panel {
	display: none;
	position: absolute;
	top: 100%;
	right: 0;
	left: 0;
	z-index: 10020;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	background: var(--wpei-orion-mobile-nav-panel-shell-bg, transparent);
	color: inherit;
	font-size: 0.9em;
	padding-bottom: 15px;
	transition: transform 0.2s ease-in-out;
}

#nav-panel.wpei-orion-mobile-nav-panel.is-open {
	display: block;
}

#nav-panel.wpei-orion-mobile-nav-panel > .container {
	display: block !important;
	box-sizing: border-box;
	width: 100%;
	max-width: var(--wpei-orion-mobile-nav-panel-max-width, 1140px);
	margin-right: auto;
	margin-left: auto;
	padding-right: var(--wpei-orion-mobile-nav-panel-gutter, 20px);
	padding-left: var(--wpei-orion-mobile-nav-panel-gutter, 20px);
}

#nav-panel.wpei-orion-mobile-nav-panel > .container > div {
	display: block !important;
}

#nav-panel.wpei-orion-mobile-nav-panel .mobile-nav-wrap {
	--wpei-orion-mobile-nav-panel-bg: #fff;
	--wpei-orion-mobile-nav-panel-text-color: #333;
	--wpei-orion-mobile-nav-panel-border-color: #e8e8e8;
	--wpei-orion-mobile-nav-panel-hover-bg: rgba(0, 0, 0, 0.03);
	--wpei-orion-mobile-nav-panel-active-bg: var(--wpei-orion-mobile-nav-panel-accent-color, var(--porto-primary-color, #e8b8ae));
	--wpei-orion-mobile-nav-panel-active-color: #fff;

	padding: 0 !important;
	min-height: 6rem;
	max-height: 50vh;
	overflow-x: hidden;
	overflow-y: auto;
	background: var(--wpei-orion-mobile-nav-panel-bg);
	color: var(--wpei-orion-mobile-nav-panel-text-color);
	border-top: 1px solid var(--wpei-orion-mobile-nav-panel-border-color);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
	transition: max-height 1.2s;
	-webkit-overflow-scrolling: touch;
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu {
	display: block;
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 0.8571em;
}

#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu {
	font-size: 1em;
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu li.menu-item {
	position: relative;
	margin: 0;
	padding-top: 1px;
	padding-bottom: 1px;
	list-style: none;
	border-bottom: 1px solid var(--wpei-orion-mobile-nav-panel-border-color);
}

#nav-panel.wpei-orion-mobile-nav-panel .menu-wrap:last-child .accordion-menu:last-child li:last-child,
#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu li li:last-child {
	border-bottom: 0;
}

#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a {
	position: relative;
	display: block;
	outline: medium none;
	text-decoration: none;
	text-align: center;
	margin: 1px 0 0;
	padding: 5px 6px;
	transition: color 0.2s ease, background-color 0.2s ease;
	color: inherit;
}

#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item.has-sub > a {
	padding-right: 33px;
}

#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a > i,
#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a > svg {
	width: 18px;
	text-align: center;
}

#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a > svg {
	fill: currentColor;
	stroke: currentColor;
}

#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a > i,
#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a > .avatar,
#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a > svg,
#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a > img {
	margin-right: 5px;
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu li > a {
	margin-top: 0;
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu .arrow {
	position: absolute;
	right: 5px;
	top: 0;
	z-index: 10;
	display: block;
	width: 30px;
	height: 35px;
	background: none !important;
	color: inherit;
	cursor: pointer;
	line-height: 35px;
	text-align: center;
	transition: color 0.2s ease, background-color 0.2s ease;
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu .arrow::before {
	content: "\e81c";
	font-family: "porto", sans-serif;
	font-size: 18px;
	line-height: 1;
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu .open > .arrow::before {
	content: "\e81c";
	font-family: "porto", sans-serif;
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu .sub-menu {
	display: none;
	margin: 0 0 0 20px;
	padding: 0;
	list-style: none;
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu .sub-menu li:not(.active):hover > a {
	background: var(--wpei-orion-mobile-nav-panel-hover-bg);
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu li.menu-item:hover > a,
#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu .arrow:hover {
	color: var(--wpei-orion-mobile-nav-panel-hover-color, currentColor);
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu li.menu-item.active > a,
#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu li.menu-item.active > .arrow {
	color: var(--wpei-orion-mobile-nav-panel-active-color);
}

#nav-panel.wpei-orion-mobile-nav-panel .accordion-menu > li.menu-item.active > a {
	background: var(--wpei-orion-mobile-nav-panel-active-bg);
}

#nav-panel.wpei-orion-mobile-nav-panel .menu-custom-block {
	margin: 15px 0;
}

#nav-panel.wpei-orion-mobile-nav-panel .menu-custom-block a,
#nav-panel.wpei-orion-mobile-nav-panel .menu-custom-block span {
	display: block;
}

#nav-panel.wpei-orion-mobile-nav-panel .menu-custom-block a {
	padding: 5px 6px;
	color: inherit;
	text-decoration: none;
}

#side-nav-panel.wpei-orion-mobile-side-panel {
	position: fixed;
	top: 0;
	bottom: 0;
	z-index: 9001;
	width: var(--wpei-orion-mobile-panel-width, 290px);
	max-width: min(100vw, var(--wpei-orion-mobile-panel-width, 290px));
	background-color: #1d1e20;
	color: #fff;
	overflow-y: auto;
	visibility: hidden;
	transition: transform 0.3s, visibility 0.3s;
	-webkit-overflow-scrolling: touch;
}

#side-nav-panel.panel-left,
#side-nav-panel.wpei-orion-mobile-side-panel--left {
	left: 0;
	right: auto;
	transform: translateX(calc(-1 * var(--wpei-orion-mobile-panel-width, 290px)));
}

#side-nav-panel.panel-right,
#side-nav-panel.wpei-orion-mobile-side-panel--right {
	right: 0;
	left: auto;
	transform: translateX(var(--wpei-orion-mobile-panel-width, 290px));
}

html.panel-opened #side-nav-panel,
#side-nav-panel.wpei-orion-mobile-side-panel.is-open {
	transform: translateX(0);
	visibility: visible;
}

html.panel-opened body > * {
	z-index: 0;
}

.panel-overlay {
	opacity: 0;
}

.panel-overlay.active {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 8999;
	min-height: 100vh;
	background: #000;
	opacity: 0.35;
	transition: opacity 0.2s;
}

.wpei-orion-mobile-panel-open {
	overflow: hidden;
}

.side-nav-panel-close {
	position: fixed;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s, visibility 0.3s;
}

html.panel-opened .side-nav-panel-close {
	display: block;
	top: 10px;
	right: 14.5px;
	z-index: 9999 !important;
	padding: 4px 8px;
	color: #fff;
	line-height: 1;
	text-decoration: none;
	opacity: 1;
	visibility: visible;
}

#side-nav-panel > .menu-wrap,
#side-nav-panel .mobile-nav-wrap > .menu-wrap {
	padding-top: 20px;
}

#side-nav-panel .accordion-menu {
	font-size: 1em;
}

#side-nav-panel .mobile-menu {
	font-size: 1em;
}

#side-nav-panel .accordion-menu > li.menu-item a {
	padding: 14px 43px 14px 16px;
}

#side-nav-panel .accordion-menu li.menu-item.has-sub > a {
	padding-right: 43px;
}

#side-nav-panel .accordion-menu li:not(:last-child) {
	border-bottom: 1px solid #242527;
}

#side-nav-panel .accordion-menu .arrow {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 10;
	display: block;
	width: 43px;
	height: 53px;
	background: none !important;
	cursor: pointer;
	font-family: "porto", sans-serif;
	font-size: 15px;
	line-height: 53px;
	text-align: center;
	vertical-align: top;
}

#side-nav-panel .accordion-menu .arrow::before {
	content: "\e81c";
}

#side-nav-panel .accordion-menu .open > .arrow::before {
	content: "\e81b";
}

#side-nav-panel .menu-empty {
	padding: 20px 10px;
}

.mobile-nav-wrap {
	width: 100%;
}

.mobile-nav-wrap .menu-wrap {
	width: 100%;
}

.mobile-menu.accordion-menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mobile-menu.accordion-menu .menu-item {
	position: relative;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mobile-menu.accordion-menu a {
	display: block;
	padding: 12px 44px 12px 16px;
	color: inherit;
	text-decoration: none;
}

.mobile-menu.accordion-menu .arrow {
	position: absolute;
	right: 5px;
	z-index: 10;
	display: block;
	width: 30px;
	background: none !important;
	cursor: pointer;
	color: inherit;
	text-align: center;
	vertical-align: top;
	transition: color 0.2s ease, background-color 0.2s ease;
}

.mobile-menu.accordion-menu .arrow::before {
	content: "\e81c";
	font-family: "porto", sans-serif;
	font-size: 18px;
	line-height: 1;
}

.mobile-menu.accordion-menu .open > .arrow::before {
	content: "\e81c";
	font-family: "porto", sans-serif;
}

.mobile-menu.accordion-menu .sub-menu {
	display: none;
	list-style: none;
	margin: 0;
	padding: 0 0 0 16px;
}

.menu-empty {
	padding: 16px;
	font-size: 14px;
}

/* ── Customizer color variables ─────────────────────────────────────────────
 * Bridge global --wpei-orion-mobile-panel-* variables (set on :root from PHP)
 * into the panel-specific internal variables and direct color rules.
 * Rules appear after the defaults above so same-specificity cascade wins.
 * ────────────────────────────────────────────────────────────────────────── */

/* nav-panel: override internal variables so all existing rules pick them up */
#nav-panel.wpei-orion-mobile-nav-panel .mobile-nav-wrap {
	--wpei-orion-mobile-nav-panel-bg:           var(--wpei-orion-mobile-panel-bg);
	--wpei-orion-mobile-nav-panel-text-color:   var(--wpei-orion-mobile-panel-text);
	--wpei-orion-mobile-nav-panel-border-color: var(--wpei-orion-mobile-panel-border);
	--wpei-orion-mobile-nav-panel-hover-bg:     var(--wpei-orion-mobile-panel-hover-bg);
	--wpei-orion-mobile-nav-panel-hover-color:  var(--wpei-orion-mobile-panel-link-hover);
	--wpei-orion-mobile-nav-panel-active-bg:    var(--wpei-orion-mobile-panel-hover-bg);
	--wpei-orion-mobile-nav-panel-active-color: var(--wpei-orion-mobile-panel-link-hover);
}

/* nav-panel: explicit link color (overrides color:inherit) */
#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item > a {
	color: var(--wpei-orion-mobile-panel-link);
}

/* nav-panel: hover + active */
#nav-panel.wpei-orion-mobile-nav-panel .mobile-menu.accordion-menu li.menu-item.active > a {
	color: var(--wpei-orion-mobile-panel-link-hover);
}

/* side-panel: background + base text */
#side-nav-panel.wpei-orion-mobile-side-panel {
	background-color: var(--wpei-orion-mobile-panel-bg);
	color: var(--wpei-orion-mobile-panel-text);
}

/* side-panel: link base color */
#side-nav-panel .accordion-menu a {
	color: var(--wpei-orion-mobile-panel-link);
}

/* side-panel: hover + active */
#side-nav-panel .accordion-menu li.menu-item:hover > a,
#side-nav-panel .accordion-menu li.menu-item.active > a {
	background: var(--wpei-orion-mobile-panel-hover-bg);
	color: var(--wpei-orion-mobile-panel-link-hover);
}

/* side-panel: border between items */
#side-nav-panel .accordion-menu li:not(:last-child) {
	border-bottom-color: var(--wpei-orion-mobile-panel-border);
}
