.body_wrapper {
	height: 100%; display: flex; flex-direction: column; flex-grow: 1
}
#cookiebanner-status {
	position: fixed;
	bottom: 0;
	right: 0;
	opacity: 0;
}
#cookiebanner-status + label {
	position: fixed;
	bottom: 3px;
	right: 3px;
	background: #fff;
	padding: 4px;
	cursor: pointer;
	z-index: 99998;
}
#cookiebanner {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.4);
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
}
#cookiebanner-status:checked + label + #cookiebanner {
	display: flex;
}
#cookiebanner > div {
	background: #fff;
	padding: 20px;
	text-align: center;
}
#cookiebanner > div button {
	display: inline-block;
	padding: 10px;
	width: 120px;
	border: 1px solid;
	cursor: pointer;
}
html {
	position: relative;
	height: 100%;
	background: #eee;
	scroll-behavior: smooth;
}
body {
	background: #ffffffff;
	color: #7a8692ff;
	position: relative;
	margin: 0;
	min-height: 100%;
	display: flex;
	flex-direction: column;
	font-family: Roboto;
	font-size: 18px;
	font-weight: 300;
	line-height: 1.2em;
}
a {
	color: inherit;
	text-decoration: none;
}
b, strong {
	font-weight: 600;
}
sup {
	vertical-align: top;
	font-size: 0.7em;
}
ol ol li { list-style-type: lower-alpha; }
ol ol ol li { list-style-type: upper-roman; }

.main_wrapper {
	flex-grow: 1;
	display: flex; 
	flex-direction: column;
	overflow: hidden;
}

.wrapper_larghezza {
	width: 1200px;
	margin-left: auto !important;
	margin-right: auto !important;
}
.wrapper_larghezza .wrapper_larghezza {
	width: 100%; /* da auto, v. blocco insegnante*/
	box-sizing: border-box;
} 
h1, h2, h3, h4, h5 {
	margin: 0;
}

.header_wrapper {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 30px;
	padding: 20px 0;
	color: #202e43ff
}
.header_wrapper img {
	max-height: 120px;
}
.header_wrapper .link_wrapper {
	flex-grow: 1;
	display: flex;
	flex-direction: row;
	justify-content: flex-end;
	align-items: center;
	gap: 5px 30px;
}
.header_wrapper .menu ul {
	list-style: none;
	display: flex;
	justify-content: flex-start;
	gap: 10px 30px;
	margin: 0;
	padding: 0;
}
.header_wrapper .menu ul.link {
	flex-wrap: wrap;
}
.header_wrapper .menu ul.social {
	gap: 4px;
}
.header_wrapper .menu a {
	transition: 0.2s all;
	white-space: nowrap;
}
.header_wrapper .menu a:hover {
	color: #00a3d6ff;
}
.header_wrapper .social li a {
	padding: 5px;
	display: block;
}
.header_wrapper .social svg {
	height: 20px;
}
.header_wrapper .social svg * {
	fill: #00a3d6ff
}
.header_wrapper .menu_status,
.header_wrapper .menu_status + label {
	display: none;
}

.footer_wrapper .logo {
	max-width: 100%;
	width: min-content;
}

h1, .titolo1 {
	text-align: center;
	color: #202e43ff;
	font-family: Merriweather;
	font-size: 70px;
	font-weight: 300;
	line-height: 1.2em;
	margin: 50px 0 20px;
}
h3 + h1, .titolo3 + .titolo1 {
	margin-top: 0;
}

h2, .titolo2 {
	text-align: center;
	font-weight: 300;
	margin: 20px 0 10px;
	padding-bottom: 20px;
	position: relative;
	color: #202e43ff;
	font-family: Merriweather;
	font-size: 48px;
	font-weight: 300;
	line-height: 1.2em;
}
h2::before, .titolo2::before {
	text-align: center;
	content: attr(data-pre);
	display: block;
	padding-bottom: 20px;
	font-family: Roboto;
	font-size: 32px;
	font-weight: 300;
	line-height: 1.2em;
	color: #00a3d6ff;
}
h2::after, .titolo2::after {
	content: "";
	display: block;
	height: 2px;
	position: absolute;
	bottom: 0;
	left: 50%;
	margin-left: -30px;
	width: 60px;
	background: #00a3d6ff;
}

h3, .titolo3 {
	text-align: center;
	font-family: Roboto;
	font-size: 24px;
	font-weight: 300;
	line-height: 1.2em;
	margin: 20px 0;
}
h4, .titolo4 {
	text-align: center;
	color: #202e43ff;
	font-family: Roboto;
	font-size: 20px;
	font-weight: 300;
	line-height: 1.2em;
	margin: 10px 0;
}

.wrapper .col_50 > div h2,
.wrapper .col_50 > div .titolo2,
.wrapper .col_50 > div h3,
.wrapper .col_50 > div .titolo3,
.wrapper .col_50 > div h4,
.wrapper .col_50 > div .titolo4 {
	text-align: left;
}
.wrapper .col_50 > div h2::before,
.wrapper .col_50 > div .titolo2::before {
	left: 0;
	margin-left: 0;
}

.wrapper .col_33 h1, .wrapper .col_33 .titolo1,
.wrapper .col_33 h2, .wrapper .col_33 .titolo2,
.wrapper .col_33 h2::before, .wrapper .col_33 .titolo2::before,
.wrapper .col_33 h3, .wrapper .col_33 .titolo3,
.wrapper .col_33 h4, .wrapper .col_33 .titolo4,
.wrapper .col_50 h1, .wrapper .col_50 .titolo1,
.wrapper .col_50 h2, .wrapper .col_50 .titolo2,
.wrapper .col_50 h2::before, .wrapper .col_50 .titolo2::before,
.wrapper .col_50 h3, .wrapper .col_50 .titolo3,
.wrapper .col_50 h4, .wrapper .col_50 .titolo4,
.wrapper_colonna_immagine > div h1, .wrapper_colonna_immagine > div .titolo1,
.wrapper_colonna_immagine > div h2, .wrapper_colonna_immagine > div .titolo2,
.wrapper_colonna_immagine > div h2::before, .wrapper_colonna_immagine > div .titolo2::before,
.wrapper_colonna_immagine > div h3, .wrapper_colonna_immagine > div .titolo3,
.wrapper_colonna_immagine > div h4, .wrapper_colonna_immagine > div .titolo4 {
	text-align: left;
}
.wrapper .col_33 h2::after, .wrapper .col_33 .titolo2::after,
.wrapper .col_50 h2::after, .wrapper .col_50 .titolo2::after,
.wrapper_colonna_immagine > div h2::before, 
.wrapper_colonna_immagine > div .titolo2::before {
	margin-left: 0;
	left: 0;
}

.bottone {
	appearance: none;
	align-self: center;
	display: inline-block;
	color: #fff;
	border: none;
	font-size: inherit;
	padding: 16px 55px 16px 55px;
	min-width: 170px;
	text-align: center;
	text-transform: uppercase;
	cursor:pointer;
	margin: 10px 0;
	transition: 0.2s all;
	background: #00a3d6ff;
	border: 2px solid #00a3d6ff;
}
.bottone:hover {
	background: #ffffffff;
	color: #202e43ff;
}

.bottone_singolo {
	padding: 10px 0 40px;
	text-align: center;
}

.immagine_singola {
	display: block;
	margin: 0 auto;
	width: 100%;
}
.immagine_singola.img-s {max-width: 235px;}
.immagine_singola.img-m {max-width: 570px;}
.immagine_singola.img-l {max-width: 100%;}
.immagine_singola.allinea_sx {
	margin-left: 0;
}
.immagine_singola.allinea_dx {
	margin-right: 0;
}


.testo {
	margin: 10px 0;
	text-align: center;
}
.wrapper .col_50 .testo,
.wrapper .col_50 .bottone_singolo {
	text-align: left;
}

.wrapper {
	padding: 70px 0;
	position: relative;
	background-repeat: no-repeat;
}
.wrapper .wrapper {padding: 30px 0;}
/* sfondi wrapper semplici */
.wrapper {background-color: transparent}
.wrapper .wrapper {background-color: transparent}

.wrapper.sfondo_scuro {
	background-color: #202e43ff;
	color: #96a1acff
}
.wrapper.sfondo_scuro h1, .wrapper.sfondo_scuro .titolo1,
.wrapper.sfondo_scuro h2, .wrapper.sfondo_scuro .titolo2,
.wrapper.sfondo_scuro h3, .wrapper.sfondo_scuro .titolo3,
.wrapper.sfondo_scuro h4, .wrapper.sfondo_scuro .titolo4 {
	color: #ffffffff
}

.wrapper.sfondo_chiaro {
	background-color: #edf4faff;
	color: #7a8692ff;
}
.wrapper.sfondo_chiaro h1, .wrapper.sfondo_chiaro .titolo1,
.wrapper.sfondo_chiaro h2, .wrapper.sfondo_chiaro .titolo2,
.wrapper.sfondo_chiaro h3, .wrapper.sfondo_chiaro .titolo3,
.wrapper.sfondo_chiaro h4, .wrapper.sfondo_chiaro .titolo4 {
	color: #202e43ff
}

.wrapper.sfondo_bianco {
	background-color: #ffffffff;
	color: #7a8692ff;
}
.wrapper.sfondo_bianco h1, .wrapper.sfondo_bianco .titolo1,
.wrapper.sfondo_bianco h2, .wrapper.sfondo_bianco .titolo2,
.wrapper.sfondo_bianco h3, .wrapper.sfondo_bianco .titolo3,
.wrapper.sfondo_bianco h4, .wrapper.sfondo_bianco .titolo4 {
	color: #202e43ff
}

/* layer per immagine di sfondo */
.wrapper.layer::before{
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: inherit;
}
.wrapper.layer::before { mask-image: linear-gradient(to right, #ffffffE3, #ffffffE3); } 
.wrapper.layer.layer_sfondo_sx::before { mask-image: linear-gradient(to left, #ffffffE3 0 calc(50% + 600px), transparent calc(50% + 800px) 100%); } 
.wrapper.layer.layer_sfondo_dx::before { mask-image: linear-gradient(to right, #ffffffE3 0 calc(50% + 600px), transparent calc(50% + 800px) 100%); } 

.wrapper.layer.layer_sfondo_sx.stacco_bianco_nero::before,
.wrapper.layer.layer_sfondo_dx.stacco_bianco_nero::before {
	background: none;
}


/* taglio a v alto */
.wrapper.sagoma_tema {
	mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='10000'><rect width='100%' height='100%' fill='white'/><path d='M0 10000l0 -11 50 10 50 -10 0 11z'/></svg>");
	mask-repeat: no-repeat;
	mask-mode: luminance;
	mask-size: 100%;
	mask-position: bottom -2px left 0;
	z-index: 7;
	padding-bottom: 10%;
}
.wrapper.sagoma_tema + * {
	padding-top: calc(11% + 20px);
	margin-top: -11%;
}
.wrapper.sagoma_tema  + .wrapper.sagoma_tema  {z-index: 6;}
.wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  {z-index: 5;}
.wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  {z-index: 4;}
.wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  {z-index: 3;}
.wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  {z-index: 2;}
.wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  + .wrapper.sagoma_tema  {z-index: 1;}

.wrapper > * {
	display: flex;
	justify-content: center;
	align-items: stretch;
	gap: 60px;
	min-height: 40px;
}

.wrapper > * > * {
	z-index: 1;
	flex-direction: column;
	justify-content: stretch;
}
.wrapper > * > *:not(:first-child) {display: none;}
.wrapper > .monocolonna > *:first-child {
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	min-width: 0;
}
.wrapper > .monocolonna > * > img {
	align-self: center;
}
.wrapper > .col_50 > * { width: 50%; }
.wrapper > .col_50 > *:first-child,
.wrapper > .col_50 > *:nth-child(2) {display: flex;}
.wrapper > .col_33 > * { width: 33.33%; }
.wrapper > .col_33 > * {
	display: flex;
	position: relative;
}

.wrapper > .col_50 > * .elenco_spunte_riquadro {
	flex-grow: 1;
} 

.wrapper_colonna_immagine {
	display: flex;
	gap: 30px;
	position: relative;
}
.wrapper .wrapper_colonna_immagine > div {
	display: block;
	flex-basis: 50%;
	min-height: 100px;
}
.wrapper_colonna_immagine > .colonna_immagine img {
	position: absolute;
	max-height: calc(90% + 10vw);
	bottom: -10vw;
}
.wrapper_colonna_immagine .testo,
.wrapper_colonna_immagine .bottone_singolo {
	text-align: left;
}

.separatore_immagine {
	overflow: hidden;
	height: 300px;
	background-size: cover;
	background-position: 50% 50%;
}
.separatore_immagine.parallasse {
	background-attachment: fixed;
}

.immagine_doppia {
	height: 390px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	background-size: cover;
	background-position: 50% 50%;
	margin-right: 124px;
}
.immagine_doppia img {
	box-sizing: border-box;
	border: 5px solid #fff;
	width: 335px;
	height: 335px;
	margin-right: -124px;
	object-fit: cover;
	object-position: center;
}
.col_50 > div:nth-child(2) .immagine_doppia {
	justify-content: flex-start;
	margin-left: 124px;
	margin-right: 0;
}
.col_50 > div:nth-child(2) .immagine_doppia img {
	margin-left: -124px;
	margin-right: 0;
}

.elenco_blocchi ul {
	list-style: none;
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
	justify-content: center;
	padding: 0;
	margin: 20px auto;
}
.elenco_blocchi ul li {
	box-sizing: border-box;
	padding: 30px;
	background-color: #edf4faff
}
.elenco_blocchi.col_2 ul li {
	flex-basis: calc(50% - 15px)
}
.elenco_blocchi.col_3 ul li {
	flex-basis: calc(33.33% - 14px)
}
.wrapper.sfondo_scuro .elenco_blocchi ul li {background-color: #2f4566ff}
.wrapper.sfondo_chiaro .elenco_blocchi ul li {background-color: #ffffffff}

.elenco_blocchi ul li img {
	height: 48px;
}
.elenco_blocchi ul li h3, 
.elenco_blocchi ul li .titolo3 {
	text-align: left !important;
}

.elenco_step ul {
	counter-reset: step;
	list-style: none;
	display: flex;
	gap: 30px;
	flex-wrap: wrap;
	justify-content: center;
	padding: 0;
	margin: 20px auto;
}
.elenco_step ul li {
	counter-increment: step;
	box-sizing: border-box;
	padding: 30px 30px;
	flex-basis: calc(33.33% - 20px);
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='11'><path d='M0 11l0 -11 40 10 40 -10 0 11z'/></svg>") no-repeat,
		linear-gradient(#000 0 0);
	mask-size: 100%;
	mask-position: bottom -2px left 0;
	mask-composite: exclude;
	background-color: #edf4faff;
}
.elenco_step ul li::after {
	content: "";
	display: block;
	padding-top: 15%;
}
.wrapper.sfondo_scuro .elenco_step ul li {background-color: #2f4566ff}
.wrapper.sfondo_chiaro .elenco_step ul li {background-color: #ffffffff}
.elenco_step ul li::before {
	content: '0' counter(step);
	font-size: 5em;
	line-height: 1em;
	color: #00a3d6ff;
}
.elenco_step ul li h3, 
.elenco_step ul li .titolo3 {
	margin-top: 0;
	text-align: left !important;
}

.elenco_testimonial {
	margin: 30px 0;
}
.elenco_testimonial ul {
	list-style: none;
	padding: 0;
}
.elenco_testimonial ul li {
	padding: 30px;
	box-sizing: border-box;
	background-color: #edf4faff;
}
.wrapper.sfondo_scuro .elenco_testimonial ul li {background-color: #2f4566ff}
.wrapper.sfondo_chiaro .elenco_testimonial ul li {background-color: #ffffffff}

.elenco_testimonial ul li .testimonial_testo {}
.elenco_testimonial ul li .testimonial_nome {
	font-weight: bold;
	margin: 20px 0 5px;
}
.elenco_testimonial ul li .testimonial_azienda {
	color: #00a3d6ff;
}
.splide__arrow {
	position: absolute;
	top: 50%;
	margin-top: -15px;
	z-index: 1;
	cursor: pointer;
	appearance: none;
	background: transparent;
	border: none;
	padding: 0;
	display: flex;
	fill: #00a3d6ff;
}
.splide__arrow svg {
	width: 30px;
	height: 30px;
}
.splide__arrow.splide__arrow--prev {
	left: 0;
	transform:rotateY(180deg)
}
.splide__arrow.splide__arrow--next {
	right: 0;
}


.elenco_spunte_riquadro {
	padding: 20px;
	border-radius: 15px;
	background: #2f4566ff;
	color: #7a8692ff;
	border: 2px solid #00a3d6ff;
	margin: 30px auto;
}
.elenco_spunte_riquadro ul {
	list-style: none;
	padding: 0;
	margin: 30px auto;
}
.elenco_spunte_riquadro ul > li {
	position: relative;
	padding-left: 30px;
	margin: 15px 0;
}
.elenco_spunte_riquadro ul > li::before,
.elenco_spunte_in_linea ul > li::before {
	content: url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 8 6"><path fill="%2300a3d6ff" d="m3 6l5 -5-1 -1-4 4-2 -2-1 1z"/></svg>');
	position: absolute;
	top: 0;
	left: 0;
}
.elenco_spunte_riquadro.elenco_icona_x ul > li::before,
.elenco_spunte_in_linea.elenco_icona_x ul > li::before {
	content: url('data:image/svg+xml; utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 8 8"><path fill="%23bed0d5ff" d="m4 5l2 2 1 -1-2 -2 2 -2-1 -1-2 2-2 -2-1 1 2 2-2 2 1 1z"/></svg>');
}
.elenco_spunte_riquadro ul > li::before{ width: 20px; }
.elenco_spunte_in_linea ul > li::before{ width: 25px; }

.elenco_spunte_in_linea ul {
	display: flex;
	list-style: none;
	padding: 0;
	gap: 30px;
	justify-content: center;
	margin: 30px auto;
	flex-wrap: wrap;
}
.elenco_spunte_in_linea ul > li {
	position: relative;
	padding-left: 35px;
	font-family: [!-- font_titoli --];
	font-size: 24px;
}

.elenco_faq {
	list-style: none;
	padding-left: 0;
}
.elenco_faq > li {
	border-bottom: 1px solid #00a3d6ff;
}
.elenco_faq > li input {
	display: none;
}
.elenco_faq > li .domanda {
	cursor: pointer;
	display: flex;
	gap: 10px;
	align-items: center;
	justify-content: space-between;
	padding: 15px;
	color: #202e43ff;
}
.sfondo_scuro .elenco_faq > li .domanda {color: #ffffffff}
.elenco_faq > li .domanda::after {
	content: "";
	background: url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 5 5"><path fill="%2300a3d6ff" d="m2 0l1 0 0 2 2 0 0 1-2 0 0 2 -1 0 0 -2-2 0 0 -1 2 0z"/></svg>');
	width: 16px;
	height: 16px;
	flex-grow: 0;
	flex-shrink: 0;
}
.elenco_faq > li .risposta {
	background-color: #0059C317;
	height: 0;
	overflow: hidden;
	padding: 0 15px;
	transition: height .4s, padding .4s;
	interpolate-size: allow-keywords;
}
.elenco_faq > li input:checked ~ .domanda {
	background-color: #202e43ff;
	color: #ffffffff
}
.elenco_faq > li input:checked ~ .domanda::after {
	background: url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 5 5"><path fill="%2300a3d6ff" d="m0 2l5 0 0 1-5 0z"/></svg>');
}
.elenco_faq > li input:checked ~ .domanda ~ .risposta {
	overflow: visible;
	height: auto;
	padding: 15px;
}

.link_social {
	list-style: none;
	display: flex;
	padding: 0;
}
.link_social.allinea_sx {justify-content: flex-start;}
.link_social.allinea_cx {justify-content: center;}
.link_social.allinea_dx {justify-content: flex-end;}
.link_social a {
	padding: 5px;
}
.link_social svg {
	height: 20px;
}
.link_social svg * {
	fill: #00a3d6ff
}

.form_contatti {
	padding: 30px;
	max-width: 800px;
	margin: 20px auto;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0px 0px 28px 0px rgba(0,0,0,0.5);
	background: #2f4566ff;
}

.form_contatti.mostra_esito .form {
	opacity: 0;
}
.form_contatti .esito {
	display: none;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.form_contatti.mostra_esito .esito {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 20px;
	color: #96a1acff
}
.form_contatti.mostra_esito .esito svg circle {
	fill: #00a3d6ff;
}
.form_contatti.mostra_esito .esito svg path {
	stroke: #edf4faff;
}
.form_contatti ul {
	list-style: none;
	padding: 0;
	margin: 0;
	max-width: 800px;
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
}
.form_contatti ul li {
	flex-basis: 40%;
	flex-grow: 1;
	display: flex;
	align-items: center;
}
.form_contatti ul li.campo_grande {
	flex-basis: 100%;
}
.form_contatti input,
.form_contatti textarea {
	appearance: none;
	border: none;
	background: #14283B;
	color: #fff;
	padding: 10px;
	margin: 1px 0;
	font: inherit;
	box-sizing: border-box;
	width: 100%;
	min-width: 180px;
	outline: none;
}
.form_contatti textarea {
	min-height: 110px;
}
.form_contatti label {
	display: flex;
	align-items: center;
	gap: 5px;
}
.form_contatti input[type="checkbox"] {
	display: inline-block;
	padding: 0;
	width: 30px;
	height: 30px;
	min-width: 30px;
	flex-shrink: 0;
	position: relative;
	vertical-align: bottom;
}
.form_contatti input[type="checkbox"]:checked::before {
	content: url('data:image/svg+xml; utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48"><path d="M10 24L20 34L38 14" stroke="%2300a3d6ff" stroke-width="6" stroke-linecap="round" stroke-linejoin="round"/></svg>');
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
.form_contatti button {
	margin-top: 20px;
	width: 100%;
	appearance: none;
}
.form_contatti button.caricamento::before {
	content: "";
	display: inline-block;
}
@keyframes icona_caricamento {
	0% {rotate: 0deg;}
	100% {rotate: 360deg;}
}
.form_contatti button.caricamento {
	cursor:progress;
	opacity: 0.7;
	filter: none;
	transform: none;
	position: relative;
}
.form_contatti button.caricamento::before {
	content: "";
	border-radius: 100%;
	border: 2px solid currentColor;
	opacity: 0.7;
	width: 15px;
	height: 15px;
	position: absolute;
	top: 7px;
	margin-left: -23px;
	border-right-color: transparent;
	animation: icona_caricamento 1s linear infinite;
}

/* .form_contatti .obbligatorio::after,
.form_contatti .obbligatorio::after {
	content: "*";
	color: #f55;
} */
.form_contatti .errore input,
.form_contatti .errore textarea {
	border: 2px solid #f55
}

@media screen and (max-width: 1279px) {
	.wrapper_larghezza {
		width: 980px;
	}
}
@media screen and (max-width: 1023px) {
	h1 > *,
	h2 > *,
	h3 > *,
	h4 > *,
	h5 > * {display: inline;}
	
	h1 > *::before,
	h2 > *::before,
	h3 > *::before,
	h4 > *::before,
	h5 > *::before {content: " ";}
	
	h1, .titolo1 {
		font-family: Merriweather;
		font-size: 40px;
		font-weight: 300;
		line-height: 1.2em;
	}
	h2, .titolo2 {
		font-family: Merriweather;
		font-size: 28px;
		font-weight: 300;
		line-height: 1.2em;
	}
	h2::before, .titolo2::before {
		font-family: Roboto;
		font-size: 22px;
		font-weight: 300;
		line-height: 1.2em;
	}
	h3, .titolo3 {
		font-family: Roboto;
		font-size: 24px;
		font-weight: 300;
		line-height: 1.2em;
	}
	h4, .titolo4 {
		font-family: Roboto;
		font-size: 20px;
		font-weight: 300;
		line-height: 1.2em;
	}

	
	.wrapper_larghezza {
		width: 720px;
	}
	
	.elenco_blocchi.col_3 ul li,
	.wrapper .elenco_step ul li {
		flex-basis: calc(50% - 15px);
	}
	
	.immagine_doppia {
		margin-right: 40px;
	}
	.immagine_doppia img {
		margin-right: -40px;
		height: auto;
		aspect-ratio: 1;
		width: 100%
	}
	.col_50 > div:nth-child(2) .immagine_doppia {
		margin-left: 40px;
	}
	.col_50 > div:nth-child(2) .immagine_doppia img {
		margin-left: -40px;
	}
}
@media screen and (max-width: 767px) {
	.wrapper {
		padding: 40px 0;
	}
	
	.wrapper_larghezza {
		width: 620px;
	}
	
	header.main_header .wrapper_larghezza {
		width: auto;
		margin-left: 20px !important;
		margin-right: 20px !important;
	}
	.header_wrapper img {
		max-height: 60px;
	}
	
	/* hamburger */ 
	.header_wrapper .menu_status {
		opacity: 0;
	}
	.header_wrapper .menu_status + label {
		display: block;
		width: 30px;
		height: 30px;
	}
	.header_wrapper .menu_status + label + .link_wrapper {
		display: flex;
		flex-direction: column;
		align-items: center;
		position: absolute;
		z-index: 10;
		top: 100%;
		left: -20px;
		right: -20px;
		overflow: hidden;
		height: 0;
		padding: 0;
		transition: height .4s, padding .4s;
		interpolate-size: allow-keywords;
		background: #202e43ff;
	}
	.header_wrapper .menu_status:checked + label + .link_wrapper {
		height: auto;
		padding: 40px 20px;
	}
	.header_wrapper .menu_status:checked + label + .link_wrapper .link {
		flex-direction: column;
	}
	.header_wrapper .menu_status + label + .link_wrapper ul a {
		display: block;
		padding: 10px;
		text-align: center;
		font-size: 1.2em;
		color: #ffffffff;
	}
	
	.header_wrapper .menu_status + label {
		width: 45px;
		height: 45px;
		box-sizing: border-box;
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		padding: 10px 5px;
	}
	.header_wrapper .menu_status + label::before, 
	.header_wrapper .menu_status + label::after {
		content: "";
		transition: all  0.3s;
	}
	.header_wrapper .menu_status + label span {
		transition: opacity  0.3s;
	}
	.header_wrapper .menu_status + label::before, 
	.header_wrapper .menu_status + label::after,
	.header_wrapper .menu_status + label span {
		height: 4px;
		border-radius: 3px;
		transform-origin: center left;
		background: #00a3d6ff;
	}
	.header_wrapper .menu_status:checked + label span {opacity: 0;}
	.header_wrapper .menu_status:checked + label::before,
	.header_wrapper .menu_status:checked + label::after {
		translate: 8px;
		scale: 0.86;
	}
	.header_wrapper .menu_status:checked + label::before {
		rotate: 45deg;
	}
	.header_wrapper .menu_status:checked + label::after {
		rotate: -45deg;
	}
	
	.footer_wrapper > div > div {
		align-items: center;
	}
	
	.video_wrapper {
		width: auto;
		margin: auto 20px;
	}
}

@media screen and (max-width: 639px) {
	.wrapper_larghezza {
		width: auto;
		margin-left: 20px !important;
		margin-right: 20px !important;
	}
	.wrapper_larghezza .wrapper_larghezza {
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
	
	.wrapper_larghezza.col_50,
	.wrapper_larghezza.col_33,
	.wrapper_colonna_immagine {
		flex-direction: column;
		gap: 30px
	}
	.wrapper > .col_50 > * {width: auto}
	.wrapper > .col_33 > * {width: auto}
	
	.wrapper_colonna_immagine .colonna_immagine img {
		position: static;
		width: 100%;
		height: auto;
		max-height: none !important;
		display: block;
		margin-bottom: -10%;
	}
	
	.wrapper_larghezza .wrapper_larghezza {
		width: auto;
	}
	
	.wrapper h1, 
	.wrapper .titolo1, 
	.wrapper h2, 
	.wrapper .titolo2, 
	.wrapper h2::before, 
	.wrapper .titolo2::before, 
	.wrapper h3, 
	.wrapper .titolo3, 
	.wrapper h4, 
	.wrapper .titolo4, 
	.wrapper_colonna_immagine > div h1, 
	.wrapper_colonna_immagine > div .titolo1, 
	.wrapper_colonna_immagine > div h2, 
	.wrapper_colonna_immagine > div .titolo2, 
	.wrapper_colonna_immagine > div h2::before, 
	.wrapper_colonna_immagine > div .titolo2::before, 
	.wrapper_colonna_immagine > div h3, 
	.wrapper_colonna_immagine > div .titolo3, 
	.wrapper_colonna_immagine > div h4, 
	.wrapper_colonna_immagine > div .titolo4 {
		text-align: center !important;
	}
	.wrapper h2::after, 
	.wrapper .titolo2::after, 
	.wrapper_colonna_immagine > div h2::after, 
	.wrapper_colonna_immagine > div .titolo2::after {
		margin-left: -30px !important;
		left: 50% !important;
	}

	.wrapper_colonna_immagine .testo, 
	.wrapper_colonna_immagine .bottone_singolo {
		text-align: center;
	}
	.wrapper .col_50 .testo,
	.wrapper .col_50 .bottone_singolo {
		text-align: center;
	}
	
	.elenco_blocchi.col_2 ul li,
	.elenco_blocchi.col_3 ul li,
	.wrapper .elenco_step ul li {
		flex-basis: 100%;
	}
	
	.link_social {
		justify-content: center !important;
	}
	
	.immagine_doppia {
		aspect-ratio: 1.2;
		height: auto;
	}
	.immagine_doppia img {
		margin-right: -60px;
		width: 70%;
	}
	.col_50 > div:nth-child(2) .immagine_doppia {
		margin-left: 60px;
	}
	.col_50 > div:nth-child(2) .immagine_doppia img {
		margin-left: -60px;
	}
}
@media screen and (max-width: 579px) {
}

@media screen and (max-width: 379px) {
}
