/* =========================
   Immagini
   ========================= */
.img {
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 10px;
}

/* =========================
   Testi (ATTENZIONE: globali)
   Mantengo i selettori uguali
   ========================= */
p {
  font-size: 16px;
  line-height: 1.7;
  margin: 0 0 14px 0;
}

.testo {
  letter-spacing: 1px;
  color: #720000;
  text-align: center;
  text-decoration: underline;
  text-indent: 5px;
  text-transform: uppercase;
  white-space: normal;
  word-spacing: 3px;
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  font-style: italic;
  font-weight: 700;
}

/* =========================
   Blink text (meno invasivo + accessibile)
   Mantengo stessa descrizione/classe
   ========================= */
.blink_text {
  /* prima era infinito: meglio limitarlo per UX/performance */
  animation: blinker 2.2s ease-in-out 6;
  color: #00f;
  font-size: 18px;
  font-weight: 700;
}

.blink_text a {
  color: #006400;
  font-size: 45px; /* lasciata uguale */
}

@keyframes blinker {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.15; } /* non sparisce del tutto (miglior UX) */
}

/* =========================
   Box evidenziato
   ========================= */
.border-radius {
  color: #000080;
  text-transform: uppercase;

  /* era 45px fisso: su mobile può essere enorme, qui lo rendo fluido */
  font-size: clamp(22px, 3vw, 45px);

  border-radius: 10px;
  width: 100%;
  border: 2px solid #808080;
  padding: 10px;

  /* margin 10px su full width può creare overflow: meglio verticale */
  margin: 10px 0;
  box-sizing: border-box;
}

h2 {
  color: #191970;
  margin: 18px 0 10px 0;
}

/* =========================
   FadeIn (ripulito)
   - rimuovo duplicazioni vendor inutili
   - rendo durata più breve (meno “pesante”)
   ========================= */
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.u--fadeIn:hover {
  color: #000080;
  animation: fadeIn 0.6s ease-in;
}

/* =========================
   Immagine responsive (mantengo selettore)
   ========================= */
.img-responsive {
  max-width: 100%;
  width: 500px;
  height: auto;
  display: block;
}

/* =========================
   Moving image (performance + layout)
   - prima: width 1000px + translateX(1500%) = pesante e spesso invisibile
   - ora: dimensione responsiva + animazione “sensata”
   ========================= */
@keyframes slideLeft {
  0%   { transform: translateX(-120%); }
  100% { transform: translateX(120vw); }
}

.moving-image {
  position: absolute;
  top: 75%; /* Puoi modificare questa posizione */
  left: 0;

  /* prima 1000px fissi: su mobile crea problemi */
  width: min(260px, 45vw);

  height: auto;
  animation: slideLeft 14s linear infinite;
  will-change: transform;
  pointer-events: none;
}

/* =========================
   Video container (fix unità + pulizia)
   ========================= */
#videoContainer {
  width: 100%;

  /* FIX: mancava px */
  max-width: 500px;

  margin: 0 auto;
  padding: 10%;
  margin-bottom: 25px;

  overflow: hidden;
  border-radius: 20px; /* Arrotonda i bordi */
  box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.2); /* Effetto ombra per un design più elegante */
  box-sizing: border-box;
}

#videoFrame {
  width: 100%;
  height: 500px;
  border-radius: 20px; /* Arrotonda anche l'iframe */
  border: 0;
  display: block;
}

/* Mob*

