@import url("_reset.css");
@import url("_columns.css");
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;700&family=Roboto:wght@300;400;700;900&display=swap');

/* struttura */
	html { font-family: 'Montserrat', sans-serif; font-size:16px;  }
	#wrapper { position:relative; z-index:1; width:100%; overflow:hidden; letter-spacing:.3px; margin:0 auto; max-width:2560px; }
	.innerTpl { position:relative; max-width:1920px; margin:0 auto; }
	.hide-desktop { display:none; }
	::-webkit-scrollbar              { background:#444444; width:5px; height:5px; }
	::-webkit-scrollbar-button       { }
	::-webkit-scrollbar-track        {}
	::-webkit-scrollbar-track-piece  { }
	::-webkit-scrollbar-track-piece:start {  }
	::-webkit-scrollbar-thumb        { background:#444444; }
	::-webkit-scrollbar-thumb:window-inactive { }
	::-webkit-scrollbar-button:horizontal:decrement:hover {}
	::-webkit-scrollbar-corner       { }
	::-webkit-resizer                { }

/* testi */
	h1, h2, h3, h4, .title, .subtitle, .text { position:relative; -webkit-font-smoothing: antialiased; word-wrap: break-word; font-smoothing: antialiased; color:#000; }
	h1, h2, h3, h4, .title { font-family: 'Roboto', sans-serif; margin-bottom:35px; }
	h1,
		.title { font-size:2.75rem; line-height:3.25rem; font-weight:700; }
    h1 a { color: #000; border-bottom:1px solid #000;  }
    h1 a:hover { border-color:transparent; }
	h2,
		.subtitle { font-size:2rem; line-height:2.5rem; font-weight:700; }
    h2 a { color: #000; border-bottom:1px solid #000;  }
    h2 a:hover { border-color:transparent; }
	h3 { font-size:1.5rem; line-height:2rem; font-weight:300; }
    h3 a { color: #000; border-bottom:1px solid #000;  }
    h3 a:hover { border-color:transparent; }
	h4 { font-size:1.25rem; line-height:1.75rem; font-weight:700; }
	.text { font-size:1.15rem; line-height:1.75rem; }
	.text p { margin:0 0 15px 0; }
	.text img { max-width:100% !important; height:auto !important; }
	.title a,
		.subtitle a,
		.text a { color:#000; border-bottom:1px solid #000; -webkit-transition: .25s ease-in-out; -moz-transition: .25s ease-in-out; -o-transition: .25s ease-in-out; transition: .25s ease-in-out;  }
	.title a:hover,
		.subtitle a:hover,
		.text a:hover { border-color:transparent; }
	.title ul li,
		.subtitle ul li,
		.text ul li { list-style-type:disc; margin-left:25px; }
	.title ol li,
		.subtitle ol li,
		.text ol li { list-style-type:decimal; margin-left:25px; }
	strong, b { font-weight:700; }
	em, .em { font-style:italic; color:#999; }
	.em p:before { content: "\f10d"; font-family: "Font Awesome 6 Pro"; font-weight:700; position:relative; top:-10px; left:-15px; color:#aaa; }
	.em p:after { content: "\f10e"; font-family: "Font Awesome 6 Pro"; font-weight:700; position:relative; top:10px; right:-15px; color:#aaa; }

/* misc */
	hr { background:#DDD; height:1px; color:#DDD; border:0; margin:20px 0; width:100%; }
	hr:after { content: ""; display: block; clear:both; }
	.fa, .fab, .fad, .fal, .far, .fas { color:#000; font-size:24px; position:relative; margin:0 3px; }
	.button { font-size:0.875rem; text-transform:uppercase; padding:15px 45px 15px; margin:25px 0 0 0; text-align:center; display:inline-block; color:#FFF; cursor:pointer; border:0; background:#000; -webkit-transition: .5s ease-in-out; -moz-transition: .5s ease-in-out; -o-transition: .5s ease-in-out; transition: .5s ease-in-out; }
		.button:hover { background:#444444; }
	.button.right { float:right; }
	.transition-050 { -webkit-transition: .5s ease-in-out; -moz-transition: .5s ease-in-out; -o-transition: .5s ease-in-out; transition: .5s ease-in-out; }
	.transition-025 { -webkit-transition: .25s ease-in-out; -moz-transition: .25s ease-in-out; -o-transition: .25s ease-in-out; transition: .25s ease-in-out; }
	#goToTop { position:fixed; z-index:3; right:-51px; bottom:45px; border:0; width:48px; height:48px; background:#000; display:block; cursor:pointer; text-align:center; opacity: 0.5; }
		#goToTop:hover { background:#444444; opacity: 1; }
	#goToTop i { color:#FFF; line-height:48px; font-size:30px; }
		#goToTop:hover i { color:#FFF; }	

/* header */
	.header { position:relative; width:100%; z-index:5; background:#FFF; }
		.header:after { content: ""; display: block; clear:both; }
	.header .column { height:150px; -webkit-transition: .5s ease-in-out; -moz-transition: .5s ease-in-out; -o-transition: .5s ease-in-out; transition: .5s ease-in-out; overflow:visible;  }
	.header .column img.logo { margin-top:25px; max-height:100px; -webkit-transition: .5s ease-in-out; -moz-transition: .5s ease-in-out; -o-transition: .5s ease-in-out; transition: .5s ease-in-out;  }
	
	.header .text { font-size:1rem; float:right; margin:47px 100px 0 0; color:#999; }
		body.scrolled .header .text { margin-top:25px; }
	.header .text a { color:#999; border-color:#DDD; padding-bottom:2px; }
		.header .text a:hover {  border-color:transparent; }
	
	.header .navOpenButton { float:right; width: 40px; height: 40px; position: relative; margin:50px 0px 0 0; -webkit-transform: rotate(0deg); -moz-transform: rotate(0deg); -o-transform: rotate(0deg); transform: rotate(0deg); cursor: pointer; }
	.header .navOpenButton span { display: block; position: absolute; height: 2px; width: 100%;  background:#000; border-radius:1px; opacity:1; left: 0; -webkit-transform: rotate(0deg); -moz-transform: rotate(0deg); -o-transform: rotate(0deg); transform: rotate(0deg); }
		.header .navOpenButton:hover span { width: 40px !important; }
	.header .navOpenButton span:nth-child(1) { top: 0px; width: 40px; }
	.header .navOpenButton span:nth-child(2) { top: 8px; width: 40px; }
	.header .navOpenButton span:nth-child(3) { top: 16px; width: 32px; left:8px; }
		.header .navOpenButton:hover span:nth-child(3) { left:0; }
	.header .navOpenButton.open span:nth-child(1) { width:40px; left:0; top: 10px; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); -o-transform: rotate(135deg); transform: rotate(135deg); }
	.header .navOpenButton.open span:nth-child(2) { opacity: 0; }
	.header .navOpenButton.open span:nth-child(3) { width:40px; left:0; top: 10px; -webkit-transform: rotate(-135deg);  -moz-transform: rotate(-135deg); -o-transform: rotate(-135deg); transform: rotate(-135deg); }	
	
	.header .chooseLang { float:right; padding:10px 0 0 0; vertical-align:top; width:70px; padding-right:25px; background:url(../images/misc/open-choose-lang.png) right 16px no-repeat; cursor:pointer; }
	.header .chooseLang a {  font-size:1.125rem; line-height:1.125rem; color:#000; display:none; margin-bottom:7px; width:inherit; text-align:left; }
	.header .chooseLang a:hover { font-weight:700; }
	.header .chooseLang.open a:last-child { padding-bottom:10px; }
	.header .chooseLang a.selected { display:block;font-weight:700;  }

		body.scrolled .header { position:fixed; box-shadow: 0 0 15px 1px rgb(0 0 0 / 20%); }
		body.scrolled .header .navOpenButton { margin-top:30px; }
		body.scrolled .header .column { height:80px; }
		body.scrolled .header .column img.logo { margin-top:10px; max-height:55px; }

/* nav */
	#navMobileBg { display:none; position:fixed; z-index:3; top:0; left:0; height:100%;  background:#444444; width:33.3%; }
	
	#navMobile { position:fixed; top:0; left:-100%; z-index:4; width:33.3%; height:100%; overflow-y:auto; }
	#navMobile .menu { padding:150px 4% 100px 8%; margin:0 auto; }
	#navMobile .menu ul {   }
	#navMobile .menu ul li { position:relative; }
	#navMobile .menu ul li:first-child { padding-top:0; }
	#navMobile .menu ul li.l1 { margin-top:10px; }
		#navMobile .menu ul li.l1[attr="0"]:after { content:""; display:none; }
	#navMobile .menu ul li a { color:#FFF; }
	#navMobile .menu ul li.l1 { padding:5px 0; }
	#navMobile .menu ul li.l1 a {  font-size:2.25rem; line-height:2.5rem; font-weight: 700; }
	#navMobile .menu ul li a:hover { color:#CCC;   }
	#navMobile .menu ul.l2 { margin:0; padding:10px 0 25px 40px;  }
	#navMobile .menu ul li.l2 { padding:6px 0;}
	#navMobile .menu ul li.l2 a { font-size:1.15rem; font-weight: 600; }
	#navMobile .menu ul li.on a { font-weight: 700; }
	#navMobile .menu ul li .open { display:inline-block; margin:0 0 0 10px;  position:relative; top:-4px; cursor:pointer; opacity:0.7; }
		#navMobile .menu ul li .open:after { content: "\f078"; font-family: "Font Awesome 6 Pro"; font-weight:900; font-size: 16px; color:#FFF; line-height:1.75rem; }
			#navMobile .menu ul li .open.active:after { content: "\f077"; }
		#navMobile .menu ul li .open:hover { opacity:1; }
	#navMobile .navOpenButton { z-index:10; top:60px; left:8%; width: 40px; height: 40px; position: relative; -webkit-transform: rotate(0deg); -moz-transform: rotate(0deg); -o-transform: rotate(0deg); transform: rotate(0deg); cursor: pointer; }
	#navMobile .navOpenButton span { display: block; position: absolute; height: 2px; width: 100%;  background: #FFF; opacity: 1; left: 0; -webkit-transform: rotate(0deg); -moz-transform: rotate(0deg); -o-transform: rotate(0deg); transform: rotate(0deg); }
	#navMobile .navOpenButton:hover span { background:#FFF; }
	#navMobile .navOpenButton span:nth-child(1) { top: 0px; width: 40px; }
	#navMobile .navOpenButton span:nth-child(2) { top: 8px; width: 40px; }
	#navMobile .navOpenButton span:nth-child(3) { top: 16px; width: 32px; }
	#navMobile .navOpenButton.open span:nth-child(1) { width:34px; top: 10px; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); -o-transform: rotate(135deg); transform: rotate(135deg); }
	#navMobile .navOpenButton.open span:nth-child(2) { opacity: 0; }
	#navMobile .navOpenButton.open span:nth-child(3) { width:34px; top: 10px; -webkit-transform: rotate(-135deg);  -moz-transform: rotate(-135deg); -o-transform: rotate(-135deg); transform: rotate(-135deg); }	
	
	#nav2 { margin:0 auto 30px auto; }
	#nav2:after { content: ""; display: block; clear:both; }
	#nav2 .c10 { border-top:1px solid #000; border-bottom:1px solid #000; padding:15px 0; }
	#nav2 ul { }
	#nav2 ul li { display:inline-block; }
	#nav2 ul li.sep { margin:0 20px; width:1px; background:#000; height:15px; }
	#nav2 ul li.sep:nth-child(2) { display:none; }
	#nav2 ul li.parent { margin:0 30px 0 0; }
	#nav2 ul li.lv2 a,
		#nav2 ul li.parent a { font-size:0.95rem; line-height:1.75rem; color:#000; font-weight:700; }
	#nav2 ul li.parent a { background:#444444; padding:5px 7px; text-transform:uppercase; }
	#nav2 ul li.lv2 a:hover { border-bottom:1px solid #000; }
	#nav2 ul li.lv2 a.on { color:#FFF; background:#000; padding:5px 7px; }
	#nav2 ul li.lv2 a.on:hover { border-bottom:0; }


/* footer */
	#footer { background:#666; padding:80px 0 100px 0; margin:50px 0 0 0;  }
	#footer:before { content: ""; display: block; clear:both; }
	#footer:after { content: ""; display: block; clear:both; }
	#footer .text { font-size:1rem; line-height:2rem; color:#FFF; }
	#footer .title a, 
		#footer .text a { color:#FFF; border:0; }
	#footer .title a:hover, 
		#footer .text a:hover { border-bottom:1px solid #666; }
	
	#footer .social { float:right; padding:0; }
		#footer .social .text { font-size:0.9rem; font-weight:700; margin:8px 20px 0 0; float:left; text-transform:uppercase; }
	#footer .social i { color:#FFF; position:relative; font-size:30px; text-align:center; padding:6px 5px 4px 6px; }
		#footer .social i:hover { color:#CCC; }
	#footer .social i a { position:absolute; top:0; left:0; width:100%; height:100%; }		
	
	
/* form */
	form { position:relative; }
	form .column { padding:0 0 30px 0; }	
	
	form input,
		form select,
		form textarea,
		form label {  font:400 16px/45px 'Roboto', sans-serif; position:relative; color:#000; -webkit-box-sizing:border-box; box-sizing: border-box; }
	form input,
		form select,
		form textarea { border:1px solid #DDD; width:100%; padding:0 15px; margin:0 0 15px 0;  }
	form input.on,
		form select.on,
		form textarea.on { border-left:4px solid #F00; }		
	form input,
		form select { height:45px; }	
		form input.on,
			form select.on {  }
	form label .mandatory { display:inline; color:#000; font-weight:700; font-size:20px; line-height:45px; }
	form textarea { height:100px;}
	form input.checkbox { width:20px; height:20px; border:1px solid #CCC; }

/* share */
	#share	{ border-top:1px solid #CCC; border-bottom:1px solid #CCC; padding:0 0 15px 0; margin:100px 0 50px 0; text-align: center; }
	#share .text { color:#000; display:inline-block; margin:0 10px 0 0; position:relative; top:25px; line-height:50px; }
	#share .inner { display:inline-block; }
	#share i { color:#000; border:1px solid #000; font-size:22px; line-height:50px; border-radius:50%; height:50px; width:50px; font-weight:300; }
	#share i:hover { color:#000; background:#000; }
	#share i:hover:before { color:#FFF;  }

/* template */
	#template { position:relative; z-index:1; width:100%; height:100%; margin:0; padding-top:0;  }
		body.scrolled #template { padding-top: 80px; }

/* plugin */
	.slideshow { width:100%; height:100%; }
	.slideshow .item { position:relative; height:600px; }
	.slideshow .item .url { position:absolute; top:0; left:0; width:100%; height:100%; z-index:3; }
	.slideshow .item .innerTpl { height:inherit; }
	.slideshow .slick-arrow { top:calc(50% - 22px); z-index:2; display:inline-block; cursor:pointer; padding:0; width:auto; height:auto; font-weight:300;  }
	.slideshow .slick-arrow:before { font-family: "Font Awesome 6 Pro"; color:#FFF; opacity:.6; font-size:45px;  display: inline-block; }
		.slideshow .slick-arrow:hover:before { color:#FFF; opacity:1; }
	
	.slideshow .slick-arrow.slick-prev { left:30px; }
		.slideshow .slick-arrow.slick-prev:before { content: "\f053"; width:50px; height:50px; display:block; }
		.slideshow .slick-arrow.slick-prev:hover:before {  }
	.slideshow .slick-arrow.slick-next { right:30px;  }
		.slideshow .slick-arrow.slick-next:before { content: "\f054"; width:50px; height:50px; display:block; }
		.slideshow .slick-arrow.slick-next:hover:before {  }
	.slideshow .slick-dots { text-align:center; left:0; right:0; margin:auto; padding:0; bottom:30px; z-index:10;  }
	.slideshow .slick-dots li  { display:inline-block; }
	.slideshow .slick-dots li button { display: block; text-indent: -9999em; text-transform:uppercase; cursor:pointer; float:left; width: 18px;height: 18px; background: #CCC; border:0; border-radius:15px; margin:0 4px; }
	.slideshow .slick-dots li:hover button{ background:#444444;}
	.slideshow .slick-dots li.slick-active button { background:#444444; }
	

/* sezioni */
	section.section { position:relative; padding:50px 0; }
	section.section:before { content: ""; display: block; clear:both; }
	section.section:after { content: ""; display: block; clear:both; }


@media (max-width: 1921px) {

/* testi */
	
/* header */
	.header .column { height:140px; }	
	.header .column img.logo { max-height:90px; margin-top:20px; }
	
/* nav */	

/* sezioni */

	
}

@media (max-width: 1441px) {

/* testi */
	
/* struttura */	
	#wrapper .innerTpl { max-width:100%; }	
	
/* header */
	.header .column { height:120px; }	
	.header .column img.logo { max-height:70px; margin-top:25px; }	
	
/* nav */	
	
/* sezioni */
	section.section { padding:30px 0; }

}

@media (max-width: 1281px) {

/* struttura */	
	html { font-size: 14px; }

/* header */
	.header .column { height:100px; }	
	.header .column img.logo { max-height:60px; margin-top:20px; }
	
/* nav */	
		

/* plugin */

	
/* sezioni */

}

@media (max-width: 1025px) {


	
/* struttura */	
	html { font-size: 13px; }
	.hide-desktop  { display:block; }
	.hide-tablet { display:none; }	

/* nav */
	#navMobile,
		#navMobileBg { width:50%; }
	
/* misc */	
	

/* header */	
    .header .text { margin-top:40px; }
    .header .navOpenButton { margin-top:43px; }

	
/* footer */
	#footer .c3 { min-height:300px;  }
	
/* plugin */	
	.slideshow .item { height:500px; }
	
/* sezioni */

}



@media only screen 
	and (min-device-width : 768px) 
	and (max-device-width : 1024px) 
	and (orientation : portrait) { 

}

@media (max-width: 769px) {

/* testi */
	em, .em { font-size:2rem; line-height:2.5rem; }
	.em p:before { font-size: 30px; line-height:2.5rem;  }
	.em p:after { font-size: 30px; line-height:2.5rem; }
	
/* struttura */	
	html { font-size: 12px; }

/* nav */
	#navMobile,
		#navMobileBg { width:60%; }
	#nav2 .c10 { overflow-x: auto;  }
	#nav2 ul { width:max-content; }
		
/* misc */	
	hr { margin:15px 0; }

/* headder */	
		
/* footer */

/* plugin */	
	.slideshow .item { height:400px; }
	
/* sezioni */

	
/* footer */	
	#footer { padding:75px 0 100px; margin:30px 0 0 0; }
	#footer .tp12 { padding:25px 0; text-align:center; }
	#footer .social { float:none; }
	#footer .social .text { display:block; float:none; margin:0 0 -5px 0; }
}

@media (max-width: 641px) {

/* struttura */	
	html { font-size: 14px; }	
	.hide-desktop  { display:block; }
	.hide-tablet { display:block; }
	.hide-mobile { display:none; }

/* misc */	

/* testi */
	em, .em { font-size:1.75rem; line-height:2.25rem; }
	.em p:before { font-size:26px; line-height:2.25rem;  }
	.em p:after { font-size:26px; line-height:2.25rem; }
	
/* header */	
	.header .text { display:none; }
	
/* nav */	
	#navMobile,
		#navMobileBg { width:100%; }	
	#navMobile .menu { padding-top:100px; }

/* plugin */
	.slideshow .slick-arrow.slick-prev { left:10px; }
	.slideshow .slick-arrow.slick-next { right:10px; }

/* footer */
	#footer .c3 { min-height:auto;  }

/* plugin */	
	.slideshow .item { height:300px; }
		
/* sezioni */

}

@media (max-width: 321px) {
		
}


