﻿body { font-family: 'Raleway', sans-serif; font-weight: 400; }
ol, ul, li { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; }
ol, ul { list-style: none; }
/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
.padding_1percent { padding: 0 1% !important; }
/* Webfonts type ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
.Font-light {  font-weight:300;}
.Font-medium {  font-weight:400; }
.Font-bold,strong,b { font-weight: 600; }
/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
/* General Font Color ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
.Font-Color-CI-01 { color: #919191; }
.Font-Color-CI-02 { color: #989898; }
.Font-Color-fff { color: #ffffff; }
.Font-Color-000 { color: #000; }
.Font-Color-orange { color: #f26531; }
/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/

/* General Background colors ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
.Background-Color-CI-01 { background-color: #1d398d; }
.Background-Color-CI-02 { background-color: #474045; }
.Background-Color-fff { background-color: #ffffff; }
.Background-Color-ddd { background-color: #ddd; }
.Background-Color-b3b { background-color: #B3B0B3; }
.grey { color: #666; }
/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/

/*rules of behavior on the HTML standard~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
a { color: inherit; text-decoration: inherit; font-family: inherit; }
.clear { clear: both; }
/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/


/*Pulsanti*/
.button { text-transform: uppercase; padding: 15px 20px; font-size: 1.125rem; text-align: center; }
	.button.btn_wht { background-color: #fff; color: #666; box-shadow: 0 0 6px rgba(0,0,0,.3); }

/**/

/*rules~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
.Text-Transform-Uppercase { text-transform: uppercase; }
/**/
.Text-Align-Left { text-align: left; }
.Text-Align-Right { text-align: right; }
.Text-Align-Center { text-align: center; }
.Text-Align-Justify { text-align: justify; }
/**/
.Italic { font-style: italic; }
/**/
.inline-block { display: inline-block; }
.D-None { display: none; }
/**/
.Line-Height-normal { line-height: normal; }
.Line-Height-0 { line-height: 0.650rem; }
.Line-Height-1 { line-height: 0.750rem; }
.Line-Height-2 { line-height: 0.813rem; }
.Line-Height-3 { line-height: 0.875rem; }
.Line-Height-4 { line-height: 0.938rem; }
.Line-Height-5 { line-height: 1rem; }
.Line-Height-6 { line-height: 1.125rem; }
.Line-Height-7 { line-height: 1.250rem; }
.Line-Height-8 { line-height: 1.375rem; }
.Line-Height-9 { line-height: 1.500rem; }
.Line-Height-10 { line-height: 2rem; }
.Line-Height-11 { line-height: 2.2rem; }
.Line-Height-12 { line-height: 2.4rem; }
.Line-Height-13 { line-height: 2.6rem; }
.Line-Height-14 { line-height: 2.8rem; }
.Line-Height-15 { line-height: 3rem; }
.Line-Height-16 { line-height: 3.5rem; }
.Line-Height-17 { line-height: 4rem; }
.Line-Height-18 { line-height: 4.5rem; }
.Line-Height-19 { line-height: 5rem; }
.Line-Height-20 { line-height: 5.5rem; }

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/

/*COOKIES*/
.cookies { position: fixed; z-index: 99999999999999; width: 100%; text-align: center; background-color: rgba(38,50,56,0.7); bottom: 0; right: 0; height: auto; padding: 10px 5px; display: none; border-top: solid 2px #fff; }
	.cookies .title { font-size: 14px; color: #e6e6e6; font-weight: normal; margin: 5px 0; }
	.cookies .text { font-size: 11px; color: #fff; }
	.cookies a { font-size: 11px; color: #263238; }
.button_cookies { background-color: #fff; padding: 5px 20px; }
/**/
.underline { text-decoration: underline !important; }

/* Custom, iPhone Retina */
@media only screen and (min-width : 320px) and (max-width : 767.999px) {
	body { margin: 0; font-size: 1rem; overflow-x: hidden; }
	/**/
	.separatore { position: relative; display: block; clear: both; height: 10px; margin: 20px 0; }
		.separatore .cover-separatore { visibility: hidden; }
			.separatore .cover-separatore .CornerLeft { width: 0; height: 0; border-style: solid; border-width: 0 0 10px 12px; border-color: transparent transparent #1d398d transparent; position: absolute; left: -12px; top: 0; }
			.separatore .cover-separatore .Center { background-color: #1d398d; height: 10px; width: 70px; position: relative; margin: 0 auto; }
			.separatore .cover-separatore .CornerRight { width: 0; height: 0; border-style: solid; border-width: 10px 12px 0 0; border-color: #1d398d transparent transparent transparent; position: absolute; right: -12px; top: 0; }
	/**/

	/* Font Size ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
	.Font-Size-0 { font-size: 0.650rem; }
	.Font-Size-1 { font-size: 0.750rem; }
	.Font-Size-2 { font-size: 0.813rem; }
	.Font-Size-3 { font-size: 0.875rem; }
	.Font-Size-4 { font-size: 0.938rem; }
	.Font-Size-5 { font-size: 1rem; }
	.Font-Size-6 { font-size: 1.125rem; }
	.Font-Size-7 { font-size: 1.250rem; }
	.Font-Size-8 { font-size: 1.300rem; }
	.Font-Size-9 { font-size: 1.450rem; }
	.Font-Size-10 { font-size: 1.5rem; }
	.Font-Size-11 { font-size: 1.2rem; }
	.Font-Size-12 { font-size: 1.4rem; }
	.Font-Size-13 { font-size: 1.6rem; }
	.Font-Size-14 { font-size: 1.8rem; }
	.Font-Size-15 { font-size: 2rem; }
	.Font-Size-16 { font-size: 2.5rem; }
	.Font-Size-17 { font-size: 3rem; }
	.Font-Size-18 { font-size: 3.5rem; }
	.Font-Size-19 { font-size: 4rem; }
	.Font-Size-20 { font-size: 5rem; }
	.Font-Size-21 { font-size: 6rem; }
	.Font-Size-22 { font-size: 7rem; }
	.Font-Size-23 { font-size: 8rem; }
	.Font-Size-24 { font-size: 9rem; }
	.Font-Size-25 { font-size: 10rem; }
	/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
	/**/
	.tipologiasrch { display: flex !important; justify-content: space-between !important; flex-wrap:wrap; }
		.tipologiasrch .item {
			text-align: center;
			background-color: #bbb;
			width: 100%;
			color: #ffffff;
			font-size: 14px;
			padding: 5px;
			margin: 2px;
			flex: 0 1 43%;
		}
			.tipologiasrch .item:hover { background-color: #f26531; transition: .5s ease-in-out; }
			.tipologiasrch .item.active { background-color: #f26531; padding: 5px; }
			.tipologiasrch .item i { }

	/**/
	.mobiledisplaynone { display: none !important; }
	.desktopdisplaynone { display: unset; }
	/**/
	.socialbar { position: fixed; left: 0 !important; right: 0 !important; bottom: 5px; transform: none !important; z-index: 99; display: flex; flex-direction: row; background-color: rgba(255,255,255,0.8); padding: 3px 10px; align-items: center; justify-content: space-around; }
		.socialbar i { font-size: 30px !important; margin: 0 5px; }

}

/* Small Devices, Tablets */
@media only screen and (min-width : 768px) and (max-width : 1379.999px) {
	.head_space { position: relative; width: 100%; }
	/* Font Size ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
	.Font-Size-0 { font-size: 0.650rem; }
	.Font-Size-1 { font-size: 0.750rem; }
	.Font-Size-2 { font-size: 0.813rem; }
	.Font-Size-3 { font-size: 0.875rem; }
	.Font-Size-4 { font-size: 0.938rem; }
	.Font-Size-5 { font-size: 1rem; }
	.Font-Size-6 { font-size: 1.125rem; }
	.Font-Size-7 { font-size: 1.250rem; }
	.Font-Size-8 { font-size: 1.375rem; }
	.Font-Size-9 { font-size: 1.500rem; }
	.Font-Size-10 { font-size: 2rem; }
	.Font-Size-11 { font-size: 2.2rem; }
	.Font-Size-12 { font-size: 2.4rem; }
	.Font-Size-13 { font-size: 2.6rem; }
	.Font-Size-14 { font-size: 2.8rem; }
	.Font-Size-15 { font-size: 3rem; }
	.Font-Size-16 { font-size: 3.5rem; }
	.Font-Size-17 { font-size: 4rem; }
	.Font-Size-18 { font-size: 4.5rem; }
	.Font-Size-19 { font-size: 5rem; }
	.Font-Size-20 { font-size: 6rem; }
	.Font-Size-21 { font-size: 7rem; }
	.Font-Size-22 { font-size: 8rem; }
	.Font-Size-23 { font-size: 9rem; }
	.Font-Size-24 { font-size: 10rem; }
	.Font-Size-25 { font-size: 11rem; }

	/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/

	/**/
	body { margin: 0; font-size: 1rem;color: #111; }
	/**/
	.separatore { position: relative; display: block; clear: both; height: 10px; margin: 20px 0; }
		.separatore .cover-separatore { width: 70px; position: relative; margin: 0 auto; }
			.separatore .cover-separatore .CornerLeft { width: 0; height: 0; border-style: solid; border-width: 0 0 10px 12px; border-color: transparent transparent #1d398d transparent; position: absolute; left: -12px; top: 0; }
			.separatore .cover-separatore .Center { background-color: #1d398d; height: 10px; width: 70px; position: relative; margin: 0 auto; }
			.separatore .cover-separatore .CornerRight { width: 0; height: 0; border-style: solid; border-width: 10px 12px 0 0; border-color: #1d398d transparent transparent transparent; position: absolute; right: -12px; top: 0; }
	/**/
	.header { background-repeat: no-repeat; background-position: right -100px center; background-size: contain; /*background-image: url('/img/bghead.jpg');*/ }
	/**/
	.tipologiasrch { display: flex !important; justify-content: space-between !important; flex-wrap:wrap }
		.tipologiasrch .item { text-align: center; background-color: #bbb; width: 100%; color: #ffffff; font-size: 14px; padding: 5px; margin:2px;flex: 0 1 31%; }
			.tipologiasrch .item:hover { background-color: #f26531; transition: .5s ease-in-out; }
			.tipologiasrch .item.active { background-color: #f26531; padding: 5px; }
			.tipologiasrch .item i { }


	/**/
	.mobiledisplaynone { display: unset; }
	.desktopdisplaynone { display: none !important; }

}

/* Large Devices, Wide Screens */
@media only screen and (min-width : 1380px) {
	.head_space { position: relative; width: 100%; height: 32px; }
	/* Font Size ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
	.Font-Size-0 { font-size: 0.650rem; }
	.Font-Size-1 { font-size: 0.750rem; }
	.Font-Size-2 { font-size: 0.813rem; }
	.Font-Size-3 { font-size: 0.875rem; }
	.Font-Size-4 { font-size: 0.938rem; }
	.Font-Size-5 { font-size: 1rem; }
	.Font-Size-6 { font-size: 1.125rem; }
	.Font-Size-7 { font-size: 1.250rem; }
	.Font-Size-8 { font-size: 1.375rem; }
	.Font-Size-9 { font-size: 1.500rem; }
	.Font-Size-10 { font-size: 2rem; }
	.Font-Size-11 { font-size: 2.2rem; }
	.Font-Size-12 { font-size: 2.4rem; }
	.Font-Size-13 { font-size: 2.6rem; }
	.Font-Size-14 { font-size: 2.8rem; }
	.Font-Size-15 { font-size: 3rem; }
	.Font-Size-16 { font-size: 3.5rem; }
	.Font-Size-17 { font-size: 4rem; }
	.Font-Size-18 { font-size: 4.5rem; }
	.Font-Size-19 { font-size: 5rem; }
	.Font-Size-20 { font-size: 6rem; }
	.Font-Size-21 { font-size: 7rem; }
	.Font-Size-22 { font-size: 8rem; }
	.Font-Size-23 { font-size: 9rem; }
	.Font-Size-24 { font-size: 10rem; }
	.Font-Size-25 { font-size: 11rem; }
	/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/

	/**/
	body { margin: 0; font-size: 1rem;  color: #111; }
	/**/
	.separatore { position: relative; display: block; clear: both; height: 10px; margin: 20px 0; }
		.separatore .cover-separatore { width: 70px; position: relative; margin: 0 auto; }
			.separatore .cover-separatore .CornerLeft { width: 0; height: 0; border-style: solid; border-width: 0 0 10px 12px; border-color: transparent transparent #1d398d transparent; position: absolute; left: -12px; top: 0; }
			.separatore .cover-separatore .Center { background-color: #1d398d; height: 10px; width: 70px; position: relative; margin: 0 auto; }
			.separatore .cover-separatore .CornerRight { width: 0; height: 0; border-style: solid; border-width: 10px 12px 0 0; border-color: #1d398d transparent transparent transparent; position: absolute; right: -12px; top: 0; }
	/**/
	.header { /*background-image: url('/img/bghead.jpg');*/ background-repeat: no-repeat; background-position: right -100px center; }
	/**/
	.tipologiasrch { display: flex; justify-content: space-between; flex-wrap:wrap; }
		.tipologiasrch .item {
			text-align: center;
			background-color: #bbb;
			width: 100%;
			color: #ffffff;
			font-size: 14px;
			padding: 5px;
			margin: 2px;flex: 0 1 43%;
		}
			.tipologiasrch .item:hover { background-color: #f26531; transition: .5s ease-in-out; }
			.tipologiasrch .item.active { background-color: #f26531; padding:5px; }
			.tipologiasrch .item i { }
	/**/
	.mobiledisplaynone { display: unset; }
	.desktopdisplaynone { display: none !important; }
}
/* RandomTextEffects*/
.RandomTextEffect-01 { animation-duration: 1s; animation-fill-mode: both; animation-timing-function: linear; animation-iteration-count: infinite; animation-name: bounceRandomTextEffect-01; }

@keyframes bounceRandomTextEffect-01 {
	0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
	40% { transform: translateY(-5px); }
	60% { transform: translateY(-1px); }
}

.RandomTextEffect-02:hover { animation-duration: 1s; animation-fill-mode: both; animation-name: pulsehover; }

@keyframes pulsehover {
	0% { transform: scale(1); }
	100% { transform: scale(1.05); text-rendering: optimizeLegibility; image-rendering: optimizeQuality; }
}

.RandomTextEffect-03 { animation-duration: 1s; animation-fill-mode: both; animation-iteration-count: infinite; animation-name: tadabutton; }

@keyframes tadabutton {
	0% { transform: scale(1); }
	10%, 20% { transform: scale(0.9) rotate(-3deg); }
	30%, 50%, 70%, 90% { transform: scale(1.1) rotate(3deg); box-shadow: 0 0 100px rgba(0,0,0,0.7); }
	40%, 60%, 80% { transform: scale(1.1) rotate(-3deg); }
	100% { transform: scale(1) rotate(0); }
}

/**/
.backbutton { padding: 5px 10px !important; width: auto; }
/**/
span.pref-btn { position: absolute; top: 10px; right: 10px; }
.dettaglio i.fas { width: 25px; }
/**/
.bottom-menu { height: 50px !important; }
/**/
.socialbar { position: fixed; left: 50%; bottom: 5px; transform: translate(-50%,0); z-index: 99; display: flex; flex-direction: row; background-color: rgba(255,255,255,0.8); padding: 3px 10px; align-items: center; }
	.socialbar i { font-size: 25px; margin: 0 5px; }
.buttoncontatti { padding: 4px 5px; margin: 0 5px; }
/**/
.caption {
	position: absolute;
	z-index: 9;
	width: 300px;
	padding: 16px;
	background-color: rgba(255,255,255,.95);
	border-radius: 10px;
	right: 10px;
	top: 50%;
	transform: translate(0,-50%);
	box-sizing: border-box;
}

	.caption .title {
		font-weight: 700;
		font-size: 20px;
		text-align: left;
	}

	.caption .text {
		font-size: 14px;
		text-align: left;
		margin: 10px 0;
		font-weight: 400;
	}

	.caption .ButtonRule {
		display: block;
		width: 100%;
		position: relative;
		background-color: #f0b00d;
		color: #fff;
		width: 90%;
		padding: 10px;
		text-align: center;
		font-weight: bold;
	}

.allegato {
	background-color: orange;
	width: 35%;
	padding: 10px;
	color: #fff;
	font-weight:bold;
}

.ButtonRule2 { display: flex; }


@media screen and (width: 1024px) and (height: 768px) {
	.caption {
		top: 25%;
	}
}

@media screen and (width: 768px) and (height: 1024px) {

	.caption {
		top: 25%;
	}
}

@media screen and (width: 820px) and (height: 1180px) {
	.caption {
		top: 25%;
	}
}