.nav-open {
	display: none;
}

.nav-overlay {
	display: none;
} 

@media (max-width: 991px) { 

	/*******************************************
	:--- Mobile Navigation - Slide In ---:
	*******************************************/

	nav.site-nav,
	ul#menu-header,
	nav.site-nav ul {
		display: block;
	}

	html, body {
		height: 100%;
	}

	body.opened {
		overflow: hidden;
	}

	.nav-wrap {
		padding: 0 !important;
	}

	.nav-open {
        cursor: pointer;
        display: block;
        position: absolute;
        right: 0;
        top: calc(50% - 30px);
        z-index: 1000;
        padding: 20px;
	}

	.nav-open.opened {
		position: fixed;
        right: 1.25em;
		top: 30px;
		z-index: 10000;
		padding: 30px;
	}

	.nav-open.opened span:nth-child(1) {
		position: absolute;
		right: 0;
		top: 10px;
		transform: rotate(45deg);
	}

	.nav-open.opened span:nth-child(2) {
		position: absolute;
		right: 0;
		top: 10px;
		transform: rotate(-45deg);
	}

	.nav-open.opened span:nth-child(3) {
		display: none;
	}

	#wpadminbar {
		display: none;
	}

	.nav-open span {
		background: var(--primary-blue);
		content: " ";
		display: block;
		height: 3px;
		margin: 0 0 5px;
		width: 30px;
	}

	.nav-overlay {
		background: rgba(0,0,0,0.8);
		height: 100vh;
		left: 0;
		opacity: 0;
		position: fixed;
		top: 0;
		transition: opacity .4s ease-out;
		width: 100%;
		z-index: 8000;
	}

	.nav-overlay.opened {
		display: block;
		opacity: 1;
	}

	.site-nav-wrap {
		height: 100vh; 
		right: -100vw;	/* Left for slide in left / -100vw if full coverage required  */
		opacity: 0;
		position: fixed;
		top: 0;
		width: 100vw; /* 100vw if full coverage required */
		transition: right .4s ease-out, opacity .4s ease-out; /* Left for slide-in left / Remove if slide in isn't required */
		z-index: 9000;
	}

	.site-nav-wrap.opened {
		display: block;
		opacity: 1;
		right: 0; /* Change to left for slide in left */
	}

	/********************************************************************/
	/* Content Push - Include to also push the page content on slide in */
	/********************************************************************/

	.page-wrap {
		margin-left: 0;
		transition: .4s margin-left ease-out;
		width: 100%;
	}

	.opened .page-wrap {
		margin-left: -100vw;
		transition: .4s margin-left ease-out;
	}

	/********************/
	/* End Content Push */
	/********************/
	
	/* Nav items */

	nav.site-nav {
		margin: 54px 0 0;
	}

	nav.site-nav ul {

	}

	nav.site-nav ul .menu-item {
		float: none;
		padding-right: 0;
		margin-right: 0;
	}

	nav.site-nav ul .menu-item a {
		display: block;
		padding: 1rem 2rem;
		font-size: 1.25rem;
	}

	nav.site-nav ul>.menu-item span {
		font-size: 1.5rem;
		line-height: 1.5;
		display: block;
		position: relative;
		color: var(--primary-blue);
		text-decoration: none;
		max-width: 80%;
		-webkit-box-flex: 0;
		-ms-flex: 0 1 auto;
		flex: 0 1 auto;
	}

	nav.site-nav ul .menu-item a:hover,
	nav.site-nav ul .menu-item a:focus,
	nav.site-nav ul .menu-item a:active {
		text-decoration: none;
		color: var(--primary-yellow);
		background-color: transparent;
	}

	nav.site-nav .menu-item.dropdown:hover::after {
		background-color: transparent;
	}
	
	nav.site-nav .menu-item.dropdown:hover {
		background-color: transparent;
	}
	
	/* nav.site-nav .menu-item.dropdown:hover a {
		color: var(--primary-yellow);
	} */

	nav.site-nav ul>.menu-item span {
		cursor: pointer;
		display: block;
		padding: 0.5rem 1.5rem;
		position: absolute;
		right: 0;
		text-align: center;
		top: 0;
	}

	nav.site-nav ul>.menu-item span.closed:after {
		font-family: "Font Awesome 6 Pro";
		content: '\2b';
		font-size: 1.5rem;
		color: var(--primary-blue);
		text-align: center;
	}

	nav.site-nav ul>.menu-item span.opened:after {
		font-family: "Font Awesome 6 Pro";
		content: '\f068';
		font-size: 1.5rem;
		color: var(--primary-blue);
		text-align: center;
	}

	nav.site-nav ul.sub-menu {
		position: absolute;
		width: auto;
	}

	nav.site-nav #menu-item-1641 ul.sub-menu {
		column-count: 1;
	}

	nav.site-nav ul.sub-menu.sub-menu-open {
		display: block;
		left: auto;
		position: relative;
		background-color: #fff;
		padding: 0 40px;
	}

	nav.site-nav ul.sub-menu .menu-item {
		border-bottom: 0;
	}

	nav.site-nav ul.sub-menu .menu-item a {
		font-size: 1.125rem;
		display: block;
		position: relative;
		color: var(--primary-blue);
		text-decoration: none;
		padding: 2px 0 2px 15px;
	}

	nav.site-nav ul.sub-menu .menu-item.nav-menu-header a {
		color: var(--primary-blue) !important;
		font-size: 1.125rem;
	}

}