/* ================
SVR
===================*/

:root {
	--color1: #252f7f;
	--color2: #B30000;
	--color3: #8C3200;
	--color4: #2748ce;
	--font: "Lato";
	--wLight: 300;
	--wNormal: normal;
	--wBold: bold;
}

.c1 {
	color: var(--color1);
}

.c2 {
	color: var(--color2);
}

.c3 {
	color: var(--color3);
}

.c4 {
	color: var(--color4);
}

.wBold {
	font-weight: var(--wBold);
}

.wNormal {
	font-weight: var(--wNormal);
}

.wLight {
	font-weight: var(--wLight);
}

.cc-window {
	font-size: .85rem !important;
	line-height: 1.2em !important;
}

@media (max-width:767px) {
	.cc-window {
	font-size: .75rem !important;
	line-height: 1.1em !important;
	}
}

body {
  font-family: var(--font), sans-serif;
  font-weight: var(--wLight);
  font-style: normal;
	color: black;
}

h1, h2, h3, b, strong {
	font-weight: var(--wBold);
	color: black;
}

.big {
	font-size: 4rem;
	opacity: 0.65;
}

.big_1 {
	font-size: 4rem;
}

.big_2 {
	font-size: 3rem;
}

a {
	font-weight: var(--wBold);
	color: black;
	text-decoration: underline;
}

.text_celeste {
	color: #ce0e2d;
}

.bg_gray {
	background-color: #e6e6e6;
}

.sfondo {
	margin-bottom: 0rem;
}

/* ================
MENU
===================*/

.skip-to-main-content-link {
	position: absolute;
	left: -9999px;
	z-index: 999;
	padding: 1em;
	background-color: black;
	color: var(--c5);
	opacity: 0;
}

.skip-to-main-content-link:focus {
	left: 50%;
	transform: translateX(-50%);
	opacity: 1;
}

#menu {
	background-color: white;
	position: relative;
	box-shadow: 0px 0px 4px rgba(0,0,0,.4);
}

#logo {
	max-height: 35px;
	width: auto;
}

#menu_list li {
	list-style-type: none;
	float: left;
	padding-left: 18px;
	position: relative;
}

#menu_list li a {
	font-weight: var(--wLight);
	display: block;
	text-align: center;
	color: black;
	text-decoration: none;
	font-size: 18px;
	padding: 5px 0px;
}

.active {
	color: #ce0e2d;
	font-size: 1.5rem;
	vertical-align: bottom;
}

#menu_list li a.active, #menu_list li a:hover  {
	display: block;
	text-align: center;
	font-weight:  var(--wBold);
	color: #ce0e2d;
	text-decoration: none;
	padding: 5px 0px;
}

@media screen and (max-width: 992px) {
	#menu_list li {
		list-style-type: none;
		float: left;
		padding-left: 10px;
		position: relative;
		width: 100%;
	}
}

/* ================
FORM
===================*/
#loghi {
	position: relative;
	top: -25%;
}

#errore{
	text-align: center;
	color: red;
	padding: 25px;
	font-size: 24px;
	font-weight: bold;
}

label {
	display: inline-block;
}

.small {
	font-size: 70%;
}

#form_container {
	padding: 2vw 2vw 0px 2vw;
}

.button {
	background-color: #ce0e2d;
	color: white;
	border: 0px solid transparent;
	border-radius: 5px;
	font-size: 1.4rem;
	padding: .5rem 2.5rem;
	font-weight: var(--wNormal);
	text-decoration: none !important;
	text-align: center;
	max-width: 450px;
}

.button:hover {
	color: #ededed;
}

.button-light {
	font-size: 1.2rem;
	padding: .3rem 1.5rem;
}

@media (max-width:576px) {
	.button {
		font-size: 1.2rem;
		padding: .2rem 1.5rem;
		max-width: 250px;
	}
}

/* ================
FOOTER
===================*/

footer {
	background-color: transparent;
	text-align: center;
	padding: 1rem 0px 0px 0px;
	/*box-shadow: 0px -1px 4px rgba(0,0,0,.4);*/
}

footer p {
	font-size: 0.85rem;
}

footer a, footer a:hover {
	display: inline;
	text-decoration: underline;
	font-weight: var(--wBold);
}

.effetto_scroll {
  justify-content: center !important;
}

@media (max-width: 991px) {
.effetto_scroll {
  justify-content: left !important;
	overflow-x: auto !important;
	flex-wrap: nowrap !important;
}
}

@media (max-width: 575px) {
	#mailto {
		font-size: 1rem;
		word-break: break-all;
	}
}

/* ================
AREA PERSONALE
===================*/

.thumbnail {
	max-height: 50px;
}
