
/*** Menu ***/
nav.mnu, nav.mnu *, nav.mnu *:before, nav.mnu *:after {
    box-sizing: border-box;	/* !!!!!!!!!!! */
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    transition: none;
	-webkit-transition: none;
    -moz-transition: none;
    -ms-transition: none;
    -o-transition: none;
}

nav.mnu ul, nav.mnu ol {
	padding: 0;
	margin: 0;
}

nav.mnu, nav.mnu ul, nav.mnu ol {
    z-index: 999;
}

nav.mnu {
	display: block;
    position: relative;
    padding: 0;
}

/********** Sub Menu ************/

nav.mnu ul ul{
	visibility:hidden;
	opacity:0;
	position: absolute;
	max-height: 0px;
    transition: max-height 1.0s ease-in-out, opacity 1.0s step-end, visibility 1.0s step-end;
	-webkit-transition: max-height 1.0s ease-in-out, opacity 1.0s step-end, visibility 1.0s step-end;
    -moz-transition: max-height 1.0s ease-in-out, opacity 1.0s step-end, visibility 1.0s step-end;
    -ms-transition: max-height 1.0s ease-in-out, opacity 1.0s step-end, visibility 1.0s step-end;
    -o-transition: max-height 1.0s ease-in-out, opacity 1.0s step-end, visibility 1.0s step-end;
}

nav.mnu ul li:hover > ul{
	visibility:visible;
	opacity:1;
	max-height: 500px;
    transition: max-height 1.5s ease-in-out, opacity 1.5s step-start, visibility 1.5s step-start;
	-webkit-transition: max-height 1.5s ease-in-out, opacity 1.5s step-start, visibility 1.5s step-start;
    -moz-transition: max-height 1.5s ease-in-out, opacity 1.5s step-start, visibility 1.5s step-start;
    -ms-transition: max-height 1.5s ease-in-out, opacity 1.5s step-start, visibility 1.5s step-start;
    -o-transition: max-height 1.5s ease-in-out, opacity 1.5s step-start, visibility 1.5s step-start;
}

nav.mnu > ul > li > ul {
	left: 50%;
	top: calc(100% - 999px);
}

nav.mnu > ul > li > ul > ol {
    display: block;
    position: relative;
    width: calc(100% + 2px);
    height: calc(100% + 2px);
    left: calc(-50% - 1px);
    top: calc(999px + 25px - 1px);
}

nav.mnu > ul > li > ul > ol > li {
	left: 0%;
    top: calc(0px + 0px);
}
	

nav.mnu ul ul li, nav.mnu ul ul a {
	display: block;
	position: relative;
	white-space: nowrap; /* !!!!!!!!!! */
}

nav.mnu ul ul a {
	height: 40px;
	line-height: 40px;
	padding: 0px 25px;
	color: rgba(0,0,0,0.7);
	text-decoration: none;
	font-size: 16px;
}

nav.mnu ul ul li, nav.mnu ul ul a {
	transition: all .3s ease-in-out;
	-webkit-transition: all .3s ease-in-out;
    -moz-transition: all .3s ease-in-out;
    -ms-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
}


nav.mnu ul ul li:hover {
    background: #c22f28;
}


nav.mnu ul ul li > a:hover, nav.mnu ul ul li:hover > a {
	color: #FFFFFF;
}

nav.mnu .right + ul {
	top: 0;
	left: calc(100% + 4px);
}

nav.mnu .left + ul {
	top: 0;
	right: calc(100% + 4px);
}

nav.mnu > ul > li > ul > ol, nav.mnu ul ul {
	background: white;
    border: 1px solid white;
    box-shadow: 0px 0px 0px 1px black, 0px 0px 5px 0px rgba(0,0,0,0.5);
}



nav.mnu > ul > li > ul > ol, nav.mnu ul ul ul {
	overflow: hidden;
}

nav.mnu > ul > li > ul > ol {
	overflow: hidden;
}

nav.mnu > ul > li > ul > ol {
	max-height: 0px;
    transition: max-height 1.0s ease-in-out;
}

nav.mnu > ul > li:hover > ul > ol {
	max-height: 500px;
    transition: max-height 1.5s ease-in-out, overflow 1.5s step-end;
	-webkit-transition: max-height 1.5s ease-in-out, overflow 1.5s step-end;
    -moz-transition: max-height 1.5s ease-in-out, overflow 1.5s step-end;
    -ms-transition: max-height 1.5s ease-in-out, overflow 1.5s step-end;
    -o-transition: max-height 1.5s ease-in-out, overflow 1.5s step-end;
}

nav.mnu > ul > li > ul > ol:hover {
	overflow: visible;
}

/************ Arrow *************/

nav.mnu > ul > li > a.arrow:after {
	content: "";
    display: block;
    position: absolute;
    border: 6px solid transparent;
    border-top-color: inherit;
    z-index: 999;
    height: 0;
    width: 0;
    left: calc(50% - 6px);
    top: 80%;
}

nav.mnu a.arrow.right:after {
  content: "";
  display: block;
  position: absolute;
  height: 0;
  width: 0;
  top: calc(50% - 6px);
  right: 2%;
  border: 6px solid transparent;
  border-left-color: inherit;
}

nav.mnu a.arrow.left:after {
  content: "";
  display: block;
  position: absolute;
  height: 0;
  width: 0;
  top: calc(50% - 6px);
  right: 95%;
  border: 6px solid transparent;
  border-right-color: inherit;
}

/************ Transfer *************/

nav.mnu > ul > li > a.arrow:hover:before, nav.mnu > ul > li:hover > a.arrow:before {
	content: "";
    display: block;
    position: absolute;
	width: 100%;
	height: 100%;
	top: 100%;
	left: 0%;
}

nav.mnu li > a.arrow.right:hover:before, nav.mnu li:hover > a.arrow.right:before {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 5%;
}

nav.mnu li > a.arrow.left:hover:before, nav.mnu li:hover > a.arrow.left:before {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	right: 5%;
}

/*********** hidden ************/

.hidden-box {
	display: block;
	position: fixed;
	width: 100%;
	height: 1000px;/*100%;*/
	visibility: hidden;
	left: 0;
	z-index: 1;
	top: 0;
	margin-top: 135px;
}

nav.mnu:hover > .hidden-box {
	visibility: visible;
}


.hidden-box:hover {
	z-index: 10000!important;
	visibility: hidden!important;
	-webkit-transition: visibility .7s step-end;
	-moz-transition: visibility .7s step-end;
	-ms-transition: visibility .7s step-end;
	-o-transition: visibility .7s step-end;
	transition: visibility .7s step-end;
}

