.flexnav .touch-button {
  display: inline-block;
}
.nav .container {
  width: 100%;
  padding: 0px 0px
}
.flexnav .touch-button {
  position: absolute;
  z-index: 99;
  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: #12c3be;
}
.menu-button svg {
  overflow: visible;
  position: absolute;
  top: 3px;
  left: 12px;
}
.menu-button svg:nth-child(2) {
  top: 13px;
}
.menu-button svg:nth-child(3) {
  top: 23px;
}

.homepage .menu-button {
  background-color: #c3126f;
  color: white;

}

.menu-button {
    position: relative;
    display: block;
    float: right;
    text-decoration: none;
    background-color: #333333;
    text-align: center;
    cursor: pointer;
    width: 50px;
    height: 50px;
    z-index: 99;
    right: 24px;
    margin-top: 21px;
    -moz-border-radius: 2px;
    border-radius: 2px;
    color: #12c3be;
    font-size: 26px;
    padding: 10px;
    top: 71px;
    line-height: normal
}


.menu-button svg {
line-height: normal
}

.menu-button.active {
  top: 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
}
.flexnav li {
  padding: 0px
}
.flexnav li a {
  padding: 0px 20px 5px 20px;
}
.nav {
  width: 100%;
  border: none;
  height: auto;
  position: absolute;
  min-height: 50px;
  margin-bottom: 0px;
  font-family: 'Roboto', sans-serif;
  font-weight: 500;
  margin-top: 0px;
  left: 0px;
  top: -71px;
  left: 0px;
  z-index: 99;
}
.flexnav li:hover .touch-button .navicon {
  color: #12c3be;
}
.flexnav li:hover li a, .flexnav li:hover li li a {
  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;
  margin-top: 71px;
}
.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 img {
    width: 33px;
    height: auto;
    margin-right: 10px;
}
.flexnav li a {
    background: #333;
    color: white;
    position: relative;
    display: block;
    z-index: 2;
    text-decoration: none;
    margin: 0px;
    font-size: 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    font-weight: 300;
    padding: 19px 20px;
    text-transform: uppercase;
}
.flexnav li a {
/*  background: #333;
  color: white;
  position: relative;
  display: block;
  z-index: 2;
  text-decoration: none;
  margin: 0px;
  font-size: 15px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  font-weight: 300;
  padding: 10px 20px;
  text-transform: uppercase;*/
}
.flexnav li.menu_shop a {
  font-weight: 500;
  text-transform: uppercase;
  color: #12c3be;
}
.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: #696a6f;
  font-weight: 400;
  background: rgba(255, 255, 255, 0.9)
}
.flexnav li {
  display: block
}
.flexnav li ul {
  width: 100%;
}
.flexnav li ul ul {
  /*	border-bottom: 1px solid #d0d3d6;*/
}
.flexnav li ul ul a {
  padding-left: 40px;
  background: #f1f1f1
}


    @media all and (min-width: 875px) {
        .nav {
            top: 0px;
        }

        .flexnav li:hover li a, .flexnav li:hover li li a {
            /*	*/ background: rgba(255, 255, 255, 0.8);
            color: #333;
        }

        .home .flexnav li:hover li a, .flexnav li:hover li li a {
        }

        .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 */
        .flexnav li.item-with-ul:hover a {
        }

        .flexnav li.item-with-ul ul li a {
            background-image: none !important;
        }

        .flexnav li:hover li a {
            border-bottom: 1px solid #d0d3d6
        }

            .flexnav li:hover li a:hover {
                border-bottom: 1px solid #d0d3d6;
                background: white;
                color: #333
            }

        .menu-button {
            display: none;
        }

        .flexnav li.riservata a {
            color: #12c3be
        }

            .flexnav li.riservata a:hover {
                color: #fff
            }

        .nav .container {
            width: 1100px;
            padding: 0px 0px
        }

        .nav {
            position: relative;
            top: 0px;
            z-index: 9;
            width: auto;
            border: none;
            height: auto;
            margin-bottom: 0px;
            margin-top: 25px;
            float: right;
            margin-right: 0px;
            border-right: 1px solid rgba(255, 255, 255, 0.1);
            min-height: 60px;
            padding-right: 10px;
        }

        .homepage .nav {
            margin-top: 26px;
        }

        .flexnav li:hover li a, .flexnav li:hover li li a {
        }

        .flexnav li.item-with-ul a {
        }

        .flexnav li.item-with-ul a {
            padding-bottom: 28px;
        }

        .flexnav li.item-with-ul li a::after {
            content: "";
        }

        .flexnav li.item-with-ul a::after {
            content: "\f105";
            color: #fc5000;
            font-weight: bold;
            font-family: Font Awesome\ 5 Free;
            margin-right: 0px;
            font-size: 12px;
            margin-left: 5px;
        }

        .home .flexnav li.item-with-ul a::after {
            color: #ffffff;
        }
        /*	.flexnav li.item-with-ul a:hover::after { 
    color: #fff;			
}*/
        .flexnav li.item-with-ul a:hover svg {
            -webkit-transform: rotate(45deg);
            -moz-transform: rotate(45deg);
            -ms-transform: rotate(45deg);
            -o-transform: rotate(45deg);
            transform: rotate(45deg)
        }

        .flexnav li.item-with-ul a:hover {
        }

        .flexnav li.item-with-ul li a {
            padding: 10px;
            background-image: none;
            margin: 0px;
            font-size: 14px;
            text-align: left;
            font-weight: normal;
        }

            .flexnav li.item-with-ul li a:hover {
                background-color: #7194b7;
                color: white
            }

        .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;
                text-align: center;
                vertical-align: top;
            }

                .flexnav li img {
                    display: block;
                    clear: both;
                    margin: 0px auto 7px auto;
                    float: inherit;
                    width: auto;
                }

                .flexnav li a {
                    border-bottom: none;
                    background: transparent;
                    color: #ffffff;
                    margin: 0px 15px;
                    padding: 0px 0px;
                    text-align: center;
                    font-size: 10px;
                }

                .flexnav li.menu_shop a {
                    color: #12c3be;
                    text-transform: uppercase;
                    font-weight: 700
                }

        .home .flexnav li a {
            color: #fff; /*border-bottom: 2px solid transparent;*/
        }

            .home .flexnav li a:hover {
            }

        .home .flexnav li li a {
            color: #797979;
            font-weight: 400;
        }

        .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 {
            color: #fff
        }

        .home .flexnav li:hover li a:hover {
        }

        .flexnav li li a {
            border-bottom: 1px solid rgba(0, 0, 0, 0.1);
        }

        .flexnav li > ul {
            position: absolute;
            top: 50px;
            width: 200px;
            background: rgba(255, 255, 255, 0.7);
        }

        .flexnav li ul li::before {
            width: 25px;
            height: 25px;
            background: red
        }

        .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;
            font-family: 'Roboto', sans-serif;
        }

        .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;
            }
    }