/* sticky header personalizzazione home*/

@media (min-width: 1200px) {
  .container {
    max-width: 80% !important;
  }
}

.header-container{
  position: absolute !important; 
  left:0; 
  right:0;
}

.sticky-header-active .header-container{
  position: relative !important;
}


.header-container .nav-link{
  color: #FFF !important;
}

.header-container .nav-link:hover{
  color: #ffcc00 !important;
}
.ntel {
  color: #FFF;
}

.ntel:hover {
  color: #ffcc00;
}

.ntelsvg{
  fill: #FF0;
}


.sticky-header-active .header-container{
  background-color: #FFF;
}


.sticky-header-active .header-container .nav-link{
  color: var(--secondary) !important;
}

.sticky-header-active .header-container .nav-link:hover{
  color: var(--primary) !important;
}

.sticky-header-active .ntelsvg{
  fill: var(--secondary) !important;
}

.sticky-header-active .ntel {
  color: var(--secondary) !important;
}

.sticky-header-active .ntel:hover {
  color: var(--primary) !important;
}






/* icona search */

/* Stile base per il pulsante */
#openChatButton {
  cursor: pointer;
  display: flex;
  align-items: center;
}

#openChatButton .bi-search {
  fill: #FFF; /* Cambia il colore della lente su hover */
}

#openChatButton:hover .bi-search {
  fill: #FF0; /* Cambia il colore della lente su hover */
}

#openChatButton .bi-stars {
  fill: #FFF; /* Cambia il colore delle stelline su hover */
}

#openChatButton:hover .bi-stars {
  fill: #ffcc00; /* Cambia il colore delle stelline su hover */
}

.sticky-header-active .header-container{
  position: relative;
}



.sticky-header-active #openChatButton .bi-search {
  fill: var(--secondary) /* Cambia il colore della lente su hover */
}

.sticky-header-active #openChatButton .bi-stars {
  fill: var(--secondary); /* Cambia il colore delle stelline su hover */
}

.sticky-header-active #openChatButton:hover .bi-search {
  fill: var(--primary); /* Cambia il colore della lente su hover */
}

.sticky-header-active #openChatButton:hover .bi-stars {
  fill: var(--primary); /* Cambia il colore della lente su hover */
}


/* Animazione opzionale per un effetto più fluido */
.bi-search,
.bi-stars {
  transition: fill 0.3s ease-in-out;
}

/* fine icona search */




#header .header-container .header-btn-collapse-nav {
  background: #FFFFFF;
  color: #183F72;
  
}

.sticky-header-active #header .header-container .header-btn-collapse-nav {
  background: #183F72;
  color: #ffffff;
}


.sticky-header-active #header .header-container .ico_whatsapp {
  fill: #183F72;
}

.sticky-header-active #header .header-container .ico_ai {
  fill: #183F72;
}


.home-wrapper {
  display: flex;             /* Attiva Flexbox */
  flex-direction: column;    /* Impila i figli verticalmente */
  height: 100vh;             /* Il genitore occupa il 100% dell'altezza schermo */
  background-color: #f0f0f0; /* Sfondo di fallback, puoi rimuoverlo */
}

/* Su schermi landscape corti, il wrapper non è più vincolato a 100vh */
@media (max-height: 900px) and (orientation: landscape) {
  .home-wrapper {
    height: auto;
  }
}


.fullscreen-image-container {
    width: 100%; /* Larghezza del contenitore uguale a quella dello schermo */
    /*height: 80vh; */ /* Altezza del contenitore: 85% dell'altezza dello schermo */
    flex: 1;
    min-height: 0;    
    overflow: hidden; /* Nascondi eventuali parti dell'immagine che escono dal contenitore */
    position: relative; /* Per posizionare l'immagine in modo assoluto */
}

/* Su schermi landscape corti, la foto occupa 100vh */
@media (max-height: 900px) and (orientation: landscape) {
  .fullscreen-image-container {
    height: 100vh;
    flex: none;
  }
}

.fullscreen-image {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    object-fit: cover; /* Copre l'intero contenitore senza distorsioni */
}

.desktop-image {
    display: block; /* Visibile su desktop */
}

.mobile-image {
    display: none; /* Nascosto su desktop */
}

.mobile-landscape-image {
    display: none; /* Nascosto di default */
}

/* Media query per mobile (smartphone) */
@media (max-width: 767px) {
    .desktop-image {
        display: none; /* Nascondi l'immagine per desktop */
    }

    .mobile-image {
        display: block; /* Mostra l'immagine per mobile */
    }
    
    .mobile-landscape-image {
        display: none;
    }
}

/* Media query per mobile landscape - Funziona su tutti i device moderni ruotati */
@media (orientation: landscape) and (max-height: 600px) {
    .desktop-image {
        display: none;
    }
    
    .mobile-image {
        display: none;
    }
    
    .mobile-landscape-image {
        display: block;
    }

    .search_ai_container{
      top: 40% !important;
    }
}


/* EFFETTO KEN BURNS */

/* Wrapper interno che contiene solo le immagini */
.fullscreen-image-inner {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    animation: kenburns-container 20s ease-out infinite alternate;
}

@keyframes kenburns-container {
    0% {
        transform: scale(1) translate(0, 0);
    }
    100% {
        transform: scale(1.15) translate(-3%, 2%);
    }
}

/* Variante per mobile */
@media (max-width: 767px) {
    .fullscreen-image-inner {
        animation: kenburns-container-mobile 18s ease-out infinite alternate;
    }
    
    @keyframes kenburns-container-mobile {
        0% {
            transform: scale(1) translate(0, 0);
        }
        100% {
            transform: scale(1.12) translate(-2%, 1.5%);
        }
    }
}

/* Variante per mobile landscape */
@media (orientation: landscape) and (max-height: 600px) {
    .fullscreen-image-inner {
        animation: kenburns-container-landscape 18s ease-out infinite alternate;
    }
    
    @keyframes kenburns-container-landscape {
        0% {
            transform: scale(1) translate(0, 0);
        }
        100% {
            transform: scale(1.12) translate(-2%, 1.5%);
        }
    }
}
/* FINE EFFETTO KEN BURNS */


/* " BOX GRANDI HOME */

.home-box-container {
  display: flex;
  gap: 2rem;
  padding: 3rem 2rem;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  max-width: 1400px;
  margin: auto;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background-color: transparent;
}

.home-box-container .info-box {
  position: relative;
  width: 100%;
  min-height: 700px;
  background-size: cover;
  background-position: center top;
  border-radius: 1.25rem;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  text-align: center;
  padding: 4rem 2rem 2rem;
}

.home-box-container .info-box:hover {
  transform: translateY(-5px) scale(1.01);
}

.home-box-container .box-content {
  z-index: 2;
  max-width: 600px;
}

.home-box-container .box-content h3 {
  font-size: 2rem;
  font-weight: 700;
  padding-top: 4rem;
  margin-bottom: 1rem;
  color: #ffffff;
}

.home-box-container .box-content p {
  font-size: 1.1rem;
  line-height: 1.6;
  color: #ffffff;
  margin-bottom: 1.5rem;
}

.home-box-container .box-btn {
  display: inline-block;
  padding: 0.75rem 1.75rem;
  border-radius: 50px;
  background-color: #ffffff;
  color: #000000;
  text-decoration: none;
  font-weight: 600;
  transition: all 0.3s ease;
  font-size: 1rem;
  border: 2px solid #000000;
}

.home-box-container .box-btn:hover {
  background-color: #000000;
  color: #ffffff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.home-box-container h3{
    line-height: 30px;
}

@media (max-width: 768px) {
  .home-box-container .info-box {
    min-height: 600px;
    padding: 3rem 1.5rem 1.5rem;
  }
}

@media (min-width: 768px) {
  .home-box-container .info-box {
    width: calc(50% - 1rem);
  }
}    


/* FINE BOX GRANDI HOME */

/*RICERCA SU HERO IMMAGINE HOME*/

.search_ai_container {
  position: absolute;
  top: 33%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 760px;
  z-index: 10;
}

.search_ai_input-group {
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.search_ai_input {
  padding: 15px 20px;
  font-size: 1rem;
  border-radius: 30px;
  border: none;
  outline: none;
  width: 100%;
}

#input_text_ai_home {
  font-size: 1.05rem;
}

#btn_search_ai_home {
  font-size: 1.09rem;
}

.search_ai_button {
  background-color: #1390c2;
  color: white;
  border-radius: 30px;
  font-weight: bold;
  transition: background-color 0.3s ease;
}

.search_ai_button:hover {
  background-color: #59A5D8;
}

.search_ai_dropdown {
  margin-top: 15px;
  background-color: rgba(255, 255, 255, 0.95);
  border-radius: 10px;
  padding: 15px;
  max-height: 300px;
  overflow-y: auto;
  display: none;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.search_ai_message {
  margin-bottom: 10px;
  line-height: 1.4;
}

.search_ai_message.search_ai_ai {
  color: #555;
}

.search_ai_message.search_ai_user {
  color: #000;
  font-weight: bold;
  text-align: right;
}

/* FINE RICERCA HERO IMMAGINE HOME */



.scroll-mouse-indicator-wrapper {
    position: absolute;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    pointer-events: none; /* evita interferenze con click */
  }
  
  .scroll-dot {
    animation: scroll-dot 2s infinite ease-in-out;
  }
  
  @keyframes scroll-dot {
    0% { transform: translateY(0); opacity: 1; }
    50% { transform: translateY(10px); opacity: 0.6; }
    100% { transform: translateY(0); opacity: 1; }
  }
  
/* ============================================
     CSS - SLIDER MINIATURE AUTO (DRAGGABLE)
     ============================================ */
  
  /* Container principale slider */
  .slider-container-m {
    flex-shrink: 0;
    overflow: hidden;
    width: 100%;
    padding: 20px 0 30px;
    position: relative;
    background-color: #fff;
    cursor: grab;
  }
  
  .slider-container-m.dragging {
    cursor: grabbing;
  }
  
  /* Su schermi landscape corti */
  @media (max-height: 900px) and (orientation: landscape) {
    .slider-container-m {
      flex-shrink: unset;
      position: static;
    }
  }
  
  /* Track dello slider */
  .slider-track {
    display: flex;
    width: max-content;
    will-change: transform;
  }
  
  /* Singolo item */
  .slider-item {
    position: relative;
    flex: 0 0 auto;
    margin-right: 20px;
  }
  
  .slider-item img {
    width: 250px;
    height: 125px;
    object-fit: cover;
    border-radius: 8px;
    transition: filter 0.3s ease, transform 0.3s ease;
    pointer-events: none;
    user-select: none;
  }
  
  .slider-item img:hover {
    transform: scale(1.05);
  }
  
  /* Badge con numero auto */
  .car-count {
    position: absolute;
    z-index: 1000;
    top: 20px;
    right: 10px;
    background-color: #1390c2;
    color: white;
    font-size: 14px;
    font-weight: bold;
    padding: 6px;
    border-radius: 50%;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    pointer-events: none;
  }
  
  /* Responsive mobile */
  @media (max-width: 768px) {
    .slider-item img {
      width: 250px;
      height: 125px;
    }
  
    .car-count {
      width: 28px;
      height: 28px;
      font-size: 12px;
      padding: 4px;
    }
  }
  
  
  /* FINE MINIATURE DRAGGABILI */	
  
  
  .info-box {
    position: relative;
    overflow: hidden;
    min-height: 450px;
  }

  .info-box-0 {
    background-position: bottom;
    background: 
    linear-gradient(to bottom, 
      rgba(0,0,0,0.5) 0%, 
      rgba(0,0,0,0.3) 40%, 
      transparent 60%),
    url('../images/box-nuovo-v2.jpg');
    background-position: center bottom !important;
  }

  .info-box-1 {
    background-position: bottom;
    background: 
    linear-gradient(to bottom, 
      rgba(0,0,0,0.5) 0%, 
      rgba(0,0,0,0.3) 40%, 
      transparent 60%),
    url('../images/box-elettrico-v2.jpg');
    background-position: center bottom !important;
  }
  
  .info-box-2 {
    background-position: bottom;
    background: 
    linear-gradient(to bottom, 
      rgba(0,0,0,0.5) 0%, 
      rgba(0,0,0,0.3) 40%, 
      transparent 60%),
    url('../images/box-assistenza-v2.jpg');
    background-position: center bottom !important;
  }


  
  .info-box .box-content {
    position: relative;
    z-index: 1;
    padding: 20px;
    color: #fff;
  }
  
  
  /* Container principale */
  .info-box {
      position: relative;
      overflow: hidden;
      min-height: 450px;
      border-radius: 1.25rem; /* Assicurati che questo sia lo stesso radius del tuo design */
  }
  
  /* Carousel interno con bordi arrotondati */
  .carof_inner-rounded {
      border-radius: 18px !important;
      overflow: hidden;
  }
  
  /* Assicura che tutto il contenuto del carousel abbia bordi arrotondati */
  #carof_financeCarousel .carousel-item,
  #carof_financeCarousel .carof_overlay,
  #carof_financeCarousel .box-content {
      border-radius: 1.25rem;
  }
  
  /* Overlay per le immagini di sfondo */
  .carof_overlay {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background-size: cover;
      background-position: bottom;
      opacity: 1;
      z-index: 0;
      border-radius: 1.25rem;
  }
  
  /* Immagini di sfondo per ogni slide */
  #carof_financeCarousel .carousel-item:nth-child(1) .carof_overlay {
      /*background-image: url('../images/box-offerte-finanziarie-volvo.jpg');*/
          background: 
      linear-gradient(to bottom, 
        rgba(0,0,0,0.5) 0%, 
        rgba(0,0,0,0.3) 40%, 
        transparent 60%),
      url('../images/box-offerte-finanziarie-volvo.jpg');
      background-position: center bottom !important;
      background-size: cover;
  }
  
  #carof_financeCarousel .carousel-item:nth-child(2) .carof_overlay {
      background-image: url('../images/box-offerte-finanziarie-lotus.jpg');
  }
  
  #carof_financeCarousel .carousel-item:nth-child(3) .carof_overlay {
      background-image: url('../images/box-offerte-finanziarie-subaru.jpg');
  }
  
  #carof_financeCarousel .carousel-item:nth-child(4) .carof_overlay {
      background-image: url('../images/box-offerte-finanziarie-lynkco.jpg');
  }
  
  #carof_financeCarousel .carousel-item:nth-child(5) .carof_overlay {
    /* background-image: url('../images/box-offerte-finanziarie-sportequipe.jpg');*/
      background: 
      linear-gradient(to bottom, 
        rgba(0,0,0,0.5) 0%, 
        rgba(0,0,0,0.3) 40%, 
        transparent 60%),
      url('../images/box-offerte-finanziarie-sportequipe.jpg');
      background-position: center bottom !important;
      background-size: cover;
  }
  
  #carof_financeCarousel .carousel-item:nth-child(6) .carof_overlay {
      background-image: url('../images/box-offerte-finanziarie-ichx.jpg');
  }
  
  #carof_financeCarousel .carousel-item:nth-child(7) .carof_overlay {
      background-image: url('../images/box-offerte-finanziarie-xev.jpg');
  }
  
  
  /* Posizionamento del contenuto */
  #carof_financeCarousel .box-content {
      position: relative;
      z-index: 1;
      height: 100%;
      display: flex;
      align-items: baseline;
      padding: 5.25rem 40px 0;   
      max-width: inherit !important;
  }
  
  /* Bottone */
  #carof_financeCarousel .box-btn {
      position: relative;
      z-index: 1;
      margin: 20px;
  }
  
  /* Nasconde indicatori e controlli */
  .carousel-indicators,
  .carousel-control-prev,
  .carousel-control-next {
      display: block !important;
  }
  
  /* Assicura che il carousel occupi tutto lo spazio */
  #carof_financeCarousel,
  #carof_financeCarousel .carousel-inner,
  #carof_financeCarousel .carousel-item {
      height: 100%;
      border-radius: 1.25rem;
  }
  
  
  .img-bw {
    filter: grayscale(100%);
    transition: filter 0.3s ease;
  }
  
  @media (max-width: 768px) {
    .slider-container-m {
      padding-top: 0px !important;
    }
  }
  
  .slider-container-m .card-body {
      padding: 0px !important;
    }
  
  
    /* Safari e iOS (necessario per sovrascrivere lo stile predefinito) */
  input::-webkit-input-placeholder {
      font-size: 14px;
      font-family: inherit;
      color: #6c757d;
  }
  
/* Carousel Offerte Fade: dissolvenza morbida */
  .carousel.carousel-fade .carousel-item {
    opacity: 0;
    transition: opacity 0.8s ease-in-out;
    backface-visibility: hidden;
    will-change: opacity;
  }
  
  .carousel.carousel-fade .carousel-item.active,
  .carousel.carousel-fade .carousel-item-next.carousel-item-left,
  .carousel.carousel-fade .carousel-item-prev.carousel-item-right {
    opacity: 1;
  }
  
  /* rimuove l'effetto translate che Bootstrap applica per lo slide */
  .carousel.carousel-fade .carousel-item-next,
  .carousel.carousel-fade .carousel-item-prev,
  .carousel.carousel-item.active.carousel-item-left,
  .carousel.carousel-fade .carousel-item.active.carousel-item-right {
    transform: none;
  }
  
  /* rispetto preferenze di riduzione del movimento */
  @media (prefers-reduced-motion: reduce) {
    .carousel.carousel-fade .carousel-item {
      transition: none !important;
    }
  }
  
  .carousel-item img {
    image-rendering: auto;
    -webkit-font-smoothing: antialiased;
    filter: contrast(0.98) saturate(1.02) blur(0.0px);
    /* Non aggiungere blur eccessivo — può impattare performance */
  }
  
  * Container dei dots */
  .custom-dots {
      position: relative;
      margin-top: 12px;
      display: flex;
      justify-content: center;
      gap: 8px;
  }
  
  /* Dot base */
  .custom-dots button {
      width: 10px;
      height: 10px;
      border: none;
      background-color: #d0d0d0;
      opacity: 1;
      transition: transform 0.3s ease, background-color 0.3s ease;
  }
  
  /* Dot attivo */
  .custom-dots button.active {
      background-color: #246d95; /* richiamo al tuo colore marker Google Maps */
      transform: scale(1.25);
  }
  
  /* Dots focus + accessibility */
  .custom-dots button:focus {
      outline: none;
      box-shadow: 0 0 0 3px rgba(227, 97, 89, 0.3);
  }
  
  /* 📱 MOBILE: riduzione dimensioni + spacing */
  @media (max-width: 576px) {
      .custom-dots {
          gap: 5px;
          margin-top: 8px;
      }
  
      .custom-dots button {
          width: 7px;
          height: 7px;
          transform: none; /* niente ingrandimento su mobile */
      }
  
      .custom-dots button.active {
          transform: none;
      }
  }
  
  /* ========================================
     RIBBON SCONTO PERCENTUALE - CARD AUTO
     Posizione: BASSO DESTRA (sopra immagine)
     Colore: VERDE (risparmio/convenienza)
     ======================================== */
  
  .boxauto-ribbon-sconto {
    position: absolute;
    bottom: 290px;
    right: 12px;
    background: linear-gradient(135deg, #28a745 0%, #218838 100%);
    color: white;
    padding: 8px 16px;
    font-size: 1.1rem;
    font-weight: 900;
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(40, 167, 69, 0.4);
    z-index: 15;
    pointer-events: none;
    transition: all 0.3s ease;
    letter-spacing: 0.5px;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  }
  
  /* Hover effect sulla card: ribbon si ingrandisce */
  .boxauto-card:hover .boxauto-ribbon-sconto {
    transform: scale(1.08);
    box-shadow: 0 6px 16px rgba(40, 167, 69, 0.6);
  }
  
  /* Responsive Mobile */
  @media (max-width: 991.98px) {
    .boxauto-ribbon-sconto {
      top: 465px;
      right: 10px;
      padding: 6px 12px;
      font-size: 0.95rem;
    }
  }
  
  @media (max-width: 575px) {
    .boxauto-ribbon-sconto {
      top: 225px;
      right: 8px;
      padding: 5px 10px;
      font-size: 0.85rem;
      letter-spacing: 0.3px;
    }
  }
  
  /* ========================================
     PREZZO BARRATO NELLA CARD
     ======================================== */
  
  /* Prezzo barrato più piccolo */
  .boxauto-card .text-decoration-line-through {
    font-size: 0.85rem;
    color: #6c757d;
    line-height: 1.2;
  }
  
  /* Prezzo finale evidenziato */
  .boxauto-card .h5.text-primary {
    line-height: 1;
    margin-top: 2px;
  }
  
  /* Contenitore prezzi allineato a destra */
  .boxauto-card .text-end {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
  }
  
  /* Mobile: prezzi più compatti */
  @media (max-width: 575px) {
    .boxauto-card .text-decoration-line-through {
      font-size: 0.75rem;
    }
    
    .boxauto-card .h5.text-primary {
      font-size: 1.1rem;
    }
  }