.flexnav .touch-button {
	display: inline-block;
}
.nav .container {
	width: 100%;
	padding: 0px 0px
}
.flexnav .touch-button {
	position: absolute;
	z-index: 999;
	top: 0;
	right: 0;
	display: inline-block;
	text-align: center;
	padding: 15px;
	cursor: pointer
}
.flexnav ul .touch-button {
	padding: 11px 11px;
}
.flexnav .touch-button:hover {
	cursor: pointer;
}
.flexnav .touch-button .navicon {
	position: relative;
	font-size: 12px;
	color: #4c4c4c;
}
.menu-button {
	position: relative;
	display: block;
	float: right;
	text-decoration: none;
	color: #000;
	background-color: #ffffff;
	text-align: center;
	cursor: pointer;
	width: 50px;
	height: 50px;
	background-image: url(../img/menu.png);
	background-position: center center;
	background-repeat: no-repeat;
	z-index: 99;
	right: 0px;
}
.menu-button.one-page {
	position: fixed;
	top: 0;
	right: 5%;
	padding-right: 45px;
}
.menu-button .touch-button {
	background: transparent;
	position: absolute;
	z-index: 999;
	top: 0;
	right: 0;
	width: 50px;
	height: 50px;
	text-align: center;
	display: none
}
/*.menu-button .touch-button .navicon {
	font-size: 16px;
	position: relative;
	top: 1em;
	color: #4c4c4c;
}*/


.flexnav li {
	padding: 0px
}
.flexnav li a {
	padding: 0px 20px 5px 20px;
}
.nav {
	width: 100%;
	clear: both;
	border: none;
	height: auto;
	position: relative;
	z-index: 9999;
}
.flexnav li:hover .touch-button .navicon {
	color: black;
}
.flexnav li:hover li a, .flexnav li:hover li li a {
	background: #f1f1f1;
	color: #333;
}
/* Flexnav Base Styles */

.menuflex {
	z-index: 99;
	position: absolute;
	top: 0px;
	float: left;
	height: 50px;
	width: 100%;
	padding: 0px;
	background: white;
	overflow: hidden;
}
.flexnav {
	-webkit-transition: none;
	-moz-transition: none;
	-ms-transition: none;
	transition: none;
	-webkit-transform-style: preserve-3d;
	overflow: hidden;
	margin: 0 auto;
	width: 100%;
	max-height: 0;
}
.flexnav li {
}
.flexnav.opacity {
	opacity: 0;
}
.flexnav.flexnav-show {
	max-height: 2000px;
	opacity: 1;
	-webkit-transition: all .5s ease-in-out;
	-moz-transition: all .5s ease-in-out;
	-ms-transition: all .5s ease-in-out;
	transition: all .5s ease-in-out;
	border-top: 1px solid #ccc;
}
.flexnav.one-page {
	position: fixed;
	top: 52px;
	right: 5%;
}
.flexnav li {
	font-size: 100%;
	position: relative;
	overflow: hidden;
	margin-bottom: 0px;/*padding: 0px 10px;*/
}
.flexnav li a, .flexnav li a:hover {
	text-decoration: none
}
.flexnav li a {
	position: relative;
	display: block;
	z-index: 2;
	color: #4c4c4c;
	text-decoration: none;
	margin: 0px;/*per responsive*/
	font-size: 20px;
	background: white;
	border-bottom: 1px solid #ccc;
	font-weight: 400;
	padding: 10px 20px;
}
.flexnav li ul {
	width: 100%;
}
.flexnav li ul li {
	font-size: 100%;
	position: relative;
	overflow: hidden;
}
.flexnav li ul.flexnav-show li {
	overflow: visible;
}
.flexnav li ul li a {
	display: block;
	text-decoration: none;
	font-size: 15px;
	line-height: 16px;
	padding: 10px 20px;
	color: #666;
}
.flexnav li {
	display: block
}
.flexnav li ul {
	width: 100%;
}
.flexnav li ul ul {
/*	border-bottom: 1px solid #ccc;*/
}
.flexnav li ul ul a {
	padding-left: 40px;
	background: #f1f1f1
}

@media all and (min-width: 778px) {
.flexnav li:hover li a, .flexnav li:hover li li a {
	background: #fff;
	color: #666;
}
.flexnav li:hover .touch-button .navicon {
	color: #000;
}
.flexnav li:hover a, .flexnav a:hover, .flexnav li > ul li a:hover, .flexnav li > ul li:hover a, .flexnav li:hover li li a:hover, .flexnav li a.selected {
	border-bottom: 4px solid #ccc
}
.flexnav li:hover li a {
	border-bottom: 1px solid #ccc
}
.flexnav li:hover li a:hover {
	border-bottom: 1px solid #ccc;
	background: #ccc;
	color: #000
}
.menu-button {
	display: none;
}
.flexnav li.riservata a {
	color: #8790a2
}
.flexnav li.riservata a:hover {
	color: #fff
}
.nav .container {
	width: 1100px;
	padding: 0px 0px
}
.nav {
	position: relative;
	top: 0px;
	z-index: 9999;
}
.flexnav li:hover li a, .flexnav li:hover li li a {
}
.flexnav li.item-with-ul a {
	background-image: url(../img/icone/next.png);
	background-position: center right;
	background-size: auto 17px;
	background-repeat: no-repeat;
	padding: 0px 22px 0px 0px;
}
.home .flexnav li.item-with-ul a {
	background-image: url(../img/icone/next-white.png);
}
.flexnav li.item-with-ul li a {
	padding: 10px 20px;
	background-image: none
}
.flexnav li ul {
	width: 100%;
}
.flexnav .touch-button {
	display: none;
}
.flexnav li {
	display: block
}
body.one-page {
	padding-top: 70px;
}
.flexnav {
	overflow: visible;
	display: block;
	text-align: center;
}
.flexnav.opacity {
	opacity: 1;
}
.flexnav.one-page {
	top: 0;
	right: auto;
	max-width: 1080px;
}
.flexnav li {
	position: relative;
	list-style: none;
	display: inline-block;
	overflow: visible;
}
.flexnav li a {
	border-bottom: none;
	background: transparent;
	color: #000;
	margin: 0px 10px;
	padding: 0px 0px;
}
.home .flexnav li a {
	color: #fff;
}

.home .flexnav li:hover a, 
.home .flexnav a:hover, 
.home .flexnav li > ul li a:hover, 
.home .flexnav li > ul li:hover a, 
.home .flexnav li:hover li li a:hover,
.home .flexnav li a.selected {
	border-color: #ccc
}

.home .flexnav li:hover li a:hover {
	background: #ccc;
	color: #000
}


.flexnav li li a {
	border-bottom: 1px solid #ccc;
}
.flexnav li > ul {
	position: absolute;
	top: 32px;
	width: 100%;
}
.flexnav li > ul li {
	width: 100%;
}
.flexnav li ul li > ul {
	margin-left: 100%;
	top: 0;
}
.flexnav li ul li a {
	padding: 0px 22px 0px 0px;
}
.flexnav li ul.open {
	display: block;
	opacity: 1;
	visibility: visible;
	z-index: 1;
}
.flexnav li ul.open li {
	overflow: visible;
	max-height: 100px;
}
.flexnav li ul.open ul.open {
	margin-left: 100%;
	top: 0;
}
}
