@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
@font-face {
  font-family: 'Satoshi';
  src: url('../fonts/Satoshi-Variable.woff2') format('woff2'),
       url('../fonts/Satoshi-Variable.woff') format('woff'),
       url('../fonts/Satoshi-Variable.ttf') format('truetype');
  font-weight: 300 900;
  font-display: swap;
  font-style: normal;
}
/**
* This is a variable font
* You can control variable axes as shown below:
* font-variation-settings: wght 900.0;
*
* available axes:
'wght' (range from 300.0 to 900.0
*/
@font-face {
  font-family: 'Satoshi-Italic';
  src: url('../fonts/Satoshi-VariableItalic.woff2') format('woff2'),
       url('../fonts/Satoshi-VariableItalic.woff') format('woff'),
       url('../fonts/Satoshi-VariableItalic.ttf') format('truetype');
  font-weight: 300 900;
  font-display: swap;
  font-style: italic;
}
@font-face {
    font-family: 'OCR A Std';
    src: url('../fonts/OCRAStd.eot');
    src: local('OCR A Std'), local('OCRAStd'),
        url('../fonts/OCRAStd.eot?#iefix') format('embedded-opentype'),
        url('../fonts/OCRAStd.woff2') format('woff2'),
        url('../fonts/OCRAStd.woff') format('woff'),
        url('../fonts/OCRAStd.ttf') format('truetype'),
        url('../fonts/OCRAStd.svg#OCRAStd') format('svg');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}


:root{
	--colorWhite: #F8F8F8;
	--colorWhite2: #EEEEEF;
	--colorWhite2Transparent: #EEEEEFA2;
	--colorBlack: #030404;
	--colorBlackTransparent: #030404E1;
	--colorHover: #D95400;
	--colorCaricamento: #F26100;
}

* {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font-family: 'Satoshi', sans-serif;
	word-spacing: 0;
	letter-spacing: 0;
	text-shadow: rgba(0, 0, 0, .01) 0 0 1px;
	-webkit-font-smoothing: antialiased
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block
}

body {
	line-height: 1
}

ol,
ul {
	list-style: none
}

blockquote,
q {
	quotes: none
}

blockquote:after,
blockquote:before,
q:after,
q:before {
	content: '';
	content: none
}

div{
	font-size: 0;
	line-height: 0;
}

img {
	vertical-align: middle
}

table {
	border-collapse: collapse;
	border-spacing: 0
}
td{
	padding: 5px 10px;
	border: solid 1px #0000001D;
}

span {
	vertical-align: baseline
}

::-webkit-scrollbar {
	width: 4px;
	height: 4px;
	background-color: #FEFAFE00
}

::-webkit-scrollbar-thumb {
	border-radius: 2px;
	background-color: #F26100
}

body,
html {
	margin: 0;
	padding: 0;
	text-align: center;
	width: 100%;
	height: 100%;
	font-family: 'Satoshi', sans-serif;
	color: #030404;
	background-color: #F8F8F8;
}

body {
	min-width: 1024px
}

img {
	position: relative;
	display: inline-block;
}

.img{
	width: 90%;
	margin: 0 5%;
	width: calc(100% - 40px);
	margin: 0 calc(20px);
}
.img.with_padding{
	padding: 10px;
	width: calc(100% - 60px);
}

@media screen and (min-width:10px) {
	body {
		min-width: 10px
	}
}

a {
	letter-spacing: 1px;
	text-decoration: none;
	color: #F26100;
	font-family: inherit
}

a:visited {
	color: #F26100
}

a:hover, a.ishover {
	color: #D95400;
	text-decoration: underline;
}

h1,h2,h3,h4,h5,h6,p,span,b,i,label{
	position: relative;
	letter-spacing: 1px;
}
p,label{
	position: relative;
	font-family: 'Satoshi', sans-serif;
}
.special{
	font-family: 'OCR A Std', monospace;
}

h1,h2,h3,h4,h5,h6{
	font-family: 'Satoshi', sans-serif;
	letter-spacing: -1px;
	color: #030404;
}

span,b,i{
	position: relative;
	font-family: inherit;
}

h1,h2,h3,h4,h5,h6,p{
	padding: 0 20px;
	text-align: left;
	color: #030404;
}
label{
	font-style: italic;
	padding: 0 10px;
}

h1{
	font-size: 54px;
	line-height: 60px;
	font-weight: 800;
}
h2,h3{
	font-size: 42px;
	line-height: 46px;
	font-weight: 800;
}
h3{
	font-family: 'Satoshi', sans-serif;
	font-weight: 800;
	letter-spacing: 1px;
}
h4{
	font-size: 32px;
	line-height: 36px;
	font-weight: 800;
	letter-spacing: 1px;
	font-family: 'Satoshi', sans-serif;
}
h5,h6{
	font-size: 24px;
	line-height: 28px;
	font-weight: 600;
	letter-spacing: 1px;
	font-family: 'Satoshi', sans-serif;
}
p {
	font-size: 14px;
	line-height: 22px;
	font-weight: 500;
	color: #6F7070;
}
label {
	font-size: 14px;
	line-height: 20px;
	font-weight: 400;
}
p.small {
	font-size: 12px;
	line-height: 16px;
}
p.desc_bigger {
	font-size: 22px;
	line-height: 1.2em;
}
p.line_bigger {
	line-height: 1.5em;
}

span{
	font-size: inherit;
	line-height: inherit;
	font-weight: inherit;
}

b{
	font-weight: 800;
}

.riga {
	position: relative;
	top: 0;
	left: 0;
	display: block;
	width: 100%
}
/*.riga::before{
	content: '';
	position: absolute;
	width: 100%;
	height: 20px;
	top: 0; left: 0;
	background: linear-gradient(180deg, #FFFFFF76 0%, #FFFFFF00 100%);
}
.riga::before{
	content: '';
	position: absolute;
	width: 100%;
	height: 60px;
	bottom: 0; left: 0;
	background: linear-gradient(0deg, #00000006 0%, #00000000 100%);
}*/

.prima_riga{
	padding-top: 60px;
}

.cont {
	position: relative;
	width: 100%;
	margin: auto;
	padding: 60px 0;
	display: block;
	max-width: 1680px
}
@media screen and (min-height: 840px){
	.cont{
		padding: 90px 0;
	}
}

.counter_cont{
	margin: -60px 0;
}
.counter_cont_top{
	margin-top: -60px;
}
.counter_cont_bottom{
	margin-bottom: -60px;
}

.cont2 {
	width: 90%;
	width: calc(100% - 120px);
}

.imm_full {
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat
}

.imm_full.top {
	background-position: top
}

.col{
	position: relative;
	display: inline-block;
	width: 100%;
	vertical-align: middle;
	font-size: 0;
	line-height: 0;
}
.col1{
	width: 8.33%;
}
.col2{
	width: 16.66%;
}
.col3{
	width: 25%;
}
.col4{
	width: 33.33%;
}
.col5{
	width: 41.66%;
}
.col6{
	width: 50%;
}
.col7{
	width: 58.33%;
}
.col8{
	width: 66.66%;
}
.col9{
	width: 75%;
}
.col10{
	width: 83.33%;
}
.col11{
	width: 91.66%;
}

@media screen and (max-width: 1280px){
	.col_med{
		width: 100%;
	}
	.col1_med{
		width: 8.33%;
	}
	.col2_med{
		width: 16.66%;
	}
	.col3_med{
		width: 25%;
	}
	.col4_med{
		width: 33.33%;
	}
	.col5_med{
		width: 41.66%;
	}
	.col6_med{
		width: 50%;
	}
	.col7_med{
		width: 58.33%;
	}
	.col8_med{
		width: 66.66%;
	}
	.col9_med{
		width: 75%;
	}
	.col10_med{
		width: 83.33%;
	}
	.col11_med{
		width: 91.66%;
	}
}

.t_align_center {
	text-align: center
}

.t_align_right {
	text-align: right
}

.t_align_left {
	text-align: left
}

.t_align_justify {
	text-align: justify
}

@media screen and (max-width: 1270px){
	.cont2 {
		width: 90%;
		width: calc(100% - 120px);
	}
}

@media screen and (max-width: 1024px){
	.cont{
		padding: 60px 0;
	}
	.cont2 {
		width: 100%;
	}
	.prima_riga{
		padding-top: 60px;
	}
}
.show_small, .show_extra_small, .show_thumb, .show_large{
	display: none;
}
@media screen and (max-width: 756px){
	.col_small{
		width: 100%;
	}
	.col1_small{
		width: 8.33%;
	}
	.col2_small{
		width: 16.66%;
	}
	.col3_small{
		width: 25%;
	}
	.col4_small{
		width: 33.33%;
	}
	.col5_small{
		width: 41.66%;
	}
	.col6_small{
		width: 50%;
	}
	.col7_small{
		width: 58.33%;
	}
	.col8_small{
		width: 66.66%;
	}
	.col9_small{
		width: 75%;
	}
	.col10_small{
		width: 83.33%;
	}
	.col11_small{
		width: 91.66%;
	}
	.t_align_center_small {
		text-align: center
	}

	.t_align_right_small {
		text-align: right
	}

	.t_align_left_small {
		text-align: left
	}

	.t_align_justify_small {
		text-align: justify
	}
	.hide_small{
		display: none;
	}
	.show_small{
		display: inline-block;
	}
	h1{
		font-size: 42px;
		line-height: 46px;
	}
	h2,h3{
		font-size: 33px;
		line-height: 37px;
	}
	h4,h5,h6{
		font-size: 20px;
		line-height: 24px;
	}
}

@media screen and (max-width: 540px){
	.col_extra_small{
		width: 100%;
	}
	.col1_extra_small{
		width: 8.33%;
	}
	.col2_extra_small{
		width: 16.66%;
	}
	.col3_extra_small{
		width: 25%;
	}
	.col4_extra_small{
		width: 33.33%;
	}
	.col5_extra_small{
		width: 41.66%;
	}
	.col6_extra_small{
		width: 50%;
	}
	.col7_extra_small{
		width: 58.33%;
	}
	.col8_extra_small{
		width: 66.66%;
	}
	.col9_extra_small{
		width: 75%;
	}
	.col10_extra_small{
		width: 83.33%;
	}
	.col11_extra_small{
		width: 91.66%;
	}
	.t_align_center_extra_small {
		text-align: center
	}

	.t_align_right_extra_small {
		text-align: right
	}

	.t_align_left_extra_small {
		text-align: left
	}

	.t_align_justify_extra_small {
		text-align: justify
	}
	.hide_extra_small{
		display: none;
	}
	.show_extra_small{
		display: inline-block;
	}
	.cont2 {
		width: 100%;
		max-width: 100%
	}
	.prima_riga{
		padding-top: 60px;
	}
	.cont {
		padding: 60px 0;
	}
	.counter_cont{
		margin: -60px 0;
	}
	.counter_cont_top{
		margin-top: -60px;
	}
	.counter_cont_bottom{
		margin-bottom: -60px;
	}
}

@media screen and (max-width: 320px){
	.col_thumb{
		width: 100%;
	}
	.col1_thumb{
		width: 8.33%;
	}
	.col2_thumb{
		width: 16.66%;
	}
	.col3_thumb{
		width: 25%;
	}
	.col4_thumb{
		width: 33.33%;
	}
	.col5_thumb{
		width: 41.66%;
	}
	.col6_thumb{
		width: 50%;
	}
	.col7_thumb{
		width: 58.33%;
	}
	.col8_thumb{
		width: 66.66%;
	}
	.col9_thumb{
		width: 75%;
	}
	.col10_thumb{
		width: 83.33%;
	}
	.col11_thumb{
		width: 91.66%;
	}
	.hide_thumb{
		display: none;
	}
	.show_thumb{
		display: inline-block;
	}
	.t_align_center_thumb {
		text-align: center
	}

	.t_align_right_thumb {
		text-align: right
	}

	.t_align_left_thumb {
		text-align: left
	}

	.t_align_justify_thumb {
		text-align: justify
	}
}

@media screen and (min-width: 1440px){
	.col_large{
		width: 100%;
	}
	.col1_large{
		width: 8.33%;
	}
	.col2_large{
		width: 16.66%;
	}
	.col3_large{
		width: 25%;
	}
	.col4_large{
		width: 33.33%;
	}
	.col5_large{
		width: 41.66%;
	}
	.col6_large{
		width: 50%;
	}
	.col7_large{
		width: 58.33%;
	}
	.col8_large{
		width: 66.66%;
	}
	.col9_large{
		width: 75%;
	}
	.col10_large{
		width: 83.33%;
	}
	.col11_large{
		width: 91.66%;
	}
	.hide_large{
		display: none;
	}
	.show_large{
		display: inline-block;
	}
	.t_align_center_large {
		text-align: center
	}

	.t_align_right_large {
		text-align: right
	}

	.t_align_left_large {
		text-align: left
	}

	.t_align_justify_large {
		text-align: justify
	}
	/*h1{
		font-size: 42px;
		line-height: 55px;
	}
	h2,h3{
		font-size: 28px;
		line-height: 38px;
	}
	h4,h5,h6{
		font-size: 24px;
		line-height: 31px;
	}*/
	p {
		font-size: 16px;
		line-height: 22px;
	}
	p.small {
		font-size: 12px;
		line-height: 14px;
	}
	.cont2 {
		width: 90%;
		width: calc(100% - 120px);
	}
}

.box_shadow{
	background-color: #FFFFFF;
	border-radius: 6px;
	box-shadow: 0 8px 16px 0 #00000020;
	overflow: hidden;
}

.button {
	position: relative;
	display: inline-block;
	padding: 12px 24px;
	margin: 20px;
	color: #FFFFFF;
	background-color: #F26100;
	font-family: 'Satoshi', sans-serif;
	text-transform: uppercase;
	font-weight: 600;
	font-size: 14px;
	line-height: 16px;
	left: 0;
	opacity: 1;
	text-align: center;
	cursor: pointer;
	border: solid 1px #F26100;
	border-radius: 4px;
	text-decoration: none;
	vertical-align: middle;
	
	transform: scale(1);
	-o-transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out, border-color .3s ease-out;
	-ms-transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out, border-color .3s ease-out;
	-moz-transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out, border-color .3s ease-out;
	-webkit-transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out, border-color .3s ease-out;
	transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out, border-color .3s ease-out;
}

.button.small {
	padding: 8px 12px;
	font-size: 12px;
	line-height: 12px;
}

.button:visited {
	color: #FFFFFF;
	background-color: #F26100;
	border: solid 1px #F26100;
	text-decoration: none;
}
.button:hover, .button.ishover {
	color: #FFFFFF;
	background-color: #D95400;
	border: solid 1px #F26100;
	text-decoration: none;
}

.button.green{
	color: #FFFFFF;
	background-color: #1A4F43;
	border: solid 1px #FFFFFF;
}

.button.green:visited{
	color: #FFFFFF;
	background-color: #1A4F43;
	border: solid 1px #FFFFFF;
}

.button.green:hover, .button.green.ishover{
	color: #FFFFFF;
	background-color: #DFA514;
	border: solid 1px #DFA514;
}

.button.grande{
	font-size: 24px;
	line-height: 32px;
	padding: 14px 45px;
}

.button.white {
	color: #3158FF;
	background-color: #FFFFFF;
}

.button.white:visited {
	color: #3158FF;
	background-color: #FFFFFF;
}
.button.white:hover, .button.white.ishover {
	color: #FFFFFF;
	background-color: #3158FF;
}

.button.orange {
	color: #FF7131;
	background-color: #FFFFFF;
}

.button.orange:visited {
	color: #FF7131;
	background-color: #FFFFFF;
}
.button.orange:hover, .button.orange.ishover {
	color: #FFFFFF;
	background-color: #FF7131;
}

.button.orange_full {
	color: #FFFFFF;
	background-color: #FF7131;
}

.button.orange_full:visited {
	color: #FFFFFF;
	background-color: #FF7131;
}
.button.orange_full:hover, .button.orange_full.ishover {
	color: #FF7131;
	background-color: #FFFFFF;
}

.button.green_full {
	color: #FFFFFF;
	background-color: #00CB51;
}

.button.green_full:visited {
	color: #FFFFFF;
	background-color: #00CB51;
}
.button.green_full:hover, .button.green_full.ishover {
	color: #00CB51;
	background-color: #FFFFFF;
}

.button.disabled, .button:disabled{
	color: #EBEBEB;
	background-color: #C2C2C2;
	border: solid 1px #C2C2C2;
	cursor: not-allowed;
}

.button.disabled:hover, .button:disabled:hover{
	color: #EBEBEB;
	background-color: #C2C2C2;
	border: solid 1px #C2C2C2;
}

.button .rot{
	display: inline-block;
	transform: rotate(0deg);
	
	-o-transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out;
	-ms-transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out;
	-moz-transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out;
	-webkit-transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out;
	transition: color .3s ease-out, background-color .3s ease-out, background-position .3s ease-out, transform .3s ease-out
}
.button:hover .rot, .button.ishover .rot{
	transform: rotate(90deg);
}

.button .left_push{
	display: inline-block;
	margin-right: 20px;
	left: 0;
	
	-o-transition: left .3s ease-out, opacity .3s ease-out;
	-ms-transition: left .3s ease-out, opacity .3s ease-out;
	-moz-transition: left .3s ease-out, opacity .3s ease-out;
	-webkit-transition: left .3s ease-out, opacity .3s ease-out;
	transition: left .3s ease-out, opacity .3s ease-out
}
.button .left_push .hover{
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	
	-o-transition: left .3s ease-out, opacity .3s ease-out;
	-ms-transition: left .3s ease-out, opacity .3s ease-out;
	-moz-transition: left .3s ease-out, opacity .3s ease-out;
	-webkit-transition: left .3s ease-out, opacity .3s ease-out;
	transition: left .3s ease-out, opacity .3s ease-out
}
.button:hover .left_push, .button.ishover .left_push{
	left: 5px;
}
.button:hover .left_push .hover, .button.ishover .left_push .hover{
	opacity: 1;
}


.input {
	-webkit-appearance: none;
	-webkit-border-radius: 0;
	position: relative;
	display: inline-block;
	width: 90%;
	margin: 5%;
	padding: 5px 5px;
	width: calc(100% - 62px);
	margin: calc(10px) calc(20px);
	padding: calc(11px) calc(10px);
	font-size: 14px;
	line-height: 16px;
	font-family: 'Satoshi', sans-serif;
	letter-spacing: 1px;
	background: none;
	border: solid 1px #C2C2C2;
	border-radius: 4px;
	color: #000000;
	background-color: #FFFFFF;
}
.input2 {
	width: calc(100% - 42px);
	margin: calc(10px) calc(10px);
}
.input3 {
	width: calc(100% - 32px);
	margin: calc(5px) calc(5px);
}

.input::placeholder {
	color: #C2C2C2
}

.input:-internal-autofill-selected{
	background-color: #FFFFFF !important;
}

.input:-webkit-autofill {
	font-size: 14px;
	line-height: 16px;
}

.input:focus {
	-webkit-appearance: none;
    -webkit-border-radius: 23;
    border: solid 1px #3395BB;
	/*box-shadow: 0 0 16px 0 #0000002D;*/
    outline: none;
}

select.input {
	background-image: url(../imm/icons/blue/icon_down.svg);
	background-size: 30px 30px;
	background-repeat: no-repeat;
	background-position: right;
	padding-right: 25px;
	width: calc(100% - 40px);
}

select.input2 {
	background-image: url(../imm/icons/blue/icon_down.svg);
	background-size: 30px 30px;
	background-repeat: no-repeat;
	background-position: right;
	padding-right: 25px;
	width: calc(100% - 20px);
}

textarea.input {
	min-height: 80px;
	height: 280px;
	resize: vertical
}

select.input_with_label{
	line-height: 20px;
}
.input_with_label{
	background-color: white;
	padding-top: 18px;
	border-radius: 4px;
}
.input_with_label::placeholder {
	color: #70707000;
}
.input_with_label + label{
	font-style: normal;
	position: absolute;
	top: 26px;
	left: 12px;
	line-height: 1em;
	padding: 0 6px;
	cursor: text;
	font-family: 'Satoshi', sans-serif;
	color: #707070;

	-o-transition: top .2s ease-out, font-size .2s ease-out, color .2s ease-out;
	-ms-transition: top .2s ease-out, font-size .2s ease-out, color .2s ease-out;
	-moz-transition: top .2s ease-out, font-size .2s ease-out, color .2s ease-out;
	-webkit-transition: top .2s ease-out, font-size .2s ease-out, color .2s ease-out;
	transition: top .2s ease-out, font-size .2s ease-out, color .2s ease-out;
}
.input3.input_with_label + label{
	left: 7px;
	top: 21px;
}
.input_with_label:focus + label, .input_with_label:not(:placeholder-shown) + label, .input_with_label:-webkit-autofill + label{
	top: 16px;
	font-size: 10px;
	background-color: #FFFFFF;
	color: #C2C2C2;
}
.input3.input_with_label:focus + label, .input3.input_with_label:not(:placeholder-shown) + label, .input3.input_with_label:-webkit-autofill + label{
	top: 12px;
	font-size: 10px;
	color: #C2C2C2;
}
.input_with_label:invalid:not(:placeholder-shown):not(:-webkit-autofill) {
	border-color: crimson;
}
.input_with_label:valid:not(:placeholder-shown), .input_with_label:-webkit-autofill {
	border-color: #00CB51;
}

.middle_align {
	position: relative;
	display: inline-block;
	height: 100%;
	width: 2px;
	vertical-align: middle;
	margin: 0 -1px;
}

.err_mex{
	position: relative;
	display: inline-block;
	padding: 10px 0px;
	width: calc(100% - 40px);
	margin: calc(10px) calc(20px);
	border-radius: 0;
	top: 0px;
	opacity: 1;
	background-color: #CF544D;
	box-shadow: 0 0 18px 0 #0000001D;
}
.err_mex p{
	color: white;
	padding: 0 20px;
}
.err_mex p:first-child{
	color: white;
	margin-bottom: 5px;
	font-weight: 500;
}
.col_with_margin{
	width: 90%;
	margin: 0 5%;
	width: calc(100% - 40px);
	margin: 0 calc(20px);
}
.col_with_small_margin{
	width: 94%;
	margin: 0 3%;
	width: calc(100% - 20px);
	margin: 0 calc(10px);
}

.font_inter{
	font-family: 'OCR A Std', monospace;
}
.font_playfair{
	font-family: 'Satoshi', sans-serif;
}

.ln_select_cont{
		position: relative;
		display: inline-block;
		height: 24px;
		width: 34px;
		vertical-align: middle;
		margin-left: 10px;
	}
	.ln_select_curent{
		position: absolute;
		display: inline-block;
		top: 0;
		left: 5px;
		border-radius: 50%;
		height: 20px;
		width: 20px;
		border: solid 2px var(--colorBlack);
		cursor: pointer;
		transform: scale(1);
		background-position: center;
		background-size: cover;
		background-repeat: no-repeat;
		
		-o-transition: transform .4s ease-out, opacity .4s ease-out;
		-ms-transition: transform .4s ease-out, opacity .4s ease-out;
		-moz-transition: transform .4s ease-out, opacity .4s ease-out;
		-webkit-transition: transform .4s ease-out, opacity .4s ease-out;
		transition: transform .4s ease-out, opacity .4s ease-out;
	}
	.ln_select_cont:hover .ln_select_curent, .ln_select_cont.ishover .ln_select_curent{
		transform: scale(1.2);
	}
	.ln_select_cont .ln_others{
		position: absolute;
		display: inline-block;
		width: 100%;
		left: 0;
		top: auto;
		bottom: 100%;
		padding-bottom: 5px;
		padding-top: 5px;
		border-radius: 16px 16px 0 0;
		visibility: hidden;
		opacity: 0;
		
		-o-transition: visibility .4s ease-out, opacity .4s ease-out;
		-ms-transition: visibility .4s ease-out, opacity .4s ease-out;
		-moz-transition: visibility .4s ease-out, opacity .4s ease-out;
		-webkit-transition: visibility .4s ease-out, opacity .4s ease-out;
		transition: visibility .4s ease-out, opacity .4s ease-out;
	}
	.ln_select_cont:hover .ln_others, .ln_select_cont.ishover .ln_others{
		visibility: visible;
		opacity: 1;
	}
	.ln_select{
		position: relative;
		display: inline-block;
		height: 24px;
		width: 24px;
		border-radius: 50%;
		margin: 5px;
		transform: scale(1);
		background-position: center;
		background-size: cover;
		background-repeat: no-repeat;
		
		-o-transition: transform .4s ease-out, opacity .4s ease-out;
		-ms-transition: transform .4s ease-out, opacity .4s ease-out;
		-moz-transition: transform .4s ease-out, opacity .4s ease-out;
		-webkit-transition: transform .4s ease-out, opacity .4s ease-out;
		transition: transform .4s ease-out, opacity .4s ease-out;
	}
	.ln_select:hover, .ln_select.ishover{
		transform: scale(1.2);
	}
	.h2_menu{
		/*font-family: 'Playfair Display', serif;*/
		font-size: 36px;
		line-height: 42px;
		font-weight: 800;
	}
	
	.ic_social_barra{
		position: relative;
		display: inline-block;
		width: 25px;
		height: 25px;
		margin: 10px;
		cursor: pointer;
		vertical-align: middle;
		color: #000000;
		color: var(--colorBlack);
		-o-transition: color .4s ease-out;-ms-transition:color .4s ease-out;-moz-transition:color .4s ease-out;-webkit-transition:color .4s ease-out;transition:color .4s ease-out;
	}
	@media screen and (max-width: 1240px){
		.ic_social_barra{
			margin: 5px;
		}
	}
	.ic_social_barra.black{
		color: #000000;
	}
	.ic_social_barra.white{
		color: #FFFFFF;
	}
	.ic_social_barra:hover{
		color: #0000FF;
		color: var(--colorHover);
	}
	
.menu_btn {
	position: absolute;
	display: inline-block;
	width: 40px;
	height: 40px;
	top: 50%;
	right: 0;
	margin-top: -20px;
	margin-right: 15px;
	cursor: pointer;
}
.menu_btn.active {
	display: inline-block;
}

.menu_btn .riga_menu_btn {
	position: absolute;
	display: block;
	width: 24px;
	height: 2px;
	border-radius: 1px;
	background-color: #FFFFFF;
	background-color: var(--colorWhite);
	-o-transition: all .4s ease-out;
	-ms-transition: all .4s ease-out;
	-moz-transition: all .4s ease-out;
	-webkit-transition: all .4s ease-out;
	transition: all .4s ease-out
}

#barra.white .menu_btn .riga_menu_btn{
	background-color: #030404;
}
.menu .menu_btn .riga_menu_btn{
	background-color: #F8F8F8;
}

.menu_btn:hover .riga_menu_btn, .menu_btn.ishover .riga_menu_btn, #barra.white .menu_btn:hover .riga_menu_btn, #barra.white .menu_btn.ishover .riga_menu_btn {
	background-color: #0000FF;
	background-color: var(--colorHover);
	-o-transition: all .4s ease-out;
	-ms-transition: all .4s ease-out;
	-moz-transition: all .4s ease-out;
	-webkit-transition: all .4s ease-out;
	transition: all .4s ease-out
}

.menu_btn .riga_menu_btn.r1 {
	top: 12px;
	left: 8px;
}

.menu_btn .riga_menu_btn.r2 {
	top: 19px;
	left: 8px;
}

.menu_btn .riga_menu_btn.r3 {
	top: 26px;
	left: 8px;
}

.menu_btn .riga_menu_btn.x.r1, .menu_btn .riga_menu_btn.x.r2 {
	top: 19px;
	left: 11px;
	width: 20px;
	-webkit-transform: rotate(-135deg);
	-moz-transform: rotate(-135deg);
	-ms-transform: rotate(-135deg);
	transform: rotate(-135deg);
}

.menu_btn .riga_menu_btn.x.r3 {
	top: 19px;
	left: 11px;
	width: 20px;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}

.loading_div {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0; left: 0;
	z-index: 999999999;
	background-color: #FFFFFF;
	overflow: hidden;
	transition: opacity 400ms ease, transform 400ms ease;
}
.loading_div.out {
	opacity: 0;
	transform: translateY(0);
}

.loader {
				position: relative;
				display: inline-block;
				width: 30px;
				padding: 4px;
				aspect-ratio: 1;
				border-radius: 50%;
				background: #000000;
				background: var(--colorCaricamento);
				--_m: 
					conic-gradient(#0000 10%,#000),
					linear-gradient(#000 0 0) content-box;
				-webkit-mask: var(--_m);
				mask: var(--_m);
				-webkit-mask-composite: source-out;
				mask-composite: subtract;
				animation: l3 1s infinite linear;
			}
			.loader.absolute{
				position: absolute; top: 50%; left: 50%; margin-top: -19px; margin-left: -19px;
			}
			.loader.no_anim{
				animation: none;
			}
			@keyframes l3 {to{transform: rotate(1turn)}}
			
		.no_img_anim{
			-webkit-animation: blink 1.2s ease-in-out infinite;
			-moz-animation: blink 1.2s ease-in-out infinite;
			animation: blink 1.2s ease-in-out infinite;
		}
	
@-webkit-keyframes blink {
  0% { 
    background-color: #E2E2E2;
  }
  50% { 
    background-color: #CCCCCC;
  }
  100% { 
    background-color: #E2E2E2;
  }
}

@-moz-keyframes blink {
  0% { 
    background-color: #E2E2E2;
  }
  50% { 
    background-color: #CCCCCC;
  }
  100% { 
    background-color: #E2E2E2;
  }
}

@keyframes blink {
  0% { 
    background-color: #E2E2E2;
  }
  50% { 
    background-color: #CCCCCC;
  }
  100% { 
    background-color: #E2E2E2;
  }
}

.popup{
				position: fixed;
				display: inline-block;
				width: 100%;
				height: 100%;
				top: 0;
				left: 0;
				z-index: 1000;
				visibility: hidden;
				opacity: 0;
				overflow: auto;

				-o-transition: visibility .4s ease-out, opacity .4s ease-out;
				-ms-transition: visibility .4s ease-out, opacity .4s ease-out;
				-moz-transition: visibility .4s ease-out, opacity .4s ease-out;
				-webkit-transition: visibility .4s ease-out, opacity .4s ease-out;
				transition: visibility .4s ease-out, opacity .4s ease-out;
			}
			.popup.opened{
				visibility: visible;
				opacity: 1;
			}
			.popup .background{
				position: absolute;
				display: inline-block;
				background-color: #000000E1;
				background-color: var(--colorBlackTransparent);
				width: 100%;
				height: 100%;
				top: 0;
				left: 0;
			}
			.popup .middle_align{
				position: relative;
				display: inline-block;
				width: 2px;
				height: 100%;
				margin: 0 -1px;
				vertical-align: middle;
			}
			.popup .popup_cont{
				position: relative;
				display: inline-block;
				width: 90%;
				vertical-align: middle;
				background-color: #FFFFFF;
				background-color: var(--colorWhite);
				padding: 20px 0;
				transform: scale(0.8);
				opacity: 0;
				border-radius: 6px;

				-o-transition: transform .4s ease-out, opacity .4s ease-out;
				-ms-transition: transform .4s ease-out, opacity .4s ease-out;
				-moz-transition: transform .4s ease-out, opacity .4s ease-out;
				-webkit-transition: transform .4s ease-out, opacity .4s ease-out;
				transition: transform .4s ease-out, opacity .4s ease-out;
			}
			.popup.opened .popup_cont{
				transform: scale(1);
				opacity: 1;
			}
			.caricamento{
				position: absolute;
				display: inline-block;
				width: 100%;
				height: 100%;
				top: 0;
				left: 0;
				
				background-color: #FFFFFFA2;
				background-color: var(--colorWhite2Transparent);
				background-image: url("../imm/carica_image.gif");
				background-size: 32px;
				background-position: center;
				background-repeat: no-repeat;
			}
			.caricamento.fixed{
				z-index: 999999;
				position: fixed;
			}

.popup_cont_galery{
				height: 80%;
				padding: 0;
			}
			
			.popup_cont_title{
				position: absolute;
				width: 100%;
				top: 0;
				left: 0;
				padding: 16px 0;
				border-bottom: solid 1px #0000000A;
			}
			.popup_title{
				font-size: 14px;
				color: #000000;
				color: var(--colorblack)
				font-weight: 500;
				text-align: center;
			}
			.popup_cont_footer{
				position: absolute;
				width: 100%;
				bottom: 0;
				left: 0;
				border-top: solid 1px #0000000A;
			}
			.popup_cont_mid{
				position: absolute;
				width: 100%;
				left: 0;
				top: 52px;
				bottom: 52px;
				overflow: auto;
			}


.imm_zoom{
		cursor: pointer;
	}

	.popup_imm{
		position: fixed;
		display: inline-block;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		visibility: visible;
		opacity: 1;
		z-index: 200;
		overflow: auto;


		-o-transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
		-ms-transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
		-moz-transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
		-webkit-transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
		transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
	}

	.popup_imm.closed{
		visibility: hidden;
		opacity: 1;
	}

	.popup_imm .back{
		position: absolute;
		display: inline-block;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		opacity: 1;

		background-color: #000000;
		background-color: var(--colorBlackTransparent);


		-o-transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
		-ms-transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
		-moz-transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
		-webkit-transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
		transition: visibility .4s ease-out, opacity .4s ease-out, top .4s ease-out, left .4s ease-out;
	}
	.popup_imm.closed .back{
		opacity: 0;
	}

	.popup_imm img{
		max-width: 90%;
		max-height: 90%;
		top: 0;
		left: 0;
		margin: 0 -2px;
		box-shadow: 0 0 18px 0 #0000001D;

		-o-transition: top .4s ease-out, left .4s ease-out, max-width .4s ease-out, max-height .4s ease-out;
		-ms-transition: top .4s ease-out, left .4s ease-out, max-width .4s ease-out, max-height .4s ease-out;
		-moz-transition: top .4s ease-out, left .4s ease-out, max-width .4s ease-out, max-height .4s ease-out;
		-webkit-transition: top .4s ease-out, left .4s ease-out, max-width .4s ease-out, max-height .4s ease-out;
		transition: top .4s ease-out, left .4s ease-out, max-width .4s ease-out, max-height .4s ease-out;
	}
	.popup_imm.closed img{
		max-width: 50%;
		max-height: 50%;
	}
	.popup_imm .icon_close{
		position: fixed;
		top: 0;
		right: 0;
		width: 40px;
		height: 40px;
		margin: 10px;
		transform: scale(1);
		cursor: pointer;
		background-image: url("../imm/icons/white/icon_close.svg");
		background-repeat: no-repeat;
		background-size: 42px;
		background-position: center;


		-o-transition: transform .2s ease-out;
		-ms-transition: transform .2s ease-out;
		-moz-transition: transform .2s ease-out;
		-webkit-transition: transform .2s ease-out;
		transition: transform .2s ease-out;
	}
	.popup_imm .icon_close:hover{
		transform: scale(1.2);
	}
	.popup_imm .zoom{
		position: absolute;
		bottom: 0;
		left: 50%;
		width: 270px;
		margin-left: -135px;
	}
	
	.animate_by_word {
		opacity: 0;
		transform: translateY(10px);
		display: inline-block;
		animation: fadeUpWord 0.5s forwards;
	}

	@keyframes fadeUpWord {
		to {
			opacity: 1;
			transform: translateY(0);
		}
	}



.progetto{
			text-decoration: none;
		}
		
		.progetto:hover, .progetto.ishover{
			text-decoration: none;
		}
		
		.progetto h5{
			color: #000000;
			color: var(--colorBlack);
		}
		
		.progetto h5, .progetto p{
			text-decoration: none;

			-o-transition: color .4s ease-out;
			-ms-transition: color .4s ease-out;
			-moz-transition: color .4s ease-out;
			-webkit-transition: color .4s ease-out;
			transition: color .4s ease-out;
		}
		
		.progetto:hover h5, .progetto.ishover h5, .progetto:hover p, .progetto.ishover p{
			color: #F6100;
			color: var(--colorHover);
			text-decoration: none;
		}
		
		.imm_progetto{
			position: relative;
			display: inline-block;
			width: 100%;
			aspect-ratio: 1920 / 1280;
			overflow: hidden;
			margin-bottom: 10px;
		}
		
		.imm_progetto .imm_full{
			transform: scale(1);

			-o-transition: transform .6s ease-out;
			-ms-transition: transform .6s ease-out;
			-moz-transition: transform .6s ease-out;
			-webkit-transition: transform .6s ease-out;
			transition: transform .6s ease-out;
		}
		.progetto:hover .imm_progetto .imm_full, .progetto.ishover .imm_progetto .imm_full{
			transform: scale(1.1);	
		}


.virgolette{
			background-image: url('<?=$link?>imm/virgolette.png'); background-size: 512px; background-position: 0 0; background-repeat: repeat;
			
			animation: virgolette_anim 6s infinite linear;
			opacity: 0.25;
		}
		@keyframes virgolette_anim {to{background-position: 1024px 512px}};
		
		.marquee{
			height: auto;
			overflow: hidden;
			display: flex;
			align-items: center;
		}

		.marquee__track{
			display: inline-flex;
			align-items: center;
			white-space: nowrap;
			animation: marquee 40s linear infinite;
		}
		.marquee__track.contrario{
			animation: marquee2 40s linear infinite;
		}

		.marquee__track span{
			font-size: 96px;
			line-height: 0.7em;
			font-weight: 900;
			margin: 0 20px;
			padding-right: 0.25em;
			color: #FFFFFF;
			color: var(--colorWhite);
			text-shadow: 0 0 30px black;
		}

		@keyframes marquee{
			from { transform: translateX(0); }
			to   { transform: translateX(-50%); }
		}

		@keyframes marquee2{
			from { transform: translateX(-50%); }
			to   { transform: translateX(0); }
		}



.cmp-backdrop{position:fixed;inset:0;background:rgba(255,255,255,.45);display:none;z-index:99998}
  .cmp{position:fixed;left:16px;right:16px;bottom:16px;max-width:760px;margin:0 auto;
       background:#111;color:#fff;border-radius:14px;padding:16px;z-index:99999;
       box-shadow:0 14px 40px rgba(0,0,0,.35);font:14px/1.35 system-ui,-apple-system,Segoe UI,Roboto}
  .cmp h4{margin:0 0 6px;font-size:16px;color: #FFFFFF;}
  .cmp p{margin:0 0 10px;opacity:.9;color: #C2C2C2;}
  .cmp .row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-end}
  .cmp button{border:0;border-radius:10px;padding:10px 12px;font-weight:600;cursor:pointer; font-size: 12px; line-height: 12px;}
  .cmp .btn-secondary{background:#2a2a2a;color:#fff}
  .cmp .btn-primary{background:#fff;color:#111}
  .cmp .btn-ghost{background:transparent;color:#fff;text-decoration:underline;padding:8px}
  .cmp small{opacity:.8}
  .cmp-panel{display:none;margin-top:10px;border-top:1px solid rgba(255,255,255,.12);padding-top:10px}
  .cmp-tog{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0}
  .cmp-tog label{display:flex;align-items:center;gap:8px}
  .cmp-tog input[type="checkbox"]{transform:scale(1.1)}
  .cmp-fixed-link{position:fixed;left:75%; transform: translateX(-50%); bottom:0;z-index:99997;
                  background:#111;color:#fff;border-radius:18px 18px 0 0;padding:6px 10px;padding-top:8px;
                  font:12px system-ui;opacity:.0;pointer-events:none;transition:.2s; cursor: pointer;}
  .cmp-fixed-link.show{opacity:.9;pointer-events:auto}


#policyModal{position:fixed;inset:0;display:none;z-index:100000}
    #policyModal.open{display:block}
    #policyModal .pm-backdrop{position:absolute;inset:0;background:rgba(255,255,255,.5)}
    #policyModal .pm-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
      width:min(920px, calc(100% - 32px)); max-height:80vh; overflow:hidden;
      background:#111;color:#fff;border-radius:14px;box-shadow:0 18px 60px rgba(0,0,0,.45)}
    #policyModal .pm-head,#policyModal .pm-foot{display:flex;justify-content:space-between;align-items:center;
      gap:12px;padding:12px 14px;background:rgba(255,255,255,.06); font-size: 12px; line-height: 12px;}
    #policyModal .pm-body{overflow:auto;padding:0 6px;max-height:calc(80vh - 120px)}
    #policyModal a{color:#fff;text-decoration:underline}
    #policyModal button{border:0;border-radius:10px;padding:8px 12px;font-weight:600;cursor:pointer}
    #policyModal .pm-close{background:#2a2a2a;color:#fff}