/* ============================================
   PeritoMap — Giro visite (postino intelligente)
   ============================================ */

.giro-wrap { max-width: 860px; margin: 0 auto; padding: 14px 12px 40px; }
.giro-intro { margin-bottom: 12px; }

.giro-controlli { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 4px; }
.giro-campo { flex: 1 1 140px; min-width: 130px; }
.giro-partenza-riga { display: flex; gap: 8px; }
.giro-partenza-riga input { flex: 1; min-width: 0; }

.giro-anteprima { margin: 6px 0 10px; }
.giro-conteggio { font-size: .95rem; font-weight: 600; color: #2c3542; margin: 4px 0; }
.giro-avviso-testo { color: #8a5300; font-weight: 500; }

.giro-risultato { margin-top: 16px; }
.giro-sintesi {
  background: #eef4ff; border: 1px solid #c4d5f2; border-radius: 10px;
  padding: 10px 14px; font-size: .95rem; margin-bottom: 12px;
}
.giro-lista { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.giro-tappa {
  display: flex; gap: 12px; align-items: flex-start;
  border: 1px solid var(--colore-bordo, #dde3ec); border-radius: 12px;
  background: #fff; padding: 12px;
}
.giro-tappa-num {
  flex: 0 0 auto; width: 34px; height: 34px; border-radius: 50%;
  background: #1f6fd6; color: #fff; font-weight: 700; font-size: 1.05rem;
  display: flex; align-items: center; justify-content: center;
}
.giro-tappa-corpo { min-width: 0; flex: 1; }
.giro-tappa-ora { font-size: .95rem; }
.giro-finestra { color: #3d4753; }
.giro-fascia-rich { font-size: .78rem; color: var(--colore-testo-secondario, #5b6572); margin-left: 6px; }
.giro-tappa-nome { font-weight: 600; margin-top: 2px; }
.giro-targa { font-family: 'Courier New', monospace; background: #f2f5f9; padding: 0 5px; border-radius: 4px; }
.giro-tappa-indirizzo { font-size: .88rem; color: #3d4753; }
.giro-avviso {
  margin-top: 6px; font-size: .84rem; color: #8a2f00;
  background: #fdf1de; border: 1px solid #eebc72; border-radius: 8px; padding: 5px 9px;
}
.giro-tappa-azioni { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }

.giro-azioni-finali { display: flex; gap: 10px; flex-wrap: wrap; margin: 14px 0 6px; }
.giro-fuori {
  margin-top: 12px; font-size: .86rem; color: #6b4a00;
  background: #fdf6e3; border: 1px solid #e4cd8a; border-radius: 8px; padding: 8px 12px;
}

.giro-mappa { height: 340px; border-radius: 12px; margin-top: 14px; border: 1px solid var(--colore-bordo, #dde3ec); }
.giro-pin {
  width: 28px; height: 28px; border-radius: 50%; background: #1f6fd6; color: #fff;
  font-weight: 700; display: flex; align-items: center; justify-content: center;
  border: 2px solid #fff; box-shadow: 0 1px 4px rgba(0, 0, 0, .35); font-size: .85rem;
}
.giro-pin-casa { background: #2c8f3a; font-size: 1rem; }

@media (max-width: 560px) {
  .giro-wrap { padding: 10px 8px 30px; }
  .giro-tappa { padding: 10px; gap: 8px; }
  .giro-mappa { height: 260px; }
}
