.dl-menuwrapper {
	width: 100%;
	max-width: 300px;
	float: right;
	position: relative;
	-webkit-perspective: 1000px;
	-moz-perspective: 1000px;
	perspective: 1000px;
	-webkit-perspective-origin: 50% 200%;
	-moz-perspective-origin: 50% 200%;
	perspective-origin: 50% 200%;
	z-index:99999;
	margin-top:40px;
}

.dl-menuwrapper:first-child {
	margin-right: 100px;
}

.dl-text {
	float:right;
	line-height:45px;
	cursor:pointer;
	padding:0 20px;
	color:#299926;
}

.dl-menuwrapper button {
	background:none;
	float: right;
	border: none;
	width: 48px;
	height: 45px;
	text-indent: -900em;
	overflow: hidden;
	position: relative;
	cursor: pointer;
	outline: none;
	background:#fff;
}

.dl-text.dl-active {
	background: #299926;
	color:#fff;
	border-right:1px solid #1a7217;
}


.dl-menuwrapper button:hover,
.dl-menuwrapper button.dl-active,
.dl-menuwrapper ul {
	background: #299926;
	color:#fff;
}

.dl-menuwrapper button:after {
	content: '';
	position: absolute;
	width: 68%;
	height: 5px;
	background: #299926;
	top: 10px;
	left: 16%;
	box-shadow: 
		0 10px 0 #299926, 
		0 20px 0 #299926;
}

.dl-menuwrapper button:hover:after, .dl-menuwrapper button.dl-active:after {
	background: #fff;
	box-shadow: 
		0 10px 0 #fff, 
		0 20px 0 #fff;
}

.dl-menuwrapper ul {
	padding: 0;
	list-style: none;
	-webkit-transform-style: preserve-3d;
	-moz-transform-style: preserve-3d;
	transform-style: preserve-3d;
}

.dl-menuwrapper li {
	position: relative;
}

.dl-menuwrapper li a {
	display: block;
	position: relative;
	padding: 10px 15px;
	font-size: 13px;
	line-height: 20px;
	font-weight: 300;
	color: #fff;
	outline: none;
}

.no-touch .dl-menuwrapper li a:hover {
	background: rgba(255,248,213,0.1);
}

.dl-menuwrapper li.dl-back > a {
	padding-left: 30px;
	background: rgba(0,0,0,0.1);
}

.dl-menuwrapper li > a:after {
	right: 10px;
	color: rgba(0,0,0,0.15);
}

.dl-menuwrapper .dl-menu {
	margin: 45px 0 0 0;
	position: absolute;
	width: 100%;
	opacity: 0;
	pointer-events: none;
	-webkit-transform: translateX(10px);
	-moz-transform: translateX(10px);
	transform: translateX(10px);
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	backface-visibility: hidden;
}

.dl-menuwrapper .dl-menu.dl-menu-toggle {
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

.dl-menuwrapper .dl-menu.dl-menuopen {
	opacity: 1;
	pointer-events: auto;
	-webkit-transform: translateX(0px);
	-moz-transform: translateX(0px);
	transform: translateX(0px);
}

/* Hide the inner submenus */
.dl-menuwrapper li .dl-submenu {
	display: none;
}

/* 
When a submenu is openend, we will hide all li siblings.
For that we give a class to the parent menu called "dl-subview".
We also hide the submenu link. 
The opened submenu will get the class "dl-subviewopen".
All this is done for any sub-level being entered.
*/
.dl-menu.dl-subview li,
.dl-menu.dl-subview li.dl-subviewopen > a,
.dl-menu.dl-subview li.dl-subview > a {
	display: none;
}

.dl-menu.dl-subview li.dl-subview,
.dl-menu.dl-subview li.dl-subview .dl-submenu,
.dl-menu.dl-subview li.dl-subviewopen,
.dl-menu.dl-subview li.dl-subviewopen > .dl-submenu,
.dl-menu.dl-subview li.dl-subviewopen > .dl-submenu > li {
	display: block;
}

/* Dynamically added submenu outside of the menu context */
.dl-menuwrapper > .dl-submenu {
	position: absolute;
	width: 100%;
	top: 50px;
	left: 0;
	margin: 0;
}

/* Animation classes for moving out and in */

.dl-menu.dl-animate-out-5 {
	-webkit-animation: MenuAnimOut5 0.3s ease;
	-moz-animation: MenuAnimOut5 0.3s ease;
	animation: MenuAnimOut5 0.3s ease;
}

@-webkit-keyframes MenuAnimOut5 {
	100% {
		-webkit-transform: translateX(20px);
		opacity: 1;
	}
}

@-moz-keyframes MenuAnimOut5 {
	100% {
		-moz-transform: translateX(20px);
		opacity: 1;
	}
}

@keyframes MenuAnimOut5 {
	100% {
		transform: translateX(20px);
		opacity: 1;
	}
}

.dl-menu.dl-animate-in-5 {
	-webkit-animation: MenuAnimIn5 0.3s ease;
	-moz-animation: MenuAnimIn5 0.3s ease;
	animation: MenuAnimIn5 0.3s ease;
}

@-webkit-keyframes MenuAnimIn5 {
	0% {
		-webkit-transform: translateX(20px);
		opacity: 0.7;
	}
	100% {
		-webkit-transform: translateX(0);
		opacity: 1;
	}
}

@-moz-keyframes MenuAnimIn5 {
	0% {
		-moz-transform: translateX(20px);
		opacity: 0.7;
	}
	100% {
		-moz-transform: translateX(0);
		opacity: 1;
	}
}

@keyframes MenuAnimIn5 {
	0% {
		transform: translateX(20px);
		opacity: 0.7;
	}
	100% {
		transform: translateX(0);
		opacity: 1;
	}
}

.dl-menuwrapper > .dl-submenu.dl-animate-in-5 {
	-webkit-animation: SubMenuAnimIn5 0.3s ease;
	-moz-animation: SubMenuAnimIn5 0.3s ease;
	animation: SubMenuAnimIn5 0.3s ease;
}

@-webkit-keyframes SubMenuAnimIn5 {
	0% {
		-webkit-transform: translateX(20px);
		opacity: 0.7;
	}
	100% {
		-webkit-transform: translateX(0);
		opacity: 1;
	}
}

@-moz-keyframes SubMenuAnimIn5 {
	0% {
		-moz-transform: translateX(20px);
		opacity: 0.7;
	}
	100% {
		-moz-transform: translateX(0);
		opacity: 1;
	}
}

@keyframes SubMenuAnimIn5 {
	0% {
		transform: translateX(20px);
		opacity: 0.7;
	}
	100% {
		transform: translateX(0);
		opacity: 1;
	}
}

.dl-menuwrapper > .dl-submenu.dl-animate-out-5 {
	-webkit-animation: SubMenuAnimOut5 0.3s ease;
	-moz-animation: SubMenuAnimOut5 0.3s ease;
	animation: SubMenuAnimOut5 0.3s ease;
}

@-webkit-keyframes SubMenuAnimOut5 {
	0% {
		-webkit-transform: translateX(0);
		opacity: 1;
	}
	100% {
		-webkit-transform: translateX(20px);
		opacity: 0.7;
	}
}

@-moz-keyframes SubMenuAnimOut5 {
	0% {
		-moz-transform: translateX(0);
		opacity: 1;
	}
	100% {
		-moz-transform: translateX(20px);
		opacity: 0.7;
	}
}

@keyframes SubMenuAnimOut5 {
	0% {
		transform: translateX(0);
		opacity: 1;
	}
	100% {
		transform: translateX(20px);
		opacity: 0.7;
	}
}

/* No JS Fallback */
.no-js .dl-menuwrapper .dl-menu {
	position: relative;
	opacity: 1;
	-webkit-transform: none;
	-moz-transform: none;
	transform: none;
}

.no-js .dl-menuwrapper li .dl-submenu {
	display: block;
}

.no-js .dl-menuwrapper li.dl-back {
	display: none;
}

.no-js .dl-menuwrapper li > a:not(:only-child) {
	background: rgba(0,0,0,0.1);
}

.no-js .dl-menuwrapper li > a:not(:only-child):after {
	content: '';
}
