/* ++++++++++++++++++++1 create scrollable Overlay ++++++++++++++++++++++ */

/* no scroll for body */
body.mobileNavOpen
{
	overflow:hidden; /*prevent scrolling*/
	-webkit-overflow-scrolling:touch;
}

/* create Overlay */
.mobileNavOpen #nav,
.mobileNavOpen #main_menu ul.menu{
	height: 100vh;
   width: 100%;
   position: fixed; /* Stay in place */
   z-index: 2000; /* Sit on top */
   background-color: rgb(255,255,255); /* Black fallback color */
   background-color: rgba(255,255,255, 0.9); /* Black w/opacity */
   overflow-x: hidden; /* Disable horizontal scroll */
   transition: 0.5s; /* 0.5 second transition effect to slide in or slide down the overlay (height or width, depending on reveal) */
	padding-top:10vh;
	padding-bottom:10vh;
	margin-top:0;
	margin-bottom:0;
	overflow-y: scroll;
   top: 0; right: 0; bottom: 0; left: 0; 
}
/*create white space after menu for better scrolling */
.mobileNavOpen #nav:after,
.mobileNavOpen #main_menu ul.menu:after
{	
	content:"";
	clear:both;
	float:none;
	display:block;
	height:40px;
	background:none;
}

/* Hamburger Button */
.fa {
    font-weight: 900;
	 font-family: Font Awesome\ 5 Free;
}

.fa-bars:before {
	content:'\f0c9';
	font-size:30px;
}
#mobileNavButton {
	position:fixed;
	top:4px;
	right:6px;
	padding: 2px 15px 0px 15px;
	border-radius: 5px;
	border: 2px solid white;
	text-align: center;
	cursor: pointer;
	color: #fff;
	z-index:2000;
}

/* hide when the button is clicked */
.mobileNavOpen #mobileNavButton { display:none }

/* Close Button in the Overlay */
.mobileNavOpen #nav:before,
.mobileNavOpen #main_menu ul.menu:before{
	content: "Close";
	padding: 5px 10px;
	border-radius: 5px;
	border: 1px solid black;
	text-align: center;
	cursor: pointer;
	color: black;
	font-size: 1.5em;
	font-weight:bold;
	position:fixed;
	right:10vw;
	top:10px;
	z-index:10000;
	background:white;
}

/* Hide it from all views/devices for the time being */
.mobileNavButtonWrapper { float: right; display:none; }

/* ++++++++++++++++++++++ MOBILE NAVIGATION STYLES +++++++++++++++++++++++++ */

.mobileNavOpen #nav_menu ul.menu li,
.mobileNavOpen #main_menu ul.menu li
{
	display:block;
	width:96%;
	margin:10px 1%;
	height:auto;
}

.mobileNavOpen #main_menu ul.menu ul {
	visibility: visible;
 	top:0;
	position:relative;
}

.mobileNavOpen #nav_menu ul.menu ul li,
.mobileNavOpen #main_menu ul.menu ul li
{
	display:block;
	width:auto;
	margin:0px;
}
.mobileNavOpen #nav_menu .moduletable
{
	margin-bottom:40px;
}

/*++++++++++++++++++++++++++++ Accordion overlay +++++++++++++++++++++++++++++++++++++*/

.mobileNavOpen #main_menu ul.menu li.legal,
.mobileNavOpen #main_menu ul.menu li.home
{	
	display: block;
}

.mobileNavOpen #main_menu ul.menu li {
  -webkit-transition: all 0.25s ease;
  -o-transition: all 0.25s ease;
  transition: all 0.25s ease;
}

.mobileNavOpen #main_menu ul.menu li ul {
  display: none;
}

.mobileNavOpen #main_menu ul.menu li.active ul {
  display: block;
}

.mobileNavOpen #main_menu ul.menu > li.parent > a:after {
  content:'\F078';
  font-family:Font Awesome\ 5 Free;
  font-weight:900;
  position: absolute;
  right: 12px;
  left: auto;
  font-size: 16px;
  -webkit-transition: all 0.4s ease;
  -o-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
.mobileNavOpen #main_menu ul.menu > li.parent.open > a:after {
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  transform: rotate(180deg);
}
  



