/*
Theme Name: Hello Elementor Child
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: Elementor Team
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Description: Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.4.4.1760349580
Updated: 2025-10-13 09:59:40

*/

	   :root{
	  --shift: 25px;
	  --dur-move: .45s;
	  --dur-fade: .25s;
	  --ease: cubic-bezier(.2,.7,.2,1);
	}
	
	
	ul {
		 padding-inline-start: 20px;
	}


	/* Seleziona il pulsante */
	.elementor-button:hover .elementor-button-icon {
	  transform: translateX(6px);
	  transition: transform 0.2s ease;
	}

	/* Applica la transizione anche nello stato normale */
	.elementor-button .elementor-button-icon {
	  transition: transform 0.2s ease;
	}
	
	.container-breadcrumb, body.single-post .container-breadcrumb {
    display: none !important;
	}
	
	body.single-dumper  .container-breadcrumb,  body.single-mini-dumper .container-breadcrumb,  body.single-skid-loader  .container-breadcrumb,  body.single-gamma-elettrica  .container-breadcrumb ,  body.single-macchine-speciali  .container-breadcrumb{
    display: flex !important;;
	}

	.card-hero {
		background-position: center center !important;
		background-repeat: no-repeat !important;
		background-size: cover !important;
		aspect-ratio: 5 / 7;
	}
	@media (min-width: 1024px) {
	  .card-hero {
		aspect-ratio: 5 / 4;
	  }
	}
	.card-hero h4 {
	  font-weight: 700!important;
	}
	.uppercase {
	  text-transform: uppercase;
	}


	.card-category {
	  aspect-ratio: 5 / 7;
	}
	
	.card-category.prodotti {
		aspect-ratio: 7 / 5;
	}
	
	@media (max-width: 1200px) {
	  .card-category.prodotti  {
		aspect-ratio: 5 / 7;
	  }
	}



   .card-hero{
    position: relative;
    overflow: hidden;
    cursor: pointer;
  }
    .card-hero .video {
    position: absolute;
	display: flex;
    justify-content: center;
	align-items: center;   
    inset: 0;
    width: 100% !important;
    height: 100%;
    object-fit: cover;
    border-radius: 10px !important;
    transition: opacity 0.6s ease !important;
   /* transition: width .6s  cubic-bezier(0, 0, .2, 1);*/
   
  }
 

 
  .card-hero .video {
    opacity: 0;
  }
 
 .grid-hero-products .card-hero:hover .video {
    opacity: 1;
  }
  

  
   .card-hero .elementor-video {
      height: 100%;
	  object-fit: cover;
	 border-radius: 10px !important;
  }

   .card-hero .video .elementor-wrapper
  {
      height: 100% !important;
  }
  
  
 /* EFFETTO CARD PULSANTE CHE APPARE */

@media (min-width: 1025px) {

.card-category, .card-prodotti {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end; /* Porta tutto in basso */
  align-items: flex-start;
  padding: 20px;
  height: 100%;
}

	
	
	

.card-category .elementor-heading-title,
.card-category .elementor-widget-button .elementor-button,
.card-prodotti .elementor-heading-title,
.card-prodotti .elementor-widget-button .elementor-button
{
  transform: translate3d(0, var(--shift), 0);
  transition:
    transform var(--dur-move) var(--ease),
    opacity   var(--dur-fade) ease-in-out;
  will-change: transform, opacity;
}

.card-category .elementor-heading-title,
.card-prodotti .elementor-heading-title{
  opacity: 1;
  z-index: 2;
}

.card-category .elementor-widget-button .elementor-button,
.card-prodotti .elementor-widget-button .elementor-button{
  opacity: 0;
  pointer-events: none;
}

.card-category:hover .elementor-heading-title,
.card-category:focus-within .elementor-heading-title,
.card-category:hover .elementor-widget-button .elementor-button,
.card-category:focus-within .elementor-widget-button .elementor-button,
.card-prodotti:hover .elementor-heading-title,
.card-prodotti:focus-within .elementor-heading-title,
.card-prodotti:hover .elementor-widget-button .elementor-button,
.card-prodotti:focus-within .elementor-widget-button .elementor-button
{
  transform: translate3d(0,0,0);
}

.card-category:hover .elementor-widget-button .elementor-button,
.card-category:focus-within .elementor-widget-button .elementor-button,
.card-prodotti:hover .elementor-widget-button .elementor-button,
.card-prodotti:focus-within .elementor-widget-button .elementor-button{
  opacity: 1;
  pointer-events: auto;
}

.card-category .elementor-widget-heading,
.card-category .elementor-widget-button,
.card-prodotti .elementor-widget-heading,
.card-prodotti .elementor-widget-button
{
  transform: none !important;
  transition: none !important;
}

}




@media (max-width: 767px) {
    .card-category {
        --padding-bottom: 15px !important;

    }
}




/* GSAP ANIMAZIONE LISTINIG */


.back-category {
	z-index:999;
	position:absolute;
	bottom:120px;
	right:20px;
}


.back-category .elementor-button-icon svg {
	    transform: rotate(270deg);
}
@media (min-width: 768px) {
.back-category:hover .elementor-button-icon svg {
    transform: rotate(270deg) translateX(5px);
}
}

.back-category.cta-button {
	font-size:20px;
}

@media (max-width: 767px) {
	
	.back-category {
		top: 50px;
		bottom:unset;
		right:15px;
	}
	
	.back-category.cta-button {
		font-size:18px;
	}
	
.back-category:active .elementor-button-icon svg {
    transform: rotate(270deg) translateY(-5px);
}

.back-category:hover .elementor-button-icon svg {
    transform: rotate(270deg) !important;
}

}

section#bike-slider {
  position: relative;
  height: 100vh;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  transition: background-color .15s linear;
}

#bike-slider #loader {
  position: absolute;
  inset: 0;
  background: #002343;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
  transition: opacity 0.6s ease, visibility 0.6s ease;
}

#bike-slider #loader.hidden {
  opacity: 0;
  visibility: hidden;
}

#bike-slider .loader-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

#bike-slider .loader-ring {
  width: 70px;
  height: 70px;
  border: 5px solid rgba(255,255,255,0.2);
  border-top-color: #169FDB;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

#bike-slider .loader-text {
  font-family: var(--e-global-typography-accent-font-family, sans-serif);
  color: #FFFFFF;
  font-size: 1rem;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.bike-wrapper {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  pointer-events: none;
}

@media (min-width: 1199px) {
  .bike-wrapper {
   left:31vw;
  justify-content: center;
  }
  	
}
	


.bike-link {
  position: absolute;
  width: 100%;
  max-width: 90vh !important;
  height: auto;
  transform: translateY(100%);
  opacity: 0;
  visibility: hidden;
  will-change: transform, opacity;
  pointer-events: auto;
  cursor: pointer;
  display: block;
}

.bike-image {
  width: 100%;
  height: auto;
  display: block;
}

.line-bar {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 15;
  display: flex;
  flex-direction: column;
  height: 100vh;
  justify-content: center;
  background: #002343;
  padding-left: 25px;
  padding-right: 25px;
  width: 130px;
}

.line-section {
  display: flex;
  flex-direction: column;
  cursor: pointer;
}

.line-label {
  font-size: .85rem;
  color: #169FDB;
  margin-bottom: 12px;
  text-transform: uppercase;
  opacity: 1;
  padding-top: 15px;
  cursor: pointer;
  transition: color .25s;
  font-family: var(--e-global-typography-accent-font-family), Sans-serif;
}

.line-label:hover {
  color: #fff;
}

.line-label.active {
  color: #fff;
  opacity: 1;
}

.line-item {
  display: flex;
  align-items: center;
  gap: 12px;
  height: 30px;
  cursor: pointer;
  font-size: 14px;
}

.line {
  width: 3px;
  height: 100%;
  background: rgba(255,255,255,.15);
  position: relative;
}

.line::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 0;
  background: #fff;
  transition: height .25s;
}

.line-item.active .line::after {
  height: 100%;
}

.line-text {
  color: rgba(255,255,255,.45);
  white-space: nowrap;
  font-family: var(--e-global-typography-accent-font-family), Sans-serif;
}

.line-item.active .line-text {
  color: #fff;
  font-weight: 600;
}

.info-panel {
  position: absolute;
  top: 0;
  left: 131px;
  z-index: 16;
  opacity: 0;
  background: rgba(255,255,255,0.8);
  backdrop-filter: blur(6px);
  padding: 60px;
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
  transition: opacity .25s;
  width: 470px;
  pointer-events: auto; 
}

.info-panel.active {
  opacity: 1;
  z-index: 20;
  pointer-events: auto; 
}

.info-panel h2 {
  font-size: clamp(3rem, 1.636rem + 3.636vw, 6rem);
  font-weight: 700;
  margin-bottom: 10px;
  color: #169FDB;
  line-height: 1;
  margin-top: 0px;
  font-family: var(--e-global-typography-primary-font-family), Sans-serif;
  letter-spacing: -0.96px;
}

.info-panel h3 {
  font-size: clamp(0.938rem, 0.767rem + 0.455vw, 1.313rem);
  font-weight: 400;
  letter-spacing: -0.21px;
  color: #002343;
  margin-bottom: 0px;
  font-family: var(--e-global-typography-accent-font-family), Sans-serif;
}

.specs {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  grid-template-rows: repeat(2,auto);
  gap: 20px;
  margin-top: 20px;
}

.spec-item {
  text-align: left;
}

.spec-value {
  font-family: var(--e-global-typography-accent-font-family), Sans-serif;
  line-height: 1;
}

.spec-value .counter {
  font-size: clamp(1.625rem, 0.443rem + 1.818vw, 2.625rem);
  font-weight: 700;
  color: #002343;
  letter-spacing: -0.42px;
}

.spec-label {
  font-size: clamp(0.813rem, 0.585rem + 0.606vw, 1.313rem);
  color: #002343;
  letter-spacing: -0.21px;
  font-family: var(--e-global-typography-accent-font-family), Sans-serif;
}

.cta-button {
  display: flex;
  align-items: center;
  margin-top: 20px;
  color: #169FDB !important;
  text-decoration: none;
  font-weight: 600;
  border-radius: 0;
  transition: all 2.3s ease;
  font-family: var(--e-global-typography-primary-font-family), Sans-serif;
  font-size: clamp(1.25rem, 1.136rem + 0.303vw, 1.5rem);
  font-style: normal;
  font-weight: 400;
  letter-spacing: -0.2px;
}

.cta-button svg {
  transition: transform 0.3s ease;
}

.cta-button:hover svg {
  transform: translateX(5px);
}

@media only screen and (max-height: 800px) { 
  .line-item {
    height: 24px !important;
  } 
  
}

@media only screen and (max-height: 600px) { 
  .line-item {
    height: 22px !important;
    font-size: 12px !important;
  } 

  .line-label {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }
}

@media (max-width:800px){
  .line-bar{
    position: absolute;
    left: 0;
    top: 0;
    z-index: 15;
    display: flex;
    flex-direction: row;
    width: 100vw;
    height:47px;
    justify-content: center;
    background: #002343;
    padding-left: 0px;
    padding-right: 0;
  }
  
  a.bike-link {
    padding-top: 80px;
    padding-bottom: 80px;
	height:80vh;
}


  
  .line-section {
    display: flex;
    flex-direction: column;
    padding-left: 10px;
    padding-right: 10px;
  }
  
  .line-item {
    display: none;
  }
  
  .info-panel {
    left:0;
    top:47px;
    padding: 15px;
    border-top-right-radius:0px;
    border-bottom-right-radius:8px;
    max-width: 250px;
  }
  
  .bike-link {
    width: 100%;
    max-width: 100% !important;
  }
  
  .bike-image {
    width: 100%;
    object-fit: contain;
  }
  
  .bike-wrapper {
    align-items: flex-end;
  }
  
  .specs {
    margin-top: 10px;  
    gap: 5px;
  }
  
  .cta-button { 
    margin-top: 10px;
  }
}
 
 
 
/* WIDGET LINGUA */
.wpml-ls-legacy-dropdown {
    width: 85px !important;
} 


 .wpml-ls-legacy-dropdown a {
	background:transparent !important;
	border:none !important;
	padding:0 !important;
} 


.home .wpml-ls-legacy-dropdown a {
    color: #fff !important;
} 

.wpml-ls-native {     
	font-family: "Roboto Condensed";
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.24px;
}
 
.wpml-ls-legacy-dropdown a:hover {
	 color: #169FDB !important;
 }
 
 .home .menu-hover .wpml-ls-legacy-dropdown a {
	 color: #002343 !important;
 }
 
.home .sticky-on .wpml-ls-legacy-dropdown a {
	 color: #002343 !important;
 }
 
 .home .sticky-on .wpml-ls-legacy-dropdown a:hover {
	  color: #169FDB !important;
 }
 
 
 .wpml-ls-legacy-dropdown > ul > li > a::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-left: 6px;
  vertical-align: middle;
  top: 7px !important;

  /* usa la tua SVG come maschera */
  mask: url('/wp-content/uploads/2025/11/arrow-wpml-custom.svg') no-repeat center;
  -webkit-mask: url('/wp-content/uploads/2025/11/arrow-wpml-custom.svg') no-repeat center;
  mask-size: contain;
  -webkit-mask-size: contain;

  background-color: currentColor; /* <-- eredita il colore del testo */
  transition: transform 0.2s ease, background-color 0.3s ease;
}


.wpml-ls-sub-menu  {
	padding-top:5px !important;
}

.wpml-ls-sub-menu  li {
	padding-top:2px !important;
	padding-bottom:2px !important;
}

.wpml-ls-legacy-dropdown > ul > li:hover > a::after {
  transform: rotate(180deg);
}

.wpml-ls-legacy-list-horizontal > ul {
    text-align: left !important;
}

.wpml-ls-legacy-list-horizontal {
    margin-bottom: 0 !important;
    padding: 0!important;
}


.wpml-ls-legacy-list-horizontal ul
{
    display: inline-flex;
    list-style-type: none;
}

.wpml-ls-legacy-list-horizontal img.wpml-ls-flag {
    margin-right: 4px;
}

.wpml-ls-legacy-list-horizontal a {
    display: block;
    text-decoration: none;
    padding: 5px 10px 6px;
    line-height: 1;
}

.wpml-ls-legacy-list-horizontal>ul {
    padding-left: 30px !important;
}

img.wpml-ls-flag {
    border-radius: 0px !important;
}

.wpml-ls-legacy-list-horizontal a {
    padding: 5px 15px 6px !important;
}

.wpml-ls-legacy-list-horizontal a:first-child {
	padding-left:0px !important;
}

.wpml-ls-legacy-list-horizontal a:hover {
	color:#169FDB !important;
}


.wpml-ls-legacy-list-horizontal .wpml-ls-flag+span {
    margin-left: 2px !important;
}


 .elementor-widget-wpml-language-switcher .wpml-elementor-ls .wpml-ls-legacy-dropdown .wpml-ls-current-language:hover>a {
    color: #169FDB !important;
}

/* AREA RISERVATA */

div#cuar-js-content-container {
    margin-bottom: 64px;
	font-size: 16px !important;
    color: #002343 !important;
}


h1.entry-title {
    font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
    font-size: var(--e-global-typography-secondary-font-size);
    font-weight: var(--e-global-typography-secondary-font-weight);
    line-height: var(--e-global-typography-secondary-line-height);
    letter-spacing: var(--e-global-typography-secondary-letter-spacing);
}


body.customer-area-active .cuar-css-wrapper .cuar-menu-container .navbar .navbar-nav>li.current-menu-item>a, body.customer-area-active .cuar-css-wrapper .cuar-menu-container .navbar .navbar-nav>li.current-page-parent>a {
    background: var(--e-global-color-secondary);
    color: #fff;
}

div#cuar-js-content-cols-sizer {
    max-width: 1016px !important;
}

body.customer-area-active .cuar-css-wrapper .cuar-single-entry {
    border: none !important;
}


body.customer-area-active .cuar-css-wrapper .panel-primary.panel-border {
    border-color: #169fdb !important;
}


body.customer-area-active .cuar-css-wrapper button, body.customer-area-active .cuar-css-wrapper input[type=button], body.customer-area-active .cuar-css-wrapper input[type=reset], body.customer-area-active .cuar-css-wrapper input[type=submit] {
    -webkit-appearance: button;
    cursor: pointer;
    background: #169fdb;
    color: #fff;
    padding: 12px 55px;
    border-radius: 6px 6px 6px 6px;
	border: none;
}





@media (min-width: 767px) and (max-width: 815px) {
  .e-n-menu-title {
	  padding-left:7px !important;
	  padding-right:7px!important;
  }
}