.menu-toggle {
  display: none;
}

.main-navigation .sub-nav li
{ padding: 5px 5px 4px 3px; text-align: left}

.main-navigation > ul > li:hover .sub-nav {
  display: block;
}
.main-navigation > ul > li:hover .sub-nav li:hover {
  background: rgba(255,255,255,0.5);
}
.main-navigation .sub-nav {
  background: #346499;
  padding: 10px 15px;
  color: #fff;
  display: none;
  position: absolute;
  top: 100%;
  /*width: 100%!important;*/
  min-width: 100%!important;
  border-radius: 0 0 8px 8px
}

.main-navigation .sub-nav a { text-align: left; display: block; color: #fff; padding: 1%; font-size: 13px}
.main-navigation .sub-nav a:hover { color: #fff; border-bottom: none;}

@media only screen and (max-width: 768px) {
  .menu { background: rgba(52,100,153,0.9)!important }

  .menu h3 { background-color:#346499 }

  .menu-toggle {
    background: rgba(52,100,153,0.9);
    color: white;
    cursor: pointer;
    display: inline-block;
    position: fixed;
    top: 0;
    width: 100%;
    text-align: center;
    left: 0;
    font-weight: 400;
    padding: 9px 0;
    z-index: 99999;
  }

  .main-navigation .sub-nav a { text-align: center; }

  .main-menu {
    display: none; margin-top: 35px
  }

  .main-navigation .sub-nav {width: 94%!important;min-width: 94%!important; }

  .main-navigation {
    display: block;
  }
	
  .main-navigation .sub-nav li { padding: 5px 0;}
	
  .main-navigation > ul.open {
    display: inline-block;
	  overflow-y: scroll;
    height: 90vh;
	  padding: 0 0 30px;
  }
  .main-navigation > ul.open > li {
    display: block;
  }
  .main-navigation > ul.open > li .sub-nav {
    display: none;
    margin-top: 0.5em;
    position: relative;
    top: auto;
  }
}
