
/************************************/
/*** 	 01. Variabili  		  ***/
/************************************/	

:root{
	--primary-color			: #333333;/*  */ 
	--secondery-color		: #f3f3f3;
	--text-color			: #2a312f;
	--text-color-light		: #7C877F;	
	--header-bg-color		: #6593B6 ;
	--main-menulnk-color	: #ffffff;
	--footer-bg-color		: #f2f1ee;	
	--footer-text-color		: #333333; 
	--accent-color			: #0066cc;  /* #6593B6 - 3a617f - #C88F5E #7C877F;*/
	--htitle-color			: #39332a; /* 8c8585 605b53 */   
	--white-color			: #FFFFFF;
	--divider-color			: #EAF0EC;
	--dark-divider-color	: #FFFFFF;
	--header-divider-color	: #333333;
	--footer-divider-color	: #333333;
	--error-color			: rgb(230, 87, 87);
	--default-font			: "Hanken Grotesk", sans-serif;
}

@font-face {
    font-family: 'Hanken Grotesk'; 
    src: url(../webfonts/HankenGrotesk-Regular.woff) format('woff'); 
  }
  
/************************************/
/*** 	   02. Classi generiche   ***/
/************************************/

body{
	font-family: var(--default-font);
	font-size: 17.5px;
	font-weight: 100 !important;
	line-height: 1.7em;
	background-color: var(--white-color);
	color: var(--text-color); 
}
b, strong{font-weight: 600;}
p{
	/*line-height: 1.5em;*/
	margin-bottom: 1.4em;
}

h1,
h2,
h3,
h4,
h5,
h6{
	margin :0;
	font-weight: 700;
	line-height: 1.2em;
	color: var(--htitle-color);
}



h1, .h1, h1.title-style{
	font-size: 42px;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin-bottom: 18px; 
}


h2, .h2, h2.title-style{
	font-size: 36px;
	font-weight: 700;
	/*letter-spacing: -0.02em;*/
	margin-bottom: 18px; 
}

h3, .h3, h3.title-style{
	/*display: inline-block;
	position: relative;*/
	font-size: 21px;
    font-weight: bold;
	line-height: 1.6em; 
    margin-bottom: 18px; 
}
 
 
 h1.title-style span,
 h2.title-style span{
	color: var(--accent-color);
} 

h2 a {
	color: var(--htitle-color);
}
h2 a:hover {
	color: var(--accent-color);
}

figure{
	margin: 0;
}
img {
	opacity: 1;
	transition: opacity 0.3s;
 }
 img[data-src] {
	opacity: 0;
 }
a{
	text-decoration: none;
	color: var(--accent-color);
}
a.arrow::before{
	content: '';
    position: absolute;
    top: 50%;
    right: 0;
    width: 18px;
    height: 18px;
	filter: brightness(0) saturate(100%) invert(80%) sepia(1%) saturate(3447%) hue-rotate(26deg) brightness(77%) contrast(76%);
    transform: translateY(-50%) rotate(-45deg); 
    background-image: url(../svgs/solid/arrow-right.svg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
   /* transition: all 0.3s ease-in-out;*/
}
 

a:hover{
	text-decoration: none;
	outline: 0;
}

a:focus{
	text-decoration: none;
	outline: 0;
}

html,
body{
	width: 100%;
	overflow-x: clip;
}

.container{
	max-width: 1300px;
}

.container,
.container-fluid,
.container-lg,
.container-md,
.container-sm,
.container-xl,
.container-xxl{
    padding-right: 15px;
    padding-left: 15px;
}

.image-anime{
	position: relative;
	overflow: hidden;
}

.image-anime:after{
	content: "";
	position: absolute;
    width: 200%;
    height: 0%;
    left: 50%;
    top: 50%;
    background-color: rgba(255,255,255,.3);
    transform: translate(-50%,-50%) rotate(-45deg);
    z-index: 1;
}

.image-anime:hover:after{
    height: 250%;
    transition: all 600ms linear;
    background-color: transparent;
}

.reveal{
	position: relative;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    visibility: hidden;
    overflow: hidden;
}

.reveal img{
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -webkit-transform-origin: left;
    transform-origin: left;
}

.row{
    margin-right: -15px;
    margin-left: -15px;
}

.row > *{
	padding-right: 15px;
	padding-left: 15px;
}

.row.no-gutters{
    margin-right: 0px;
    margin-left: 0px;
}

.row.no-gutters > *{
    padding-right: 0px;
    padding-left: 0px;
}

.btn-default-inline{
 
    display: inline-block;
    background: var(--accent-color);
    color: var(--white-color);
    font-size: 16px;
    font-weight: 500;
    line-height: 1em; 
    border: none;
    padding: 9px 6px;
	transition: all 0.5s ease-in-out;
 
}
.btn-default-inline:hover{
	
    color: var(--white-color);
	background: var(--htitle-color); 
    transition: all 0.4s ease-in-out;
	 
}  
.btn-default{
	position: relative;
    display: inline-block;
    background: var(--accent-color);
    color: var(--white-color);
    font-size: 16px;
    font-weight: 700;
    line-height: 1em; 
    border: none;
    padding: 17px 46px 17px 20px;
    transition: all 0.5s ease-in-out;
    overflow: hidden;
    z-index: 0;
}

.btn-default:hover{
	background: transparent;
    color: var(--white-color);
}

.btn-default::before{
	content: '';
    position: absolute;
    top: 50%;
    right: 0;
    width: 16px;
    height: 16px;
    background-image: url(../svgs/solid/arrow-up-right-from-square-w.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    transform: translate(-20px, -50%);
    transition: all 0.4s ease-in-out;
}

.btn-default:hover::before{
	transform: translate(-18px, -50%);
}

.btn-default::after{
	content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: -15%;
	right: 0;
    width: 0;
    height: 106%;
    background: #605b53;
    transform: skew(45deg);
    transition: all 0.4s ease-in-out;
    z-index: -1;
}

.btn-default:hover:after{
	width: 100%;
    transform: skew(0deg);
    left: 0;
}

.btn-default.btn-highlighted{
	background-color: var(--white-color);
	color: var(--accent-color);
}

.btn-default.btn-highlighted:hover{
	color: var(--white-color);
}

.btn-default.btn-highlighted::before{
	background-image: url(../svgs/solid/arrow-up-right-from-square.svg);
}

.btn-default.btn-highlighted:hover::before{
    filter: brightness(0) invert(1);
}

.btn-default.btn-highlighted::after{
	background-color: var(--accent-color);
}

.cb-cursor:before{
	background: var(--accent-color);
}
 

.section-row{
	margin-bottom: 80px;
}

.section-row .section-title{
	margin-bottom: 0;
	margin-right: 30px;
	border:2px solid #000
}

.section-btn{
	text-align: end;
}

/*
.section-title-content{
	margin-left: 120px;
}

.section-title-content p{
	margin: 0;
}

.section-title{
	margin-bottom: 40px;
	 
} 

.section-title h2{
	font-size: 38px;
	font-weight: 700; 
	margin-bottom: 0; 
}

.section-title h1 span,
.section-title h2 span{
	color: var(--accent-color);
}

.section-title h3{
	display: inline-block;
	position: relative;
	font-size: 16px;
    font-weight: 500;
	line-height: 1.6em; 
    color: var(--accent-color);
	padding-left: 35px;
    margin-bottom: 20px;
}

.section-title h3::before{
	content: '';
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    background: url('../images/icon-sub-heading.svg');
	background-repeat: no-repeat;
	background-position: left center;
	background-size: cover;
    width: 24px;
    height: 5px;
}

.section-title p{
	margin-top: 18px;
	margin-bottom: 0;
}


.section-title-content.dark-section p,
.section-title.dark-section p,
.section-title.dark-section h2,
.section-title.dark-section h3{
	color: var(--white-color);
}

.help-block.with-errors ul{
	margin: 0;
	text-align: left;
}

.help-block.with-errors ul li{
	color: var(--error-color);
	font-weight: 500;
	font-size: 14px;
}
*/

/* SECTION COLOR */
.white-section{
	background: #fff; 
} 
.grey-section{
	background: var(--secondery-color); 
} 
.dark-section{
	background: #605b53;  
	color: var(--white-color);
} 
.dark-section p,
.dark-section h2,
.dark-section h3{
	color: var(--white-color);
}


.yellow-section{ 
background:  rgb(255 219 136 / 0.3); 
}  
.green-section{ 
background: #ececec; 
}


.gradient-yellow{
background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
--tw-gradient-from: rgb(255 206 0 / 0.05);
--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgb(255 206 0 / 0));
--tw-gradient-to: rgb(255 219 136 / 0.3);
}
.gradient-grey{
background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
--tw-gradient-from: #FFFFFF;
--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgb(255 255 255 / 0));
--tw-gradient-to: rgb(236 236 236 / 0.6);
}

.gradient-green{
background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
--tw-gradient-from: rgb(255 206 0 / 0.05);
--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgb(255 206 0 / 0));
--tw-gradient-to: #ececec; /* #0d6efd ; */
} 

.section-grey-2{
	background: #ececec;

}    


.white-section, .grey-section, .dark-section, 
.yellow-section, .green-section, .gradient-yellow,
.gradient-grey, .gradient-green, .section-grey-2
{
	/*padding: 39px 0;*/
	padding: 21px 18px;
}
  
.page-content .white-section, .page-content .grey-section, .page-content .dark-section,
.page-content .yellow-section, .page-content .green-section, .page-content .gradient-yellow,
.page-content .gradient-grey, .page-content .gradient-green, .page-content .section-grey-2
{
	padding: 21px 18px;
}


.low-section{
	padding: 33px 0 0 0 !important;
}



/* END SECTION COLOR */

/* ADD CSS */
.swiper{max-width: 800px;max-height: 600px;}
.video-container{max-width:500px}
.subtitle{
	font-size: 1.1em;
	margin-bottom: 1.3em;
	display: block;
	color: #6c757d;

}   


@media (min-width: 1300px){
	.container-fluid.container-fluid-padding{
		padding: 25px 35px; 
	}
}
.w-90{
	width:90%; 

}
.row > * {
 	word-wrap: break-word !important
}


.text-evidenza-1{
	font-size:1.2em;
	font-weight:600;

}
.text-evidenza-2{
	font-size:1.8em;
	font-weight:800;
}
.text-evidenza-3{
	font-size:2.1em
} 
.text-evidenza-4{
	font-size:2.1em;
	font-weight:800;
}  

/* END ADD CSS */

 
.section-breadcrumb { 
	margin-top:20px;
	margin-bottom:0;
} 
 
.section-breadcrumb ol li.breadcrumb-item a{
    color: inherit;
}
 
.section-page{
	padding: 0 0 66px 0 !important;
}

.page-content h1{
    font-size: 40px;
    font-weight: 700;
    /*letter-spacing: -0.02em;*/
    margin-bottom: 30px;
}
.page-content h2{
    font-size: 32px;
    font-weight: 700;
    /*letter-spacing: -0.02em;*/
	margin-top: 21px;
    margin-bottom: 26px;
}
.page-content h3{
	font-size: 24px;
	margin-top: 26px;	
	margin-bottom: 15px;	
	font-weight: 500;
 
}
 

/*
.page-content p{
	margin-bottom: 20px;
}

.page-content p:last-child{
	margin-bottom: 0;
}

.page-content ul{
    list-style: none;
    margin-bottom: 20px;
    padding: 0;
}

.page-content ul li{
	position: relative;
    font-weight: 500;
    color: var(--text-color);
    padding-left: 30px;
    margin-bottom: 15px;
}

.page-content ul li:last-child{
	margin-bottom: 0;
}

.page-content ul li::before{
    content: '\f058';
    position: absolute;
    font-family: 'FontAwesome';
    font-size: 20px;
    font-weight: 900;
    line-height: normal;
    color: var(--accent-color);
    display: inline-block;
    top: 2px;
    left: 0;
} 
*/
.page-content ul{
    margin-bottom: 33px;
}

.page-content ul li{ 
    color: var(--text-color); 
    margin-bottom: 15px;
}
  
 
ul.content-list {
	padding: 0;
	margin: 0 0 40px 0 ;
	list-style: none; 
}

ul.content-list  li{
	position: relative;
	font-weight: 500;
	color: var(--primary-color);
	padding-left: 30px;
	margin-bottom: 15px;
}

ul.content-list li:last-child{
	margin-bottom: 0;
}

ul.content-list  li::before{
	content: '\f058';
    position: absolute;
    font-family: 'FontAwesome';
    font-size: 20px;
    font-weight: 900;
    line-height: normal;
    color: var(--accent-color);
    display: inline-block;
    top: 2px;
    left: 0;
}

ul.content-list.content-list-neg  li::before{
	content: '\f056'; 
	color: var(--error-color);
}

 
ul.content-list-flex {
	padding: 0;
	margin: 0 0 40px 0 ;
	list-style: none;  
	display:flex;
}

ul.content-list-flex  li{
	position: relative;
	font-weight: 500;
	color: var(--primary-color);
	padding-left: 30px;
	margin-bottom: 15px;
	margin-left: 15px;
}
ul.content-list-flex  li:first-child{
	margin-left: 0;
}
ul.content-list-flex li:last-child{
	margin-bottom: 0;
}

ul.content-list-flex li::before{
	content: '\f058';
    position: absolute;
    font-family: 'FontAwesome';
    font-size: 20px;
    font-weight: 900;
    line-height: normal;
    color: var(--accent-color);
    display: inline-block;
    top: 2px;
    left: 0;
}
 
 
h3.X123{
	margin-top:50px
	
}
li.X123{
	margin-top:50px
	
}
 
.vstyle-m1-content-xxxx{ 
	border-right: 1px solid var(--divider-color); 
	height: 100%;
}

.banner{margin-top:60px; margin-bottom:60px}

/* swiper */
    .swiper-all {
      width: 100%;
      height: 100%;
    }

    .swiper-slide{
      text-align: center;
      font-size: 18px; 
      display: flex;
      justify-content: center;
      align-items: center;
    }

    .swiper-slide img{
      display: block;
      width: auto;
      height: auto;
      object-fit: cover;
    } 

/************************************/
/***  .box1-sidebar ***/
/************************************/
 
.box1-sidebar{
	position: sticky;
	top: 30px;
	margin-right: 30px;
}

.box1-sidebar-list{
	border: 1px solid var(--divider-color);
	padding: 30px;
	margin-bottom: 60px;
}

.box1-sidebar-list ul{
	list-style: none;
	margin: 0;
	padding: 0;
}
 
.box1-sidebar-list ul li{
    margin-bottom: 20px;
    transition: all 0.3s ease-in-out;
}

.box1-sidebar-list ul li:last-child{
	margin-bottom: 0;
}

.box1-sidebar-list ul li a{
	position: relative;
    display: block;
    font-weight: 500; 
    color: var(--text-color-light);
    padding-right: 25px;
    /*transition: all 0.3s ease-in-out;*/
}

.box1-sidebar-list ul li:hover a{
	color: var(--accent-color);
}

.box1-sidebar-list ul li a::before{
	content: '';
    position: absolute;
    top: 50%;
    right: 0;
    width: 18px;
    height: 18px;
	filter: brightness(0) saturate(100%) invert(80%) sepia(1%) saturate(3447%) hue-rotate(26deg) brightness(77%) contrast(76%);
    transform: translateY(-50%) rotate(-45deg); 
    background-image: url(../svgs/solid/arrow-right.svg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
   /* transition: all 0.3s ease-in-out;*/
}
 
.box1-sidebar-image figure{
	display: block;
}

.box1-sidebar-image img{
	width: 100%;
	aspect-ratio: 1 / 0.57;
	object-fit: cover;
}

.box1-sidebar-Body{
	border: 1px solid var(--divider-color);
	padding: 30px;
}

.box1-sidebar-content{
	margin-bottom: 25px;
}

.box1-sidebar-content h3{
	font-size: 20px; 
	margin-bottom: 10px;
}

.box1-sidebar-content p{
	font-weight: 500;
	margin-bottom: 0;
}

.box1-sidebar-contact-item{
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}

.box1-sidebar-contact-item:last-child{
	margin-bottom: 0;
}

.box1-sidebar-contact-item .icon-box{
	position: relative;
	height: 58px;
	width: 58px;
	background-color: var(--divider-color);
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-right: 20px;
	transition: all 0.4s ease-in-out;
}

.box1-sidebar-contact-item:hover{
	background-color: transparent;
}

.box1-sidebar-contact-item .icon-box::before{
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: var(--primary-color);
    border-radius: 50%;
    height: 100%;
    width: 100%;
    transform: scale(0);
    transition: all 0.3s ease-in-out;
}

.box1-sidebar-contact-item:hover .icon-box::before{
    transform: scale(1);
}

.box1-sidebar-contact-item .icon-box img{
	position: relative;
	max-width: 24px;
	transition: all 0.3s ease-in-out;
	z-index: 1;
}

.box1-sidebar-contact-item:hover .icon-box img{
	filter: brightness(0) invert(1);
} 



/************************************/
/***  box1-2images 				  ***/
/************************************/ 

.box1-2images {
	position: relative;  
	padding-right: 100px;
	padding-bottom: 180px;
	margin-right: 30px;
}

.box1-2images figure{
	display: block;
}

.box1-2images img{
	width: 100%;
	object-fit: cover;
	aspect-ratio: 1 / 0.76;
}

.box1-2images .box1-2images-2
{
	position: absolute;
	width: 100%;
	max-width: 385px;
	bottom: 0;
	right: 0;
}
 

/************************************/
/***     box1-4images  ***/
/************************************/
.box1-4images {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin-left: 30px;
}

.box1-4images-box-1,
.box1-4images-box-2{
	display: flex;
	gap: 20px;
	width: 100%; 
} 
.box1-4images figure {
	display: block; 
}  
.box1-4images-img-1 {
	width: calc(57% - 10px); 
} 
.box1-4images-img-1 figure img{
	width: 100%;
	aspect-ratio: 1 / 0.756;
	object-fit: cover; 
} 
.box1-4images-img-2 {
	width: calc(43% - 10px); 
} 
.box1-4images-img-2 figure img{
	width: 100%;
	aspect-ratio: 1 / 1.01;
	object-fit: cover; 
}

.box1-4images-img-3 {
	width: calc(67% - 10px); 
}

.box1-4images-img-3 figure img{
	width: 100%;
	aspect-ratio: 1 / 0.746;
	object-fit: cover;
}

.box1-4images-img-4 {
	width: calc(33% - 10px); 
}

.box1-4images-img-4 figure img{
	width: 100%;
	aspect-ratio: 1 / 1.55;
	object-fit: cover;
}
 
 
 /************************************/
/***     06. vstyle-m3 ***/
/************************************/

 
.vstyle-m3 h3 {font-size:20px; margin-bottom:10px}
  
/************************************/
/**** 	   03. Header css		 ****/
/************************************/

header.main-header{
	position: relative;
	z-index: 100;
	background:  var(--header-bg-color); 
	opacity: 1; 
	
 
}

header.main-header .header-sticky{
	position: relative;
	top: 0;
	z-index: 100;
}
header.main-header .header-sticky.header-bordered-old {
	border-bottom: 33px solid var(--accent-color); /*var(--accent-color); #f2f1ee;*/
}
 
header.main-header .header-sticky.hide{
	transform: translateY(-100%);
	transition: transform 0.3s ease-in-out;
	border-radius: 0;
}

header.main-header .header-sticky.active{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	border-radius: 0;
    transform: translateY(0);
	/*background: #356285; 
	border:10px solid #000;*/
	/* border-bottom: 1px solid var(--header-divider-color);*/
}

.navbar{
	padding: 25px 0;
	align-items: center;
	/* border-bottom: 1px solid var(--header-divider-color);*/
}

header.main-header .header-sticky.active .navbar{
	border-bottom: none;
}

.navbar-brand{
	padding: 0;
	margin: 0;
}

.main-menu .nav-menu-wrapper{
	flex: 1;
	text-align: center;
	margin-left: 40px;
}

.main-menu .nav-menu-wrapper > ul{
	align-items: center;
	display: inline-flex; 
}

.main-menu ul li{
	margin: 0 6px;
	position: relative;
}

.main-menu ul li a{
	font-family: var(--accent-font);
	font-size: 18px;
	font-weight: 400;
	padding: 15px 14px !important;
	color: var(--main-menulnk-color); 
	transition: all 0.3s ease-in-out;
}

.main-menu ul li.submenu > a:after{
	content: '\f107';
	font-family: 'FontAwesome';
	font-weight: 900;
	font-size: 14px;
	margin-left: 8px;
}

.main-menu ul li a:hover,
.main-menu ul li a:focus{
	color: var(--main-menulnk-color);
}
.navbar-nav .nav-link.active,
.main-menu ul li a.active{ 
	color: var(--main-menulnk-color);  
    
}

.main-menu ul ul{
	visibility: hidden;
	opacity: 0;
	transform: scaleY(0.8);
	transform-origin: top;
	padding: 0;
	margin: 0;
	list-style: none;
	width: 230px;
	border-radius: 20px;
	position: absolute;
	left: 0;
	top: 100%;
	background-color: #3a617f ;/*bck menu var(--accent-color) */
	transition: all 0.3s ease-in-out;
	text-align: left;
}

.main-menu ul li.submenu:first-child ul{
    width: 230px;
}

.main-menu ul ul ul{
	left: 100%;
	top: 0;
	text-align: left;
}
.main-menu ul li:hover > ul{
	visibility: visible;
	opacity: 1;
	transform: scaleY(1);
    padding: 5px 0;
}

.main-menu ul li.submenu ul li.submenu > a:after{
    content: '\f105';
    float: right;
}

.main-menu ul ul li{
	margin: 0;
	padding: 0;
}

.main-menu ul ul li a{
	color: var(--white-color);
	padding: 6px 20px !important;
	transition: all 0.3s ease-in-out;
}

.main-menu ul li:hover > ul{
	visibility: visible;
	opacity: 1;
	transform: scaleY(1);
    padding: 5px 0;
}

.main-menu ul ul li a:hover,
.main-menu ul ul li a:focus{
	color: #ccc;
	background-color: transparent;
	padding: 6px 20px 6px 23px !important;
}

.responsive-menu,
.navbar-toggle{
	display: none;
}

.responsive-menu{
	top: 0;
	position: relative;
}

.slicknav_btn{
	background: var(--accent-color);
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	margin: 0;
	border-radius: 0;
}

.slicknav_icon .slicknav_icon-bar{
	display: block;
	width: 100%;
	height: 3px;
	width: 22px;
	background-color: var(--white-color);
	border-radius: 6px;
	margin: 4px auto !important;
	transition: all 0.1s ease-in-out;
}

.slicknav_icon .slicknav_icon-bar:first-child{
	margin-top: 0 !important;
}

.slicknav_icon .slicknav_icon-bar:last-child{
	margin-bottom: 0 !important;
}

.navbar-toggle a.slicknav_btn.slicknav_open .slicknav_icon span.slicknav_icon-bar:nth-child(1){
    transform: rotate(-45deg) translate(-5px, 5px);
}

.navbar-toggle a.slicknav_btn.slicknav_open .slicknav_icon span.slicknav_icon-bar:nth-child(2){
    opacity: 0;
}

.navbar-toggle a.slicknav_btn.slicknav_open .slicknav_icon span.slicknav_icon-bar:nth-child(3){
    transform: rotate(45deg) translate(-5px, -5px);
}

.slicknav_menu{
	position: absolute;
    width: 100%;
	padding: 0;
	background: var(--accent-color);
}

.slicknav_menu ul{
	margin: 5px 0;
}

.slicknav_menu ul ul{
	margin: 0;
}

.slicknav_nav .slicknav_row,
.slicknav_nav li a{
	position: relative;
	font-family: var(--accent-font);
	font-size: 20px;	
	padding: 10px 20px;
	color: var(--white-color);
	line-height: normal;
	margin: 0;
	border-radius: 0 !important;
	transition: all 0.3s ease-in-out;
}

.slicknav_nav a:hover,
.slicknav_nav a:focus,
.slicknav_nav .slicknav_row:hover{
	background-color: transparent;
	color: var(--primary-color);
}

.slicknav_menu ul ul li a{
    padding: 10px 20px 10px 30px;
}

.slicknav_arrow{
	font-size: 0 !important;
}

.slicknav_arrow:after{
	content: '\f107';
	font-family: 'FontAwesome';
	font-weight: 900;
	font-size: 12px;
	margin-left: 8px;
	color: var(--white-color);
	position: absolute;
	right: 15px;
    top: 15px;
	transition: all 0.3s ease-out;
}

.slicknav_open > a .slicknav_arrow:after{
    transform: rotate(-180deg);
	color: var(--primary-color);
}

/************************************/
/***        04. Hero css	      ***/
/************************************/

.hero{
	position: relative; 
	padding-top: 26vh !important; 
	min-height: 100vh;
	margin-top: -138px; /* -118px */
}
.hero.sfondo{ 
	background: linear-gradient(rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.35)),url('../img/bp/sfondo-1-2000.webp')  !important;  
	background-repeat: no-repeat  !important;
	background-position: center center  !important;
	background-size: cover  !important; 
}
.hero::before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	/*background: linear-gradient(180deg, rgba(25, 35, 36, 0) 0%, rgba(25, 35, 36, 0.4) 80.94%);*/
	height: 100%;
	width: 100%;
	z-index: 1;
}

.hero .hero-content  h1, .hero .hero-content .asH1 {color:#333;font-size:65px; font-weight:800 !important; letter-spacing: 0em !important;line-height: 1.25em;}
.hero .hero-content p.asH1{font-size:40px;} 
 
.hero.hero-video .hero-bg-video{         

	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
}

.hero.hero-video .hero-bg-video video{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero.hero-slider-layout{
	background: none;
	padding: 0;
}

.hero.hero-slider-layout .hero-slide{
	position: relative;
    padding: 280px 0 250px;
	min-height: 100vh;
}

.hero.hero-slider-layout .hero-slide::before{
	content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(180deg, rgba(25, 35, 36, 0) 0%, rgba(25, 35, 36, 0.4) 80.94%);
    width: 100%;
    height: 100%;
    z-index: 1;
}

.hero.hero-slider-layout .hero-slide .hero-slider-image{
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
}

.hero.hero-slider-layout .hero-slide .hero-slider-image img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero.hero-slider-layout .hero-pagination{
	position: absolute;
    bottom: 50px;
	text-align: left;
	padding-left: calc(((100vw - 1300px) / 2));
	z-index: 2;
}

.hero.hero-slider-layout .hero-pagination .swiper-pagination-bullet{
    width: 12px;
    height: 12px;
    background: var(--white-color);
    opacity: 1;
    transition: all 0.3s ease-in-out;
    margin: 0 5px;
}

.hero.hero-slider-layout .hero-pagination .swiper-pagination-bullet-active{
    background-color: var(--accent-color);
}

.hero-content{
	position: relative;
	z-index: 2;
}

 
.hero-content   p{
	font-size: 22px;
	color: #000;
	width: 95%;
	/*max-width: 650px;*/
}
 
.hero-content .btn-default.btn-highlighted{
	margin-left: 30px;
}


 
/************************************/
/***      	14. Footer css 		  ***/
/************************************/

.main-footer{
    margin-top:50px;
	padding: 30px 0 0;
	background: var(--footer-bg-color);
}

.main-footer .footer-header{
	border-bottom: 1px solid var(--footer-divider-color);
	margin-bottom: 40px;
	padding-bottom: 40px;
}

.footer-social-links{
	display: flex;
	align-items: center;
	/*justify-content: end;*/
	gap: 30px;
}

.footer-social-link-title h3{
	font-size: 20px; 
	color: var(--footer-text-color);
}

.footer-social-links ul{
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-social-links ul li{
	display: inline-flex;
	margin-right: 10px;
}

.footer-social-links ul li:last-child{
	margin-right: 0;
}

  
a.social-links{ 
    display: flex !important;
    justify-content: center;
    align-items: center;
    background: var(--footer-text-color);
    border-radius: 50%;
    height: 36px;
    width: 36px;
    transition: all 0.3s ease-in-out;
}

a.social-links i{
	font-size: 18px;
	color: var(--white-color);
	transition: all 0.3s ease-in-out;
}

a.social-links:hover{
	background: var(--white-color);
}

a.social-links:hover i{
	color: var(--footer-text-color);
}

.footer-links h3{
	font-size: 20px; 
	color: var(--footer-text-color);
	margin-bottom: 20px;
}

.footer-links ul{
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-links ul li{
	color: var(--footer-text-color); 
	transition: all 0.3s ease-in-out;
	margin-bottom: 10px;
}

.footer-links ul li:last-child{
	margin-bottom: 0;
}

.footer-links ul li:hover{
	color: var(--footer-text-color); 
}

.footer-links ul li a{
	display: block;
	color: inherit;
}

.footer-contact-item{
	display: flex;
	align-items: center;
	margin-bottom: 15px;
}

.footer-contact-item:last-child{
	margin-bottom: 0;
}

.footer-contact-item .icon-box{
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--footer-divider-color);
	border-radius: 50%;
	width: 40px;
	height: 40px;
	margin-right: 10px;
	transition: all 0.3s ease-in-out;
}

.footer-contact-item:hover .icon-box{
	border-color: var(--footer-text-color);
}

.footer-contact-item .icon-box i{
	font-size: 16px;
	color: var(--footer-text-color);
}

.footer-contact-content{
	width: calc(100% - 50px);
}

.footer-contact-content p{
	color: var(--footer-text-color);
	margin: 0;
}

.footer-newsletter-form p{
	color: var(--footer-text-color);
	margin-bottom: 30px;
}

.footer-newsletter-form .form-group{
	display: flex;
	background: var(--footer-text-color);
	overflow: hidden;
}

.footer-newsletter-form .form-group .form-control{
	width: 85%;
	border: none;
	border-radius: 0;
	color: var(--footer-text-color);
	background: transparent;
	padding: 13px 10px;
	box-shadow: none;
}

.footer-newsletter-form .form-group .form-control::placeholder{
	color: var(--footer-text-color);
}

.footer-newsletter-form button{
	background-color: transparent;
	width: 15%;
	border: none;
	padding: 0;
}

.footer-newsletter-form button i{
	color: var(--accent-color);
	font-size: 16px;
	transition: all 0.3s ease-in-out;
}

.footer-newsletter-form button:hover i{
	color: var(--primary-color);
}

.footer-copyright{
	border-top: 1px solid var(--footer-divider-color);
	text-align: center;
	margin-top: 33px;
	padding: 20px 0;
}

.footer-copyright-text p{
	color: var(--footer-text-color); 
	margin: 0;
}

 
/************************************/ 
/*** team ***/
/******** */
.our-team{
	padding: 100px 0 70px;
}

.team-member-item{
	height: calc(100% - 30px);
	margin-bottom: 30px;
}

.team-image{
	position: relative;
	margin-bottom: 20px;
    overflow: hidden;
}

.team-image a{
	display: block;
	cursor: none;
}

.team-image figure{
	display: block;
}

.team-image figure img{
	width: 100%;
	max-width:265px;
    aspect-ratio: 1 / 1.11;
    object-fit: cover;
	transition: all 0.4s ease-in-out;
}

/************************************/
/***     16. FAQ 	  ***/
/************************************/
.our-faqs{
	padding: 100px 0;
}

.our-faqs-content{
	margin-right: 70px;
}

.faq-accordion .accordion-item{
    border-bottom: 1px solid var(--divider-color);
    margin-bottom: 30px;
    padding-bottom: 15px;
}

.faq-accordion .accordion-item:last-child{
    margin-bottom: 0;
	padding-bottom: 0;
    border-bottom: none;
}

.faq-accordion .accordion-header .accordion-button{
    font-size: 20px;
    font-weight: 500;
    line-height: 1.2em;
    color: var(--htitle-color);
	align-items: start;
    padding-right: 35px;
    transition: all 0.3s ease-in-out;
}

.faq-accordion .accordion-header .accordion-button span{
	margin-right: 7px;
}

.faq-accordion .accordion-button:not(.collapsed){
    padding-bottom: 15px;
}

.faq-accordion .accordion-item .accordion-button::after, 
.faq-accordion .accordion-item .accordion-button.collapsed::after{
	content: '\2b';
	font-family: 'Font Awesome 6 Free';
	position: absolute;
	font-size: 18px;
	font-weight: 900;
	color: var(--primary-color);
	text-align: right;
    top: 0;
    right: 0;
	transition: all 0.3s ease-in-out;
}

.faq-accordion .accordion-button:not(.collapsed)::after{
    content: '\f068';
}

.faq-accordion .accordion-body{
	padding-right: 35px;
}

.faq-accordion .accordion-body p{
	margin: 0;
}
 
 
/************************************/
/***     18. Blog Archive css 	  ***/
/************************************/

.page-blog{
	padding: 100px 0;
}

.page-pagination{
    margin-top: 20px;
    text-align: center;
}

.page-pagination ul{
    justify-content: center;
    padding: 0;
    margin: 0;
}

.page-pagination ul li a,
.page-pagination ul li span{
    display: flex;
    text-decoration: none;
    justify-content: center;
    align-items: center;
    background: var(--accent-color);
    color: var(--white-color);
    width: 40px;
    height: 40px;
    margin: 0 5px;
    font-weight: 700;
	line-height: 1em;
    transition: all 0.3s ease-in-out;
}

.page-pagination ul li.active a, 
.page-pagination ul li a:hover{
    background: var(--primary-color);
    color: var(--white-color);
}
    .post-item{
        height: calc(100% - 30px);
        margin-bottom: 30px;
    }

    .post-featured-image{
        margin-bottom: 20px;
    }
 

    .post-featured-image figure,
    .post-featured-image a{
        display: block;
    }

    .post-featured-image img{
        width: 100%;
        aspect-ratio: 1 / 0.85;
        object-fit: cover;
        transition: all 0.4s ease-in-out;
    }

    .post-item:hover .post-featured-image img{
        transform: scale(1.1);
    }

    .post-item-content{
        margin-bottom: 15px;
        padding-top: 5px;
    }

    .post-item-content h2{
        color: var(--primary-color);
        font-size: 22px;
        line-height: 1.4em;
        font-weight: 800;
    }

 
 
/************************************/
/***   24. Contact Us Page css 	  ***/
/************************************/

.page-contact-us{
	padding: 100px 0 50px;
}

.contact-us-image{
	height: 100%;
}

.contact-us-image figure{
	height: 100%;
	display: block;
}

.contact-us-image img{
	height: 100%;
	width: 100%;
    object-fit: cover;
    aspect-ratio: 1 / 0.962;
}

.contact-us-form{
	margin-left: 30px;
}

.contact-form .form-control{
    font-size: 16px;
    font-weight: 500;
	line-height: 1.2em;
    background-color: var(--white-color);
    color: var(--text-color);
    border: 1px solid var(--divider-color);
	border-radius: 0;
    outline: none;
    box-shadow: none;
    padding: 14px 15px;
}

.contact-form .form-control::placeholder{
	font-weight: 400;
}

.google-map{
	padding: 50px 0 100px;
}

.google-map .section-title{
	width: 100%;
	max-width: 560px;
	margin: 0 auto 30px;
	text-align: center;
}

.google-map-iframe,
.google-map-iframe iframe{
	width: 100%;
	height: 500px;
}

.contact-info-box{
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	margin-top: 60px;
}

.contact-info-item{
	width: calc(33.33% - 20px);
	display: flex;
}

.contact-info-item .icon-box{
	position: relative;
	height: 60px;
	width: 60px;
	background-color: var(--divider-color);
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-right: 20px;
}

.contact-info-item .icon-box:before{
	content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background: var(--primary-color);
    border-radius: 50%;
    width: 100%;
    height: 100%;
    transform: scale(0);
    transition: all 0.4s ease-in-out;
    z-index: 0;
}

.contact-info-item:hover .icon-box:before{
	transform: scale(1);
}

.contact-info-item .icon-box i{
	position: relative;
	font-size: 20px;
	color: var(--accent-color);
	transition: all 0.3s ease-in-out;
	z-index: 1;
}

.contact-info-item:hover .icon-box i{
	color: var(--white-color);
}

.contact-info-content{
	width: calc(100% - 80px);
}

.contact-info-content h3{
	font-size: 20px; 
	margin-bottom: 10px;
}

.contact-info-content p{
	margin-bottom: 0;
}

/************************************/
/***    25. 404 Error Page css 	  ***/
/************************************/

.error-page{
	background-image: url(../images/error-page-bg.svg);
	background-repeat: no-repeat;
	background-position: top -100px center;
	background-size: auto;
	padding: 100px 0;
}

.error-page-image{
	text-align: center;
	margin-bottom: 30px;
}

.error-page-image img{
	width: 100%;
	max-width: 50%;
}

 .error-page-content{
	width: 100%;
	max-width: 500px;
	margin: 0 auto;
	text-align: center;
}

.error-page-content .section-title{
	margin-bottom: 20px;
}

.error-page-content-body p{
	font-weight: 500;
	margin-bottom: 20px;
}

/************************************/
/***      26. Responsive css      ***/
/************************************/

@media only screen and (max-width: 1366px){
	
	.our-testimonial-content{
		padding: 100px 50px;
	}
}

@media only screen and (max-width: 1024px){
	
	.main-menu ul li{
		margin: 0;
	}

	.our-testimonial-content{
		padding: 50px 20px;
	}
}

@media only screen and (max-width: 991px){

	.navbar{
		padding: 20px 0;
	}
	
	.slicknav_nav li,
	.slicknav_nav ul{
        display: block;
    }

	.responsive-menu,
    .navbar-toggle{
        display: block;
    }

	.header-btn{
		display: none;
	}

	.btn-default{
		padding: 14px 42px 14px 16px;
	}

	.section-row{
		margin-bottom: 40px;
	}

	.section-row .section-title{
		margin-bottom: 0;
		margin-right: 0px;
	}

	.section-title-content{
		margin-left: 0;
		margin-top: 15px;
	}

	.section-btn{
		text-align: left;
		margin-top: 15px;
	}

	.section-title{
		margin-bottom: 30px;
	}

	.section-title h3{
		margin-bottom: 10px;
	}

	.section-title h1{
		font-size: 50px;
	}

	.section-title h2{
		font-size: 36px;
	}

	.section-title p{
		margin-top: 15px;
	}

	.hero{
		min-height: auto;
		padding: 180px 0 140px;
		margin-top: -125px;/* 92*/
	} 	
	.hero.sfondo{ 
		background: linear-gradient(rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.35)),url('../img/bp/sfondo-1-1000.webp')  !important; 
	}	
	.hero.hero-slider-layout .hero-slide{
		padding: 180px 0 140px;
		min-height: auto;
	}

	.hero.hero-slider-layout .hero-pagination{
		padding-left: 15px;
		bottom: 30px;
	}

	.hero-content .section-title p{
		font-size: 20px;
	}


	.hero .hero-content  h1, .hero .hero-content .asH1 {color:#333;font-size:45px; font-weight:800 !important; letter-spacing: 0em !important;line-height: 1.25em;}
	.hero .hero-content p.asH1{font-size:30px;} 
 
 
	 h1.title-style{
		font-size: 35px;
		font-weight: 700;
		letter-spacing: -0.02em;
		margin-bottom: 18px; 
	}

	 h2.title-style{
		font-size: 26px;
		font-weight: 700;
		/*letter-spacing: -0.02em;*/
		margin-bottom: 18px; 
	}
	 h3.title-style{
		display: inline-block;
		position: relative;
		font-size: 19px;
		font-weight: bold;
		line-height: 1.6em; 
		color: var(--accent-color); 
		margin-bottom: 18px; 
	}

	 
	 h1.title-style span,
	 h2.title-style span{
		color: var(--accent-color);
	} 
 
 	.box1-2images{
		margin: 0 0 30px 0;
	}
 	.box1-4images{ 
		margin-left: 0;
	} 
	 .box1-4images-img-2 figure img{
		aspect-ratio: 1 / 1.02;
	}

	.box1-4images-img-4 figure img{
		aspect-ratio: 1 / 1.588;
	} 
	.main-footer{
		padding: 20px 0 0;
	}
 
    
    
	.main-footer .footer-header{
		margin-bottom: 30px;
		padding-bottom: 30px;
	}

	.footer-links{
		padding-right: 0;
		margin-bottom: 30px;
	}

	.footer-newsletter-form p{
		margin-bottom: 20px;
	}

	.footer-copyright{
		margin-top: 0px;
		padding: 20px 0;
	}

	.page-header{
        padding: 180px 0 100px;
        margin-top: -92px;
    }

    .page-header-box h1{
        font-size: 50px;
    }

	.page-header-box ol li.breadcrumb-item{
		font-size: 18px;
	}

	.page-header-box ol .breadcrumb-item+.breadcrumb-item::before{
		font-size: 16px;
	}
 
	.our-faqs{
		padding: 50px 0;
	}

	.our-faqs-content{
		margin-right: 0;
		margin-bottom: 30px;
	}

	.faq-accordion .accordion-item{
		margin-bottom: 20px;
	}

	.our-faqs-image{
		text-align: center;
		margin-left: 0px;
	}

	.our-faqs-image img{
		aspect-ratio: 1 / 0.8;
	}

	.our-clients{
		padding: 50px 0;
	}

	.our-clients .our-clients-box{
		max-width: 100%;
	}

	.page-services{
		padding: 50px 0 20px;
	}

	.page-service-single{
		padding: 50px 0;
	}
 
	.page-faqs{
		padding: 50px 0;
	}

	.faq-sidebar{
		position: initial;
		margin-right: 0;
		margin-bottom: 30px;
	}

	.faq-catagery-list{
		padding: 20px;
		margin-bottom: 30px;
	}

	.faq-catagery-list ul li{
        margin-bottom: 15px;
    }

	.faq-catagery-list ul li a::before{
        width: 16px;
        height: 16px;
    }

	.our-faq-section.page-faq-accordion{
		margin-bottom: 40px;
	}

	.page-contact-us{
		padding: 50px 0 25px;
	}
 
	.contact-us-image{
		height: auto;
		margin-bottom: 30px;
	}

	.contact-us-image img{
		aspect-ratio: 1 / 0.6;
	}

	.contact-us-form{
		margin-left: 0;
	}

	.contact-form .form-control{
		padding: 12px 15px;
	}

	.google-map{
		padding: 25px 0 50px;
	}

	.google-map-iframe,
	.google-map-iframe iframe{
		height: 400px;
	}

	.contact-info-box{
		gap: 20px;
		margin-top: 40px;
	}

	.contact-info-item{
		width: calc(33.33% - 13.33px);
	}

	.contact-info-item .icon-box{
		height: 50px;
		width: 50px;
		margin-right: 10px;
	}

	.contact-info-item .icon-box i{
		font-size: 16px;
	}

	.contact-info-content{
		width: calc(100% - 60px);
	}

	.contact-info-content h3{
		font-size: 18px;
	}

	.error-page{
		padding: 50px 0;
	}

	.error-page-image img{
		max-width: 80%;
	}
}

@media only screen and (max-width: 767px){

	.section-row{
		margin-bottom: 30px;
	}

	.section-title{
		margin-bottom: 30px;
	}

	.section-title h1{
		font-size: 28px;
	}

	.section-title h2{
		font-size: 26px;
	}

	.hero-content .section-title p{
		font-size: 18px;
	}

	.hero-content .btn-default{
		margin-right: 40px;
		margin-bottom: 10px;
	}

	.hero-content .btn-default.btn-highlighted{
		margin: 0;
	}
	
	.hero .hero-content  h1, .hero .hero-content .asH1 {color:#333;font-size:40px; font-weight:800 !important; letter-spacing: 0em !important;line-height: 1.25em;}
	.hero .hero-content p.asH1{font-size:26px;} 	
	
	 h1.title-style{
		font-size: 35px;
		font-weight: 700;
		letter-spacing: -0.02em;
		margin-bottom: 18px; 
	}

	 h2.title-style{
		font-size: 26px;
		font-weight: 700;
		/*letter-spacing: -0.02em;*/
		margin-bottom: 18px; 
	}
	 h3.title-style{
		display: inline-block;
		position: relative;
		font-size: 19px;
		font-weight: bold;
		line-height: 1.6em; 
		color: var(--accent-color); 
		margin-bottom: 18px; 
	}
	 
	 h1.title-style span,
	 h2.title-style span{
		color: var(--accent-color);
	} 
	
 	.box1-2images{
		background-position: left 10px bottom 10px;
		background-size: 20% auto;
		padding: 10px 45px 100px 0;
	}

	.box1-2images .box1-2images-2{
		max-width: 240px;
	}
 
    
	.footer-logo{
		margin-bottom: 20px;
	}

	.footer-social-links{
		justify-content: start;
		gap: 20px;
        margin-bottom:30px;
	}

	.footer-social-link-title h3{
		font-size: 18px;
	}

	.footer-links h3{
		margin-bottom: 15px;
	}

	.footer-links ul li{
		margin-bottom: 5px;
	}
	
	.footer-copyright{
		padding: 15px 0;
	}

	.page-header-box h1{
		font-size: 28px;
		margin-bottom: 5px;
	}

	.page-header-box ol li.breadcrumb-item{
        font-size: 16px;
    }

	.page-header-box ol .breadcrumb-item+.breadcrumb-item::before{
		font-size: 14px;
	}
 
	.faq-accordion .accordion-header .accordion-button{
		font-size: 18px;
		padding-right: 30px;
	}

	.faq-accordion .accordion-item .accordion-button::after, 
	.faq-accordion .accordion-item .accordion-button.collapsed::after{
		top: 2px;
	}

	.faq-accordion .accordion-body{
		padding-right: 0;
	}

	.our-faqs-image img{
		aspect-ratio: 1 / 1.26;
	}
 
	.contact-us-image img{
        aspect-ratio: 1 / 0.75;
    }

	.google-map-iframe,
	.google-map-iframe iframe{
        height: 350px;
    }

	.contact-info-item{
		width: 100%;
	}

	.error-page-image img{
        max-width: 100%;
    }
}
 