:root {
	--color-1: #292929;
	--color-2: #313131;
	--color-3: #F0801D;
	--color-4: #E94D60;
	--color-5: #63A476;
	--color-6: #009847;
	--color-7: #DDD9DF;
	--color-8: #F8F7F8;
	--color-9: #030603;
	--color-11: #FFBE43; /* giallo */
	--color-12: #80ADA0; /* carta da zucchero */
	--color-13: #5F5566; /* vinaccia */
	--color-14: #33202A; /* viola scuro */
	--color-15: #000000;
}
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@100..900&family=Merriweather:ital,wght@0,300;0,400;0,700;0,900;1,300;1,400;1,700;1,900&display=swap');
body, html, input, textarea, select, button {
	font-family: 'Archivo', sans-serif;
	font-optical-sizing: auto;
	font-weight: 300;
	font-style: normal;
	font-size: 16px;
	line-height: 1.4em;
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
*, *:before, *:after {
	box-sizing: border-box;
}
body {
	overflow-x: hidden;
}
a {
	color: var(--color-14);
	outline: none;
	text-decoration: none;
}
.material-symbols-rounded {
	font-size: 2em !important;
	vertical-align: middle !important;
}
h1, h2, h3, h4, h5, h6 {
	margin: 0 auto 1rem;
	padding: 0;
	text-wrap: balance;
	line-height: 1.3em;
	max-width:80vw;
}
h1, h2, h4, h5, h6 {
	font-family: "Merriweather", serif;
	line-height: initial;
}
h1::first-letter,h2::first-letter,h3::first-letter,p::first-letter {
  text-transform: uppercase;
}
ol, ul {
	list-style-type: none;
}
p {
	margin-top: 1rem;
}
h1 {
	font-size: 3.2rem;
	text-align: center;
	margin: 5vh auto;
	color: var(--color-13);
}
h2 {
	font-size: 2.7rem;
	color: var(--color-14);
}
h3 {
	font-size: 2rem;
	color: var(--color-9);
}
h4 {
	font-size: 1rem;
}
h5 {
	font-size: 0.8rem;
}
h6 {
	font-size: 0.6rem;
}
.br20 {
	border-radius: 20px;
}
table {
	width: 100%;
	border: none;
	margin: 30px auto;
}
th, td {
	padding: 2px 5px;
	border-bottom: 1px dotted var(--color-2);
}
th {
	background: 1px dotted var(--color-1);
	color: var(--color-8);
}
form.sign {
	padding: 30px;
	/*background:#fff;*/
	background: rgba(95, 85, 102, 0.2);
	border: 2px solid #ccc;
	border-radius: 10px;
}
form.sign h3 {
	color: var(--color-13);
}
.col50.nopadd {
	padding: 0 !important;
	margin-right: 1%;
	width: 49%
}
input[type="text"], input[type="password"], input[type="email"], input[type="number"], select, textarea {
	background: var(--color-8);
	border: none;
	padding: 7px;
	border-radius: 5px;
	width: 100%;
	margin-bottom: 10px;
	font-size: 1rem;
}
select {
	padding: 9px 5px 10px;
}
label {
	display: inline-block;
	margin: 15px 0 5px;
	cursor: pointer;
}
label:hover {
	color: #772650;
}
.cx {
	text-align: center;
}
.sx {
	text-align: left;
}
.dx {
	text-align: right;
}
img {
	border-radius:10px;
}
img.w100 {
	width: 100%;
	height: auto;
}
.jx {
	text-align: justify;
}
.flsx {
	float: left;
}
.fldx {
	float: right;
}
.vam {
	vertical-align: middle;
}
.mrgl {
	margin-left: 20px;
}
.mrgr {
	margin-right: 20px;
}
hr {
	margin: 30px auto;
	border: none;
	height: 2px;
	background: var(--color-14);
}
.hide {
	display: none;
}
.flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: stretch;
}
.flex.alsx {
	justify-content: flex-start;
}
.flex.alml {
	align-items: center;
}
.vaml {
	align-self: middle;
}
.breakFlex {
	width: 100%;
	height: 0;
}
.col {
	padding: 2% 3%;
}
.col10 {
	width: 10%;
}
.col16 { /* 6 colonne */
	width: 16.66%;
}
.col20 {
	width: 20%;
}
.col25 {
	width: 25%;
}
.col30 {
	width: 30%;
}
.col33 {
	width: 33%;
}
.col50 {
	width: 50%;
}
.col60 {
	width: 60%;
}
.col70 {
	width: 70%;
}
.col100 {
	width: 100%;
}
.col img {
	width:100%;
	height:auto;
}
.fvam {
	self-align: center;
}
.bg {
	background: var(--color-5);
}
.boxed {
	margin: 0 auto;
	width: 80vw;
}
.boxed_small {
	margin: 0 auto;
	width: 800px;
	max-width: 98vw;
}
.highlight {
	margin: 0 auto;
	width: 600px;
	max-width: 60%;
	text-align: center;
	font-size: 1.4rem;
	line-height: 1.4em;
	font-style: italic;
	color: var(--color-4);
}
.margt {
	margin-top: 40px;
}
.margb {
	margin-bottom: 40px;
}
.margt_x2 {
	margin-top: 80px;
}
.margb_x2 {
	margin-bottom: 80px;
}
.paddt {
	padding-top: 40px;
}
.paddb {
	padding-bottom: 40px;
}
.paddt_x2 {
	padding-top: 80px;
}
.paddb_x2 {
	padding-bottom: 80px;
}
.mobile {
	display: none;
}
input[type=submit], input[type=reset], button, .submitSimulation, .pulsante {
	background: var(--color-13) !important;
	border: none !important;
	border-radius: 10px !important;
	color: var(--color-8) !important;
	padding: 10px 20px !important;
	cursor: pointer !important;
	text-transform: uppercase;
	font-weight: bold;
	display: inline-block;
}
input[type=submit]:hover, input[type=reset]:hover, button:hover, .submitSimulation:hover, .pulsante:hover {
	background: var(--color-14) !important;
}
input[type=range] {
	vertical-align: middle;
}
.avviso {
	background: var(--color-2);
	color: var(--color-8);
	padding: 8px;
	border-radius: 5px;
	margin: 10px 0;
}
/* tasti lingua */
.lingue {
	margin-left: 20px;
}
.lingue a {
	display: inline-block;
	background: #efefef;
	width: 30px;
	height: 30px;
	text-align: center;
	line-height: 30px;
}
/* menu */
nav {
	background: #33202A;
}
nav img {
	vertical-align: middle;
	width: 20px;
	height: 20px;
	object-fit: fill;
	margin-right: 5px;
}
ul#nav {
	display: block;
	min-height: 50px;
	line-height: 50px;
	text-align: center;
	padding: 0;
	margin-bottom: 0;
}
ul#nav .simbolotrigger {
	display: none;
}
ul#nav li {
	display: inline-block;
	margin: 0 1%;
	position: relative;
}
ul#nav li.mobile {
	display: none;
}
ul#nav a {
	padding: 0 8px;
	display: block;
	font-weight: bold;
	cursor: pointer;
	color: #fff;
}
ul#nav > li:hover .sottomenu {
	display: block;
}
ul#nav .sottomenu {
	display: none;
	min-width: 100%;
	background: var(--color-8);
	border-radius: 5px;
	position: absolute;
	top: 40px;
	left: 0;
	text-align: left;
	margin: 0;
	padding: 0;
	z-index: 50;
}
ul#nav .sottomenu li {
	display: block;
	margin: 0;
	width: 100%;
	white-space: nowrap;
	border-bottom: 1px solid var(--color-8);
}
#aprimenu {
	display: none;
}
/* custom */
body {
	background-color: var(--color-8);
}
/* testata */
#logo {
	width: 80px;
	height: auto;
	filter: invert(1);
	opacity: 0.9;
}
header {
	color: #ccc;
}
header a {
	font-weight: bold;
}
header .link_accesso {
	color: var(--color-1);
}
header .link_accesso a {
	color: var(--color-1);
}
/* barra ricerca */
#search {
	position: relative;
	max-width: 600px;
	margin: 0 auto;
}
#search input[type=text] {
	border-radius: 20px;
	border: 1px solid var(--color-14);
	padding: 6px 20px 0;
	height: 40px;
	width: 100%;
	background: #fff;
	vertical-align: middle;
	color: var(--color-14);
}
#submit_search {
	position: absolute;
	right: 15px;
	top: 4px;
	color: var(--color-14);
}
/* homepage */
.hero {
	overflow: hidden;
	padding:120px 0;
}
.hero img {
	width: 100%;
}
.hero h1 {
	color: #fff;
	font-size: calc(30px + 2vw);
	margin:0 auto;
}
.hero h2 {
	color: #fff;
	font-size: calc(12px + 0.8vw);
	line-height:1.4em;
	text-wrap: balance;
	margin:40px auto 0;
	text-align: center;
	font-family: 'Abhaya Libre', sans-serif;
}
.bancone {
	margin: inherit auto;
	padding: 5vh 0;
}
.bancone img {
	float: left;
	aspect-ratio: 1/1;
}
.presentation h2 {
	margin-bottom: 40px;
}
.presentation h2 span {
	color: var(--color-1);
}
.presentation p {
	font-size: 1.6rem;
	line-height: 1.4em;
	color: #888;
}
.presentation img {
	max-height: 80vh
}
#userpanel a {
	display: block;
	width: 280px;
	margin: 0 auto 20px;
}
#recapiti {
	padding: 40px 20px;
	border-radius: 10px;
	background: rgba(95, 85, 102, 0.3);
	color: var(--color-14);
	margin-bottom: 40px;
}
/* footer */
footer {
	border-top: 2px solid #000;
	padding: 5vh 0;
	font-size: 0.8rem;
	margin-top: 10vh;
	background: var(--color-14);
	color: var(--color-8);
}
footer h3 {
	color: #fff;
	line-height: 1.4em;
	font-size:1.6rem;
}
footer a {
	color: var(--color-8);
}
.scheda_image img {
	aspect-ratio:1;
	object-fit:cover;
}
.scheda .pulsante {
	font-size:1.2rem;
	text-transform: none;
	background-color:var(--color-11)!important;
	color:var(--color-13)!important;
	border:1px solid var(--color-11)!important;
}
.scheda .pulsante:hover {
	background-color:var(--color-8)!important;	
	border:1px solid var(--color-13)!important;
}
.procedura .p_image {
	aspect-ratio: 1/1;
	width: 100%;
	margin-bottom: 20px;
}
.procedura .p_image img {
	aspect-ratio: 1/1;
	width: 100%;
	object-fit: cover;
	background: #eee;
	object-position: center;
}
.procedura .p_nome {
	font-weight: bold;
	text-transform: uppercase;
	margin-bottom: 20px;
}
.procedura .p_data {
	color: #888;
	margin-bottom: 40px;
}
.bene {
	background: #eee;
	margin-bottom: 20px;
	border-radius:20px;
	border:2px solid #ddd;
}
.bene .b_image {
	aspect-ratio: 1/1;
	width: 100%;
}
.bene .b_image img {
	aspect-ratio: 1/1;
	width: 100%;
	object-fit: cover;
	object-position: center;
}
.bene .b_text {
	font-size: 0.9rem;
}
.etichetta {
	display: inline-block;
	width: 200px;
	background: #eee;
	padding: 5px;
	border-radius: 5px;
}

@media (max-width: 1024px) {
	header .col {
		width: 100% !important;
		margin: inherit auto !important;
	}
	#logo {
		width: 100px;
	}
	#submit_search {
		position: absolute;
		right: 10px;
		top: 2px;
	}
	form {
		max-width: 90vw;
		margin: 0 auto;
	}
	nav {
		background: #fff;
		margin-bottom: 20px;
	}
	nav img {
		width: 24px;
		height: 24px;
	}
	ul#nav {
		background: var(--color-1);
		display: none;
		font-weight: bold;
		color: var(--color-8);
		margin: 0 10vw;
		border-radius: 10px;
	}
	ul#nav a {
		color: var(--color-8) !important;
		display: block;
	}
	ul#nav a:hover {
		color: var(--color-8) !important;
	}
	ul#nav li {
		width: 100%;
		display: block;
		margin: 0;
		position: relative;
		border: none;
		text-align: left;
		overflow: hidden;
		border-bottom: 1px dotted #eee;
		padding: 0 10px;
	}
	ul#nav li.mobile {
		background: #777;
		display: block;
	}
	ul#nav .sottomenu {
		background: var(--color-1);
		width: 100%;
		top: 0;
		display: block;
		margin: 0;
		padding: 0;
		padding-left: 20px;
		z-index: auto;
		position: relative;
		border: none;
	}
	ul#nav .sottomenu li {
		min-height: 20px;
		line-height: 20px;
		text-align: left;
		margin: 0;
		border: none;
	}
	ul#nav .sottomenu li a, ul#nav li a {
		display: block;
		width: 100%;
	}
	#aprimenu {
		display: inline-block;
		position: absolute;
		right: 10vw;
		top: 30px;
	}
	.link_accesso {
		display: inline-block;
		position: absolute;
		right: calc(50px + 10vw);
		top: 30px;
		padding: 0 !important;
		width: auto !important;
	}
	.nomobile {
		display: none;
	}
	.mobile {
		display: block;
	}
	header .material-symbols-rounded {
		color: #aaa;
		font-size: 36px;
	}
}
@media (max-width: 960px) {
	.col {
		width: 100% !important;
		margin: inherit auto !important;
	}
	.mob_cx {
		text-align: center;
	}
	.highlight {
		font-size: 1.2rem;
	}
	.hero img {
		width: 200%;
	}
}