@import url("_reset.css");
@import url("_columns.css");
@import url("_sections.css");
@import url("_modules.css");
@import url("_plugins.css");
/* @import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;700&family=Roboto:wght@300;400;700;900&display=swap'); */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap');


/* struttura */
html { font-family: "Lato", sans-serif; font-size:16px; background:var(--css-html-bg-color);  }
#wrapper { position:relative; z-index:1; width:100%; overflow:hidden; letter-spacing:.3px; margin:0 auto; max-width:2560px; }
.innerTpl { position:relative; max-width: var(--css-innerTpl-max-width); margin:0 auto; }
.hide-desktop { display:none; }
::-webkit-scrollbar { background:#EEE; width:10px; height:5px; }
::-webkit-scrollbar-button { }
::-webkit-scrollbar-track { }
::-webkit-scrollbar-track-piece { }
::-webkit-scrollbar-track-piece:start {  }
::-webkit-scrollbar-thumb { background:var(--css-color-active); }
::-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; }
h1, h2, h3, h4, .title { font-family: "DM Serif Display", serif; margin-bottom:35px; }
h1,
.title { font-size:2.75rem; line-height:3.25rem; font-weight:600; color: var(--css-font-title-color); }
h2,
.subtitle { font-size:2rem; line-height:2.5rem; font-weight:400; color: var(--css-font-subtitle-color); }
h3 { font-size:1.5rem; line-height:2rem; font-weight:400; color: var(--css-font-subtitle-color); }
h4 { font-size:1.25rem; line-height:1.75rem; font-weight:400; color: var(--css-font-subtitle-color); }
.kicker { font-size:1.375rem; line-height:1.5rem; font-weight:400; color: var(--css-font-text-color); margin-bottom: 50px; text-transform: uppercase; }
.text { font-size:1.15rem; line-height:1.75rem; color: var(--css-font-text-color); }
.text p { margin:0 0 15px 0; }
.text img { max-width:100% !important; height:auto !important; }
h1 a,
h2 a,
h3 a,
h4 a,
.title a,
.subtitle a,
.text a { color: var(--css-font-text-link-color); border-bottom:1px solid var(--css-font-text-link-color); -webkit-transition: .25s ease-in-out; -moz-transition: .25s ease-in-out; -o-transition: .25s ease-in-out; transition: .25s ease-in-out;  }
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
.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; }

/* 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:var(--css-button-color); 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:var(--css-button-color); -webkit-transition: .5s ease-in-out; -moz-transition: .5s ease-in-out; -o-transition: .5s ease-in-out; transition: .5s ease-in-out; border-radius: 8px 8px 0 8px; }
.button:hover { background:var(--css-button-color-active); }
.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:var(--css-button-color); display:block; cursor:pointer; text-align:center; opacity: 0.5; border-radius: 50% 50% 0 50%; }
#goToTop:hover { background:var(--css-color-active); opacity: 1; }
#goToTop i { color:#FFF; line-height:48px; font-size:30px; }
#goToTop:hover i { color:#FFF; }	
#easyMessage { position:fixed; top:0px;  z-index:990; width:100%; height:100%;  }
#easyMessage .bg { z-index:991; position:absolute; top:0; left:0; width:100%; height:100%; background:#FFF; opacity:0.7;  }
#easyMessage .content { z-index:991; position:absolute; top:30%; width:500px; left:calc(50% - 300px);  padding:25px; background:#FFF; min-height:100px; border:1px solid #DDD; }
#easyMessage .content .close { position:absolute; z-index:991;  top:20px; right:20px; cursor:pointer; font-size:30px; color:#BBB; }
#easyMessage .content .close:hover { color:#005da7; }
#easyMessage .content .title { font-size:1.25rem; line-height:1.5rem; margin:0 0 20px 0; max-width:calc(100% - 40px); color:#005da7; }
#easyMessage .content .text { font-size:1.05rem; line-height:1.85rem; color:#666; }

.wrapper-image, .wrapper-image img.media { border-radius: 20px 20px 0 20px; }

/* header */
.pre-header { height: 40px; padding: 10px 0; background: #EEE; text-align: center; }
.pre-header p { margin: 0; }
.pre-header .text { color: #AAA; font-size: 1.05rem; line-height: 40px; font-weight: 300; }
.pre-header .text a { color: #AAA; border-bottom: 1px solid #CCC; }
.pre-header .text a:hover { border-color:transparent; }
    body.scrolled .pre-header { display:none; }

.header { position:relative; width:100%; z-index:5; background:var(--css-header-bg-color); }
.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 .button { font-size:1rem; float:right; margin:45px 0 0 20px; padding: 7px 15px; }
    body.scrolled .header .button { margin-top:15px; }
.header .button a { color:#FFF; border-color:#DDD;  }
    .header .button:hover a {  border-color:transparent; }
.header .button p { margin-top:-4px; }
.header .button p:before { font-family: "Font Awesome 6 Pro"; font-weight:300; font-size: 20px; color:#FFF; line-height:1.75rem; position:relative; top:2px; display: inline-block; margin-right:10px; }
.header .button.phone p:before { content: "\f095"; }
.header .button.email p:before { content: "\f0e0"; }
.header .button.wa p:before { font-family: 'Font Awesome 6 Brands'; content: "\f232"; }
    .header .button:hover p:before { font-weight:700; }

.header .navOpenButton { float:right; width: 40px; height: 40px; position: relative; margin:50px 0px 0 100px; -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:var(--css-color-active); 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: 40px; }
.header .navOpenButton:hover span:nth-child(1) { left:0; right:4px; width: 28px !important; }
.header .navOpenButton:hover span:nth-child(3) { left:12px; width: 28px !important; }
.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 .navOpenButton .label-menu { text-transform: uppercase; font-size: .75rem; line-height: 1.5rem; position: absolute; bottom: -2px; width: 100%; text-align: center; }
.header .navOpenButton:hover .label-menu { color:  var(--css-color-active); }

.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:20px; }
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; right:0; height:100%; width:40%; background: transparent linear-gradient(300deg, var(--css-verde-001) 0%, var(--css-verde-002) 35%, var(--css-verde-003) 60%,  var(--css-verde-004) 100%) 0% 0% no-repeat padding-box; }

#navMobile { position:fixed; top:0; right:-100%; z-index:4; width:40%; height:100%; overflow-y:auto; }
#navMobile .menu { padding:150px 4% 100px 8%; margin:0 auto; }
#navMobile .menu ul {   }
#navMobile .menu ul li { position:relative; width: fit-content; }
#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; font-family: "DM Serif Display", serif;  }
    #navMobile .menu ul li a:after { transition: width .3s; display: block; position: absolute; content: ""; border-bottom: 2px solid #FFF; margin-top: 3px; left: 0; right: 0; width: 0; height: 1px; }
    #navMobile .menu ul li a:hover::after { width:50px; }
#navMobile .menu ul li.l1 { padding:5px 0; }
#navMobile .menu ul li.l1 a {  font-size:2.25rem; line-height:2.5rem; font-weight: 400; }
#navMobile .menu ul.l2 { margin:0; padding:10px 0 25px 40px;  }
#navMobile .menu ul li.l2 { padding:9px 0;}
#navMobile .menu ul li.l2 a { font-size:1.5rem; line-height:1.5rem; font-weight: 400; }
    #navMobile .menu ul li.l2 a:hover:after  { width:50px; }
#navMobile .menu ul li.on a { font-weight: 400; }
#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: "\f067"; font-family: "Font Awesome 6 Pro"; font-weight:900; font-size: 18px; color:#FFF; line-height:1.75rem; position:relative; top:2px; }
        #navMobile .menu ul li .open.active:after { content: "\f068"; }
    #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:#88bc24; 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:var(--css-footer-bg-color); 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 .c4 { padding-right: 4%; }
#footer .text { font-size:1rem; line-height:1.75rem; color:#666; }
#footer .title a, 
#footer .text a { color:#666; border-bottom:1px solid #CCC; padding-bottom: 2px; }
#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:10px 20px 0 0; float:left; text-transform:uppercase; }
#footer .social i { color:var(--css-button-color); position:relative; font-size:36px; text-align:center; padding:6px 5px 4px 6px; font-weight: 700; }
#footer .social i:hover { opacity:0.6; }
#footer .social i a { position:absolute; top:0; left:0; width:100%; height:100%; }	

#footer .social i.fa-facebook { color: #3b5998; }
#footer .social i.fa-instagram { color: #DD2A7B; }

#incipit  { background:var(--css-footer-bg-color); padding: 15px 0; text-align: center; }
#incipit .text { font-size: 0.9rem; line-height: 1.5rem; color: #AAA; }
#incipit .text a { color: #AAA; border-color:#ccc; }
#incipit .text a:hover { color: #000; border-color: transparent;}	

/* form */
form { position:relative; }
form .column { padding:0 0 30px 0; }	

section.section input,
section.section select,
section.section textarea,
section.section label {  font:400 16px/45px "DM Serif Display", serif; position:relative; color:var(--css-font-text-color); -webkit-box-sizing:border-box; box-sizing: border-box; }
section.section input,
section.section select,
section.section textarea { border:1px solid #DDD; width:100%; padding:0 15px; margin:0 0 15px 0;  }
section.section input.on,
section.section select.on,
section.section textarea.on { border-left:4px solid #F00; }		
section.section input,
section.section select { height:45px; }	
section.section input.on,
form select.on {  }
section.section label .mandatory { display:inline; color:var(--css-font-text-color); font-weight:700; font-size:20px; line-height:45px; }
section.section textarea { height:100px;}
section.section input.checkbox { width:20px; height:20px; border:1px solid #CCC; }

/* template */
#template { position:relative; z-index:1; width:100%; height:100%; margin:0; padding-top:0;  }
    body.scrolled #template { padding-top: 80px; }

/* sezioni */

@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 */

}

@media (max-width: 1281px) {

/* struttura */	
html { font-size: 14px; }

/* header */
.header .column { height:100px; }	
.header .column img.logo { max-height:55px; margin-top:20px; }
.header .navOpenButton { margin-top:35px; }
.header .button { margin-top:30px; }

/* nav */	

/* sezioni */

}

@media (max-width: 1025px) {



/* struttura */	
html { font-size: 13px; }
.hide-desktop  { display:block; }
.hide-tablet { display:none; }	

/* nav */
	#navMobile,
		#navMobileBg { width:50%; }
    
/* header */
    .header .button { width:30px; height: 25px; text-align: center; position: relative; margin-left: 30px; }
    .header .button p { margin:0; padding: 0; }
    .header .button p:before { margin: -2px 0 0 0; line-height: 25px;}
    .header .button a { color:transparent; overflow: hidden; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }   
/*    
.header .button { font-size:1rem; float:right; margin:45px 0 0 20px; padding: 7px 15px; }
    body.scrolled .header .button { margin-top:15px; }
.header .button a { color:#FFF; border-color:#DDD;  }
    .header .button:hover a {  border-color:transparent; }
.header .button p { margin-top:-4px; }
.header .button p:before { font-family: "Font Awesome 6 Pro"; font-weight:300; font-size: 20px; color:#FFF; line-height:1.75rem; position:relative; top:2px; display: inline-block; margin-right:10px; }
.header .button.phone p:before { content: "\f095"; }
.header .button.email p:before { content: "\f0e0"; }
.header .button.wa p:before { font-family: 'Font Awesome 6 Brands'; content: "\f232"; }
    .header .button:hover p:before { font-weight:700; }
*/    
    
    
/* footer */

/* sezioni */

}



@media only screen 
and (min-device-width : 768px) 
and (max-device-width : 1024px) 
and (orientation : portrait) { 

}

@media (max-width: 769px) {

/* testi */

/* 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; }

/* header */
.pre-header { padding: 0 0; }
.pre-header .text { font-size: 1rem;  }
    
/* footer */
#incipit .text p { text-align: center !important; }

/* 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 */	
#easyMessage .content { top:15%; width:calc(90% - 50px); left:5%; }

/* testi */
.kicker { line-height:1.75rem; }

/* header */	
.header .column img.logo { margin-top:25px; }
.header .button { margin-left:0; }
.header .button.email, .header .button.wa { display:none; }   
.header .text { display:none; }
.header .navOpenButton { margin-left: 40px; }

/* nav */	
#navMobile,
    #navMobileBg { width:100%; }		
#navMobile .menu { padding-top:100px; }

/* footer */
#footer .c3 { min-height:auto;  }

/* sezioni */

}

@media (max-width: 321px) {

}


