/*###################################### START GENERIC CLASSES ######################################*/

.clear{
	clear: both;
}

.clearLeft{
	clear: left;
}

.clearRight{
	clear: right;
}

.noMarginLeft{
	margin-left: 0!important;
}

.noMarginRight{
	margin-right: 0!important;
}

.noBorderBottom{
	border-bottom: 0!important;
}

/*###################################### END GENERIC CLASSES ######################################*/









/*###################################### START TEMPLATE STYLES ######################################*/

*{
	margin: 0px;
	border: 0px;
	padding: 0px;
}

body{
	background: #2f332b;
	color: #2f332b;
    font-family: 'Roboto', sans-serif;
	/*font-family: "Times New Roman", Times, serif;*/
	font-size: 14px;
}

#container{
	display: inline;
	float: left;
	width: 100%;
	background: #d5cea6 url(../images/bgContainer.gif) left top repeat-x;
}

#wrapper{
	width: 960px;
	margin: 0 auto;
	position: relative;
}

#header{
	float: left;
	/*width: 100%;*/
	width: 960px;
	height: 142px;
	display: inline;
	position: relative;
	box-sizing: border-box;
}

#header h1{
	display: inline;
	float: left;
	width: 99px;
	height: 142px;
	position:absolute;
	left: 5px;
	top: 0;
	z-index: 100;
	background: url(../images/logo.png) left top no-repeat;
}

#header h1 a{
	display: inline;
	float: left;
	width: 99px;
	height: 142px;
	cursor:pointer;
}

#header h1 a span{
	display: none;
}

#footer{
	display: inline;
	float: left;
	width: 100%;
	color: #d5cea6;
	font-size: 11px;
}

#footerInside{
	width: 960px;
	margin: 20px auto;
	position: relative;
}

#footerInside .footerLeft{
	display:inline;
	float: left;
	width: 480px;
	text-align:left;
}

#footerInside .footerRight{
	display:inline;
	float: left;
	width: 480px;
	text-align:right;
}

#footer a{
	color: #FFF;
	text-decoration: none;
}

#footer a:hover{
	color: #d5cea6;
}

a{
	color:#a20327;
	text-decoration:none;
}

a:hover{
	text-decoration: underline;
}

/*###################################### END TEMPLATE STYLES ######################################*/








/*###################################### START BOX SEARCH ######################################*/

#header .boxSearch{
	display: inline;
	float: left;
	width: 330px;
	height: 22px;
	background: url(../images/bgSearch.gif) 118px 0 no-repeat;
	position:absolute;
	left: auto;
	right: 12px;
	/*left: 620px;*/
	top: 8px;
	z-index: 100;
}

#header .boxSearch label{
	display: inline;
	float: left;
	margin: 0;
	width: 121px;
	height: 22px;
	color: #d5cea6;
	/*font-size:16px;*/
	font-size: 14px;
	line-height: 1.75;
}

#header .boxSearch input.searchField{
	display: inline;
	float: left;
	width: 161px;
	height: 18px;
	padding: 2px 5px;
	color:#2f332b;
	font-family: 'Roboto', sans-serif;
	/*font-family: "Times New Roman", Times, serif;*/
	font-size:14px;
	font-weight:normal;
}

#header .boxSearch input.searchButton{
	display: inline;
	float: left;
	width: 38px;
	height: 22px;
	background: url(../images/buttonSearch.gif) left top no-repeat;
}

/*###################################### END BOX SEARCH ######################################*/









/*###################################### START MAIN MENU ######################################*/

.nav {
	display: inline;
	float: right;
	list-style: none;
	z-index: 100;
	margin: 40px 10px 0 0;
}

.nav li {
	display: inline;
	float: left;
	position: relative;
	z-index: 100;
	margin-left: 5px;
}

.nav li a span {
	display: inline;
	float: left;
	height: 26px;
	margin-left: 10px;
	/*margin-left: 12px;*/
	padding: 28px 10px 0 0;
	/*padding: 28px 12px 0 0;*/
	cursor:pointer;
}

.nav li a {
	display: inline;
	float: left;
	height: 54px;
	color: #d5cea6;
	font-size: 16px;
	text-decoration: none;
	z-index: 100;
	cursor:pointer;
}

.nav li a:hover, .nav li a.sel {
	color: #d5cea6;
	background: url(../images/bgItemNavOver.gif) left bottom no-repeat;
}

.nav li a:hover span, .nav li a.sel span {
	color: #d5cea6;
	background: url(../images/bgItemNavOver.gif) right bottom no-repeat;
}

/*###################################### END MAIN MENU ######################################*/








/*###################################### START CONTENT ######################################*/

#contentHome,
#contentInside {
	padding-top: 10px !important;
	padding-bottom: 20px !important;
}

#contentHome{
	display: inline;
	float: left;
	width: 920px;
	margin-top: 286px;
	padding: 20px;
	background:url(../images/bgContentHome.gif) left top no-repeat;
}

#flashHome{
	display: inline;
	float: left;
	position: absolute;
	width: 960px;
	height: 315px;
	left: 0;
	top: 94px;
	z-index: 0;
}

.boxContentHome{
	display:inline;
	float:left;
	width: 440px;
	padding: 10px;
}

.boxContentInside table {
	width: 100%;
}

.boxContentHome h2{
	padding-bottom: 15px;
	color:#a20327;
	font-size:18px;
	font-style:italic;
	font-weight:bold;
}

.boxContentHome h3{
	padding-bottom: 15px;
	color:#a20327;
	font-size:14px;
	font-weight:bold;
}

.boxContentHome p{
	color:#2f332b;
	font-size:14px;
	font-weight:normal;
	line-height: 18px;
}

.boxContentHome p a{
	color:#a20327;
	font-weight:bold;
	text-decoration:none;
}

.boxContentHome p a:hover{
	text-decoration:underline;
}

.boxContentHome img{
	display:inline;
	float:right;
	border: 4px solid #FFF;
	margin-left: 10px;
}

#contentInside{
	float: left;
	width: 100%;
	padding: 20px;
	display: inline;
	box-sizing: border-box;
	background:url(../images/bgContentInside.gif) left top no-repeat;
}

.boxContentInside{
	display:inline;
	float:left;
	width: 630px;
	margin-left: 20px;
	padding: 10px 0;
}

.boxContentInside h2{
	padding-bottom: 15px;
	color:#a20327;
	font-size:18px;
	font-style:italic;
	font-weight:bold;
}

.boxContentInside h3{
	padding-bottom: 15px;
	color:#a20327;
	font-size:14px;
	font-weight:bold;
}

.boxContentInside p{
	color:#2f332b;
	font-size:14px;
	font-weight:normal;
	line-height: 18px;
}

.boxContentInside p a{
	color:#a20327;
	font-weight:bold;
	text-decoration:none;
}

.boxContentInside p a:hover{
	text-decoration:underline;
}

.boxContentInside ul{
	margin: 10px 20px;
}

.boxContentInside ul li{
	padding-top: 5px;
	list-style: disc;
	line-height:16px;
}

.boxContentInside ol{
	margin: 10px 25px;
}

.boxContentInside ol li{
	padding-top: 5px;
	list-style: decimal;
	line-height:16px;
}

.boxContentInside img{
	display:inline;
	float:right;
	border: 4px solid #FFF;
	margin-left: 10px;
}

/*###################################### END CONTENT ######################################*/









/*###################################### START MENU LEFT ######################################*/

#navLeft{
	display:inline;
	float: left;
	width:240px;
	margin-right:20px;
}

#navLeft h2{
	padding: 10px 0;
	color:#a20327;
	font-size:18px;
	font-style:italic;
	font-weight:bold;
}

#navLeft li{
	float:left;
	display:inline;
	list-style:none;
	margin-bottom: 5px;
}

#navLeft li a{
	display:inline;
	float:left;
	width:210px;
	height: 30px;
	color: #2f332b;
	padding: 0 10px;
	text-decoration:none;
	font-size:14px;
	line-height: 30px;
}

#navLeft li a:hover, #navLeft li a.selNav{
	background:url(../images/bgNavLeftItemOver.gif) left top no-repeat;
	color:#d5cea6;
}

#navLeftSub {
	display: inline;
	float: left;
	margin:5px 10px;
}

#navLeftSub li {
	display: inline;
	float: left;
	background:none;
	margin-bottom:0;
}

#navLeftSub li a {
	display: inline;
	float: left;
	width: 190px;
	height: auto;
	padding:2px 10px;
	text-decoration: none;
	font-size:12px;
	background: none;
	line-height: normal;
}

#navLeftSub li a:hover, #navLeftSub li a.selSub {
	color:#a20327;
	background:none;
}

#navLeft span.select {
	display:inline;
	float:left;
	position: absolute;
	width: 201px;
	height: 20px;
	padding: 2px 24px 0 5px;
	color: #2f332b;
	font-family: 'Roboto', sans-serif;
	/*font-family: "Times New Roman", Times, serif;*/
	font-size: 14px;
	background: url(../images/bgSelect.gif) right top no-repeat;
	overflow: hidden;
	border-radius: 4px;
	background-size: 230px 100%;
	background-color: #FFF;
}

#navLeft select {
	height: 22px;
	margin-bottom: 5px;
	color: #2f332b;
	font-family: 'Roboto', sans-serif;
	/*font-family: "Times New Roman", Times, serif;*/
	font-size: 14px;
}

#navLeft form {
	width: 100%;
	position: relative;
}

/*###################################### END MENU LEFT ######################################*/









/*###################################### START FORM ######################################*/

.textField{
	display: inline;
	float: left;
	width: 220px;
	height: 12px;
	margin-top: 6px;
	padding: 2px;
	color: #444444;
	font-family: "Lucida Sans Unicode", Arial, Helvetica, sans-serif;
	font-size: 11px;
}

textarea{
	display: inline;
	float: left;
	width: 220px;
	height: 40px;
	margin-top: 6px;
	padding: 2px;
	color: #444444;
	font-family: "Lucida Sans Unicode", Arial, Helvetica, sans-serif;
	font-size: 11px;
}

label{
	display: inline;
	float: left;
	width: 150px;
	height: 10px;
	margin-top: 6px;
}

input.btnInvia {
	display: inline;
	float: right;
	width: 90px;
	height: 20px;
	margin: 16px 46px 5px 0;
	border: 0;
	padding: 0;
	color: #353631;
	font-family: "Lucida Sans Unicode", Arial, Helvetica, sans-serif;
	font-size: 12px;
	font-weight: normal;
	text-align: center;
	cursor: pointer;
	background:#FFF;
}

input.btnInvia:hover {
	color: #fccd03;
}

input.btnCancella {
	display: inline;
	float: right;
	width: 90px;
	height: 20px;
	margin: 16px 5px 5px 0;
	border: 0;
	padding: 0;
	color: #353631;
	font-family: "Lucida Sans Unicode", Arial, Helvetica, sans-serif;
	font-size: 12px;
	font-weight: normal;
	text-align: center;
	cursor: pointer;
	background:#FFF;
}

input.btnCancella:hover {
	color: #fccd03;
}

fieldset.formdata {
	display: inline;
	float: left;
	width: 548px;
}

fieldset.formprivacy {
	display: inline;
	float: left;
	width: 350px;		              
}

/*###################################### END FORM ######################################*/









/*###################################### START DOVE SIAMO ######################################*/

#map{
	display: inline;
	float: left;
	border: 2px solid #fbca46;
	margin:135px 20px 0 0;
	width: 365px;
	height: 371px;
}

/*###################################### END DOVE SIAMO ######################################*/






/*###################################### START CAROUSEL ######################################*/

.carousel-wrapper {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	width: 100%;
	display: block;	
	position: absolute;
	top: 108px;
	left: 0;
	overflow: hidden;
}

.carousel-wrapper * {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

.carousel {
	display: inline-block;
	position: relative;
	height: 100%;
	width: 100%;
}

.slick-list,
.slick-track {
	display: inline-block;
	width: 100%;
	height: 100%;
	padding: 0 !important;
}

.carousel__item {
	float: left;
	display: inline-block;
	margin: 0;
	width: 320px;
	height: 320px; 
}

.carousel__item > div { 
	display: block;
	height: 100%;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	box-shadow: 0px 0px 59px 0px rgba(0, 0, 0, 0.35) inset; 
	-webkit-box-shadow: 0px 0px 59px 0px rgba(0, 0, 0, 0.35) inset;
}

.slick-arrow {
	position: absolute;
	bottom: 20px;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	z-index: 50;
	width: 32px;
	height: 32px;
	border: none;
	background-color: transparent;
	cursor: pointer;
	outline: none !important;
}

.slick-arrow.slick-prev {
	background-image: url('../icon/other/left-arrow.png');
	left: 20px;
}

.slick-arrow.slick-next {
	background-image: url('../icon/other/right-arrow.png');
	right: 20px;
}

#carousel-wrapper.absolute-wrapper {
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -480px;
	z-index: 10;
	height: 100%;
}

.carousel-text {
	height: 100%;
	width: 320px;
	background-color: #2f332b;
	color: #fff;
	box-shadow: 0px 0px 49px 0px rgba(0, 0, 0, 0.45); 
	-webkit-box-shadow: 0px 0px 49px 0px rgba(0, 0, 0, 0.45);
	padding: 60px 20px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	position: relative;
}

.carousel-text h3 { 
	font-size: 26px;
	font-weight: 300;
	font-family: "Roboto";
}

.carousel-text a {
	display: inline-block;
	margin-top: 20px;
	padding-right: 30px;
	text-transform: uppercase;
	color: #fff;
	font-family: "Roboto";
	background-position: right center;
	background-repeat: no-repeat;
	background-image: url('../icon/other/arrow-link.png');
	background-size: 18px auto;
}

.carousel-text h2 {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 15px 20px;
	font-style: italic;
	font-size: 22px;
	color: #d5cea6;
	font-weight: 300;
	width: 100%;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

.carousel-text h2 strong {
	color: #fff;
}

/*###################################### END CAROUSEL ######################################*/




/*###################################### START MOBILE ######################################*/

.mobile-search {
	top: 8px;
	/*right: 28px;*/
	right: 20px;
	width: 22px;
	height: 22px;
	z-index: 100;
	position: absolute;
}

.mobile-hamburger {
	top: 50%;
	right: 12px;
	width: 40px;
	height: 40px;
	display: none;
	position: absolute;
	border-radius: 100%;
	/*display: inline-block;*/
	background-color: #D5CEA6;
	transform: translateY(-50%);

}

.mobile-hamburger:hover,
.mobile-hamburger--active {
	background-color: #E6E1CA;
}

.mobile-hamburger span {
	left: 10px;
	right: 10px;
	height: 0px;
	display: block;
	position: absolute;
	border-top: 1px solid #A20327;
	background-color: transparent;
	transition: all 0.3s ease-in-out;
	-webkit-transition: all 0.3s ease-out;
}

.mobile-hamburger span:first-child {
	top: 10px;
}

.mobile-hamburger--active span:first-child {
    transform: rotate(45deg);
    transform-origin: -1px 5px 0;
	-webkit-transform: rotate(45deg);
    -webkit-transform-origin: -1px 5px 0;
}

.mobile-hamburger span.middle {
	top: 50%;
	left: 7px;
	right: 7px;
	opacity: 1;
	height: 6px;
	border-top: 1px solid #A20327;
	transform: translateY(-50%);
	border-bottom: 1px solid #A20327;
}

.mobile-hamburger--active span.middle {
	opacity: 0;
}

.mobile-hamburger span:last-child {
	bottom: 10px;
}

.mobile-hamburger--active span:last-child {
    transform: rotate(-45deg);
    transform-origin: -2px -5px 0;
	-webkit-transform: rotate(-45deg);
    -webkit-transform-origin: -2px -5px 0;
}

.mobile-search::before/*,
.mobile-hamburger::before*/ {
	top: 50%;
	left: 50%;
	content: "";
	color: #2F332B;
	position: absolute;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
	transform: translateX(-50%) translateY(-50%);
}

.mobile-search::before {
	width: 22px;
	height: 22px;
	background-image: url(../images/search.png);
}

/*.mobile-hamburger::before {
	width: 40px;
	height: 40px;
	background-image: url(../images/menu.png);
}*/

.mobile-menu {
	left: 0;
	top: 108px;
	width: 100%;
	z-index: 99;
	padding: 10px;
	color: #2F332B;
	display: block;
	overflow: auto;
	position: absolute;
	box-sizing: border-box;
	background-color: #E6E1CA;
	height: calc(100vh - 108px);
}

.mobile-menu.mobile-menu--hidden,
.mobile-search-menu.mobile-search-menu--hidden {
	display: none;
}

.mobile-menu .nav {
	float: none;
	margin: 0 auto;
	display: block;
}

.mobile-menu .nav li {
	margin: 0;
	float: none;
	width: 100%;
	height: auto;
	text-align: center;
	margin-bottom: 5px;
	display: inline-block;
}

.mobile-menu .nav li a,
.mobile-menu .nav li a span {
	margin: 0;
	float: none;
	height: auto;
	color: #2F332B;
	display: inline-block;
	background-image: none;
}

.mobile-menu .nav li a {
	width: 100%;
	border-radius: 4px;
}

.mobile-menu .nav li a.sel,
.mobile-menu .nav li:hover a {
	background: #2F332B;
}

.mobile-menu .nav li a span {
	height: auto;
	padding: 14px 12px;
}

.mobile-menu .nav li a.sel span,
.mobile-menu .nav li:hover a span {
	color: #D5CEA6;
}

#mobile-search-menu {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 200;
	position: fixed;
	background-color: #D5CEA6;
}

#mobile-search-close {
	top: 10px;
	right: 10px;
	width: 40px;
	height: 40px;
	position: absolute;
	border-radius: 100%;
	background-color: #2F332B;
}

#mobile-search-close:hover {
	background-color: #41453D;
}

#mobile-search-close::before {
	top: 50%;
	left: 50%;
	width: 20px;
	content: "";
	height: 20px;
	position: absolute;
	background-size: 100%;
	background-repeat: no-repeat;
	background-position: center center;
	background-image: url(../images/close.png);
	transform: translateX(-50%) translateY(-50%);
}

#mobile-search-menu .boxSearch {
	top: 50%;
	left: 50%;
	width: 250px;
	height: 50px; 
	position: absolute;
	text-align: center;
	transform: translateX(-50%) translateY(-50%);
}

#mobile-search-menu .boxSearch form {
	width: 100%;
    height: 100%;
}

#mobile-search-menu .boxSearch .input-container {
	height: 30px;
    font-size: 0;
    display: block;
    position: relative;
}

#mobile-search-menu .boxSearch .input-container * {
	font-size: initial;
}

.input-container > * {
	height: 30px;
	vertical-align: top;
}

.input-container :first-child {
	border-radius: 10px 0 0 10px;
}

.input-container :last-child {
	border-radius: 0 10px 10px 0;
}

.input-container .searchField {
	width: 220px;
	padding: 0 10px;
	box-sizing: border-box;
}

.input-container .searchButton {
	width: 30px;
	cursor: pointer;
	background-color: #A20327;
}

.input-container .searchButton::before {
	top: 0;
	right: 0;
	width: 30px;
	content: "";
	height: 30px;
	cursor: pointer;
	position: absolute;
	background-size: 75%;
	transform: rotate(90deg);
	background-repeat: no-repeat;
	background-position: center center;
	background-image: url(../images/search.png);
}

#mobile-search-menu .boxSearch label {
	float: none;
	height: 20px;
	margin: 0 auto;
	display: block;
}

.is-menu-active {
	overflow: hidden;
}

.is-search-active {
	overflow: hidden;
}

/*###################################### START MOBILE ######################################*/



/*###################################### START NEW STYLE ######################################*/

.option-group {
	float: right;
	width: 100px;
	height: 30px;
	display: inline;
}

.option-group--small {
	width: 60px;
	float: right;
	height: 30px;
	display: inline;
}

/*************************************/

.home-image {
	float: left;
	display: inline;
}

.home-image__link {
	display: inline;
	float: left;
	width: 146px;
	height: 100px;
	border: none;
}

.home-image__link__img {
	float: left;
	margin: 3px;
	display: inline;
	border: 2px solid #FFF;
}

.home-image__text {
	float: left;
	width: 146px;
	height: 60px;
	border: none;
	display: inline;
	text-align: center;
}

/*************************************/

.dettaglio {
	float: left;
	width: 100%;
	display: inline;
	text-align: left;
	padding-top: 15px;
	padding-bottom: 10px;
}

.dettaglio p {
	font-size: 16px;
}

.boxContentInside hr {
	color: #ACA78A;
	margin-bottom: 10px;
	background-color: #ACA78A;
}

.image-container {
	float: left;
	display: inline;
	margin-bottom: 15px;
}

.image-container__box {
	height: 180px;
}

.image-container__box__img {
	float: none !important;
	margin-left: 0px !important;
}

.image-container__text {
	height: 35px;
	padding-top: 3px;
}

.image-container__box,
.image-container__text {
	float: none;
	width: 180px;
	border: none;
	margin: 0 auto;
	display: block;
	position: relative;
	text-align: center;
}

/*************************************/

.image-block {
	width: 100%;
	float: none;
	display: block;
}

.image-block img {
	float: none;
	margin: 0 auto;
	display: block;
}

/*************************************/

.table-search,
.table-search tbody {
	width: 100%;
}

.table-search table td {
	width: 25%;
	height: 25px;
}

input.search-image {
	padding: 0;
	color: #FFF;
	float: left;
	width: 230px;
	height: 22px;
	cursor: pointer;
	display: inline;
	font-size: 14px;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	font-family: 'Roboto', sans-serif;
	/*font-family: 'Times New Roman', Times, serif;*/
	background-image: url(../images/bgFormButton.gif);
}

/**/

#overlay {
	width: 100% !important;
	height: 100% !important;
	z-index: 300 !important;
	position: fixed !important;
}

#lightbox {
	top: 50% !important;
	left: 10px !important;
	z-index: 301 !important;
	position: fixed !important;
	transform: translateY(-50%);
	width: calc(100vw - 20px) !important;
}

#imageContainer {
	box-sizing: border-box;
}

#lightboxImage,
#imageDataContainer,
#outerImageContainer {
	max-width: 100%;
}

#outerImageContainer {
	height: 100% !important;
}

/**/

.title-archivio {
	width: 100%;
	float: left;
	color: #a20327;
	display: inline;
	font-size: 18px;
	font-weight: bold;
	font-style: italic;
	padding-bottom: 20px;
}

/*###################################### END NEW STYLE ######################################