/* reset CSS */

@keyframes cssload-spin {
	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
		transform: rotate(360deg);
	}
}

@-webkit-keyframes cssload-spin {
	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}


* {
	padding: 0;
	margin: 0;
	outline: none!important;
}

html, body {
	max-width: 100%;
}

/* @group COLORI SFONDI */

.BgdFFF {
	background: #fff !important;
}

.Bgd000 {
	background: #000 !important;
}

.BgdDDD {
	background-color: #dddddd !important;
}

.Bgd333 {
	background-color: #333333 !important;
}	

.BgdBlu {
	background-color: #1d4781 !important;
}

.BgdF6F {
	background-color: #f6f6f6 !important;
}	


/* @end */

/* @group COLORI TESTI */

.text000 {
	color: #000;
}

.textFFF {
	color: #fff !important;
}

/* @end */

/* @group GENERICI */

.icon-bar {
	color: black;
	border-color: black;
	background-color: black;
}

body {
	font-family: 'Open Sans', sans-serif;
	color: #000000 !important;
	font-weight: 300 !important;
	font-size: 14px;
	line-height: 1.2rem;
}


.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
	line-height: 1.2em;
}

.Block {
	display: block;
}

.clear {
	clear: both;
}

.no-border {
	border: 0px !important;
}

.ImgFull {
	background-size: cover;
}

.FullWidth {
	width: 100%;
}

.no-left {
	padding-left: 0 !important;
}

.no-right {
	padding-right: 0 !important;
}

.text-shadow {
	text-shadow: 1px 1px 2px #333333;
}

.shadowLight {
	text-shadow: 1px 1px 2px #999999;
}

.border {
	border: 1px solid #333 !important;
}

.border999-right {
	border-right: 1px solid #999 !important;
	border-radius: 0;
}

.BorderBottomLight {
	border-bottom: 1px solid #ededed !important;
	margin: 20px 0;
}

.noborder {
	border: none !important;
}

.radius {
	border-radius: 5px;
}

.no-radius {
	border-radius: 0;
}

a {
	color: #999;
	text-decoration: none;
	background-color: transparent;
	-webkit-text-decoration-skip: objects;
}

a:hover {
	color: #3B4847;
	text-decoration: none;
}


a.blu {
	color: #1d4781;
	text-decoration: none;
}

a.blu:hover {
	text-decoration: underline !important;
}

/* @end */

/* @group WEIGHT TESTI*/


.w300 {
	font-weight: 300 !important;
}

.w400 {
	font-weight: 400 !important;
}

.w600 {
	font-weight: 600 !important;
}

.w700 {
	font-weight: 700 !important;
}


/* @end */


/* @group X-INDEX */

.z2 {
	z-index: 2 !important;
	opacity: .4;
	width: 100%;
	position: absolute;
}

.z999 {
	z-index: 999 !important;
}

/* @end */

.relative {
	position: relative !important;
}

.absolute {
	position: absolute !important;
}

.no-display {
	display: none;
}

/* ---------------------------          ---------------------------*/

/* ---------------------------  CUSTOM  ---------------------------*/

/* ---------------------------          ---------------------------*/

div#Map {
	width: 100%;
	height: 500px;
}

.chp {
	visibility: hidden;
	width: 1px;
	height: 1px;
	font-size: 1px;
}

.Alert {
	display: none;
}

span.has-error {
	background: none;
	color: red;
	border: none;
	padding: 0;
	display: block;
	text-align: left;
	font-size: 12px;
}

.Privacy {
	height: 50px;
	margin-bottom: 20px;
	overflow: auto;
	font-size: 11px;
	color: #666;
	line-height: normal !important;
}

.link {
	vertical-align: middle;
	display: table-cell;
}

.btn-primary {
	background: rgba(255, 255, 255, 1);
	border-radius: 8px;
	font-size: 20px;
	color: #000000;
	padding: 3px 20px;
	width: 360px;
	text-align: center;
	font-weight: 300;
	line-height: 2em !important;
	display: inline-block;
}

.btn-primary-mini {
	background: rgba(255, 255, 255, 1);
	border-radius: 8px;
	font-size: 16px;
	color: #000000;
	padding: 3px 10px;
	width: 300px;
	text-align: center;
	font-weight: 300;
	line-height: 2em !important;
	display: inline-block;
}

.btn-primary:hover, .btn-primary-mini:hover {
	background: rgba(255, 255, 255, 0.9);
	color: #000000;
}

.btn-secondary {
	background: #94AAAE;
	font-size: 16px;
	color: #fff !important;
	padding: 10px 40px;
	text-align: center;
	font-weight: 300;
	line-height: 2em !important;
	min-width: 220px;
	min-height: 50px;
	display: inline-block;
	border: 0px;
}

.btn-secondary:hover {
	background: #728386;
	color: #fff !important;
	text-decoration: none;
}

h1 {
	font-size: 24px;
	font-weight: 600;
	line-height: 2rem;
}

h2 {
	font-size: 22px;
	font-weight: 400;
	line-height: 2rem;
}

h3 {
	font-size: 28px;
	font-weight: 300;
	text-transform: uppercase;
}

h4 {
	font-size: 20px;
	color: #0077B3;
}

h5 {
	font-size: 14px;
	font-weight: 300;
}

b {
	font-weight: 600;
}

p {
	font-size: 15px;
	line-height: 1.6em;
	font-weight: 400;
	color: #000;
}



/*------------ TOP MENU ------------*/

.top-menu a {
	color: #58585a;
	margin: 0 15px;
    text-decoration: none;
    font-weight: 700;
    font-size: 13px;
}

.top-menu a:hover {
	color: #1d4781;
}

/*------------ NAVABAR ------------*/

.navbar {
	background-color: #fff;
	padding: 10px 15px 10px 15px;
}

.navbar-brand {
	height:auto;
	width: 250px;
	margin-left: 15px;
}

.nav-link {
	font-size: 15px;
	color: #58585a !important;
	font-weight: 700;
	text-transform: uppercase;
	padding-right: 1rem !important;;
    padding-left: 1rem !important;;
}

.nav-link.active, .nav-link:hover {
    color: #000 !important;
}

.navbar-light .navbar-nav .active>.nav-link, .navbar-light .navbar-nav .nav-link.active, .navbar-light .navbar-nav .nav-link.show, .navbar-light .navbar-nav .show>.nav-link {
    color: #000;
}

.navbar-light .navbar-toggler {
    color: rgba(0,0,0,.5);
    border-color: rgba(0,0,0,.1);
    margin-right: 15px;
}

.briciole {
	font-size: 12px;
	font-weight: 300;
	color: #fff;
}

.briciole a{
	color: #fff;
}

.briciole a:hover{
	text-decoration: underline	;
}


/*------------ MAIN ------------*/

.page-title {
	color: #1d4781;
	font-size: 24px;
	font-weight: 700;
	padding: 0 0 10px;
	border-bottom: #f4f4f4 1px solid;
}

.page-title-1 {
	color: #eea03c;
	font-size: 20px;
	font-weight: 700;
	padding: 0 0 10px;
	border-bottom: #f4f4f4 1px solid;
	text-transform: none;
}

.table th {
    padding: .75rem;
    vertical-align: top;
    border-top: 1px solid #dee2e6;
    width: 50%;
	color: #1d4781;
}



/*------------ FOOTER ------------*/



.footer h3 {
	font-size: 14px;
	color: #ffffff;
	text-transform: none;
	font-weight: 600;
}

.footer p {
	font-size: 12px;
	color: #ffffff;
	text-transform: none;
	font-weight: 300;
}

.footer a {
	color: #ffffff;
}

.footer a:hover {
	text-decoration: underline;
}

.footer a.menu {
	color: #ffffff;
	text-transform: uppercase;
	font-weight: 700;
	text-align: right;
}

.footer a.menu:hover {
	color: #dedede;
	font-weight: 700;
	text-decoration: none	;
}



.subfooter p {
	font-size: 12px;
	color: #58585a;
}

.subfooter a {
	color: #58585a;
}

.subfooter a:hover {
	color: #000;
	text-decoration: none;

}

/*------------ RESPONSIVE MEDIA ------------*/

@media (max-width: 575px) {

}

@media (min-width: 576px) and (max-width: 767px) {
	
}

@media (min-width: 576px) {}

@media (min-width: 768px) {}

@media (min-width: 768px) and (max-width: 991px) {

}

@media (min-width: 992px) and (max-width: 1199px) {
}

@media (min-width: 1200px) {}

@media (min-width: 576px) {}

@media (min-width: 992px) {}

@media (max-width: 991px) {
}

@media (max-width: 1199px) {
}
