/* @version: 6 | 2025-09-09 16:25:49 | autore: Simone De Marchi */
/* =========================================
   Preventivatore Viaggio (scoped su #viaggioForm)
   Dipendenze: futura2025.css + components.css
========================================= */

#viaggioForm {
  /* dimensioni complessive */ 
  width: 100%;
  max-width: 1200px;            /* pieno in desktop, limitato solo dal max */
  margin: 32px auto 48px;

  /* contenitore & sfondo */
  background: #fafbfc;
  border-radius: 18px;
  box-shadow: 0 2px 16px rgba(80,80,80,0.08);
  border: 1px solid rgba(80,80,80,0.08);

  /* padding per evitare overflow laterali */
  padding: 20px 20px 28px;
  box-sizing: border-box;

  /* controlla eventuali sbordi interni */
  overflow-x: hidden;

  /* variabili locali (fallback se il tema non c’è) */
  --pv-primary: #527099;
  --pv-accent: var(--green-futura, #4caf50);
  --pv-muted: #5c6a79;
  --pv-border: #e5e7eb;
  --pv-bg: #fff;
  --pv-input-bg: #f6f7fa;
  --pv-focus: #3b77c3;
}

/* Evita che le .row di Bootstrap usino gutter negativi che causano overflow
   (scopo solo intra-form) */
#viaggioForm .row {
  --bs-gutter-x: 1rem;
  margin-left: 0;
  margin-right: 0;
  flex-wrap: wrap;
}

/* Colonne: assicurati che non superino mai la larghezza del contenitore */
#viaggioForm [class*="col-"] {
  max-width: 100%;
  box-sizing: border-box;
  padding-left: calc(var(--bs-gutter-x) * .5);
  padding-right: calc(var(--bs-gutter-x) * .5);
}

/* -------------------------------------------------
   Label
-------------------------------------------------- */
#viaggioForm .form-label,
#viaggioForm label {
  display: block;
  margin-bottom: 6px;
  margin-top: 10px;
  font-size: 0.95rem;
  color: #243446;
  overflow-wrap: anywhere;  /* evita sbordi con testi lunghi */
}

/* -------------------------------------------------
   Input / Select arrotondati e coerenti
-------------------------------------------------- */
#viaggioForm .form-control,
#viaggioForm .form-select,
#viaggioForm select,
#viaggioForm input[type="text"],
#viaggioForm input[type="time"],
#viaggioForm input[type="number"],
#viaggioForm input[type="date"] {
  border-radius: 999px !important;
  background: var(--pv-input-bg);
  border: 1.2px solid #d4d8de;
  padding: 10px 14px;
  font-size: 1rem;
  line-height: 1.25rem;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
}

/* Caso specifico: #durata_viaggio arrotondato */
#durata_viaggio {
  border-radius: 999px !important;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* Stato focus uniforme SOLO per campi testuali/select (non checkbox) */
#viaggioForm .form-control:focus,
#viaggioForm .form-select:focus,
#viaggioForm select:focus,
#viaggioForm input[type="text"]:focus,
#viaggioForm input[type="time"]:focus,
#viaggioForm input[type="number"]:focus,
#viaggioForm input[type="date"]:focus {
  background: #fff;
  border-color: var(--pv-focus);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--pv-focus) 22%, transparent);
  outline: none;
}

/* Flatpickr: l’input visibile è l’input di testo dopo l’hidden */
#viaggioForm .flatpickr.input,
#viaggioForm .flatpickr-input + .form-control,
#viaggioForm .flatpickr + input.form-control {
  border-radius: 999px !important;
  width: 100%;
  max-width: 100%;
}

/* -------------------------------------------------
   Bottoni (testo sempre chiaro, anche su hover/active)
-------------------------------------------------- */
#viaggioForm .btn {
  border-radius: 999px;
  font-weight: 600;
  overflow-wrap: anywhere; /* evita sbordi su testi lunghi */
}

/* Btn primary pieni */
#viaggioForm .btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--pv-primary);
  --bs-btn-border-color: var(--pv-primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: color-mix(in srgb, var(--pv-primary) 90%, #000 10%);
  --bs-btn-hover-border-color: color-mix(in srgb, var(--pv-primary) 90%, #000 10%);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: color-mix(in srgb, var(--pv-primary) 85%, #000 15%);
  --bs-btn-active-border-color: color-mix(in srgb, var(--pv-primary) 85%, #000 15%);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--pv-primary);
  --bs-btn-disabled-border-color: var(--pv-primary);
}

/* Btn outline (principali usati nel form) */
#viaggioForm .btn-outline-primary {
  --bs-btn-color: var(--pv-primary);
  --bs-btn-border-color: var(--pv-primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--pv-primary);
  --bs-btn-hover-border-color: var(--pv-primary);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: color-mix(in srgb, var(--pv-primary) 85%, #000 15%);
  --bs-btn-active-border-color: color-mix(in srgb, var(--pv-primary) 85%, #000 15%);
}
#viaggioForm .btn-outline-success {
  --bs-btn-color: var(--pv-accent);
  --bs-btn-border-color: var(--pv-accent);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--pv-accent);
  --bs-btn-hover-border-color: var(--pv-accent);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: color-mix(in srgb, var(--pv-accent) 85%, #000 15%);
  --bs-btn-active-border-color: color-mix(in srgb, var(--pv-accent) 85%, #000 15%);
}

/* -------------------------------------------------
   Checkbox (spunta visibile, niente ombra invadente)
-------------------------------------------------- */
#viaggioForm .form-check-input {
  border-radius: 6px;
  box-shadow: none;
  border-color: #c8ced6;
  background-color: #fff;
}

/* Focus sobrio per checkbox */
#viaggioForm .form-check-input:focus {
  box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--pv-primary) 25%, transparent);
  border-color: var(--pv-primary);
}

/* Spunta e colori coerenti */
#viaggioForm .form-check-input:checked {
  background-color: var(--pv-primary);
  border-color: var(--pv-primary);
}

/* Assicura l’icona spunta su tutti i browser */
#viaggioForm .form-check-input[type="checkbox"]:checked {
  background-image: var(--bs-form-check-bg-image, url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10l3 3l6-6'/%3e%3c/svg%3e"));
}

/* -------------------------------------------------
   Sezioni dinamiche (giorni / tappe / mezzi)
-------------------------------------------------- */

/* Giorno: contenitore principale di una giornata */
#viaggioForm .giorno-block {
  background: var(--pv-bg);
  border: 1px solid var(--pv-border);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 18px;
}
#viaggioForm .giorno-block h5 {
  margin-bottom: 10px;
  color: var(--pv-primary);
  overflow-wrap: anywhere;
}

/* Tappa e Mezzo: riquadri con bordo colorato a sinistra */
#viaggioForm .tappa-block,
#viaggioForm .mezzo-block {
  background: #fff;
  border: 1px solid var(--pv-border);
  border-left: 4px solid var(--pv-primary);
  border-radius: 12px;
  padding: 14px 14px 14px 16px;
  margin-bottom: 10px;
}
#viaggioForm .tappa-block h6,
#viaggioForm .mezzo-block h6 {
  color: var(--pv-primary);
  margin-bottom: 10px;
}

/* Righe interne dei riquadri (evita gutter negativi) */
#viaggioForm .tappe .row.g-2,
#viaggioForm #mezziContainer .row.g-2 {
  --bs-gutter-x: 0.75rem;
  margin-left: 0;
  margin-right: 0;
}

/* Blocco MEZZI: aspetto come giorno-block */
#viaggioForm #bloccoMezzi {
  background: var(--pv-bg);
  border: 1px solid var(--pv-border);
  border-radius: 12px;
  padding: 16px;
  margin-top: 24px;
  margin-bottom: 18px;
}
#viaggioForm #bloccoMezzi > h5 {
  margin-bottom: 10px;
  color: var(--pv-primary);
}

/* Icone informative */
#viaggioForm i.bi { vertical-align: -0.125em; }

/* -------------------------------------------------
   Responsive
-------------------------------------------------- */
@media (min-width: 992px) {
  #viaggioForm { padding: 24px 28px 32px; }
}

@media (max-width: 768px) {
  #viaggioForm {
    /* pieno, padding ridotto e nessuno sbordo */
    width: 100%;
    max-width: 100%;
    margin: 16px auto 32px;
    padding: 16px 14px 22px;

    /* contenitore & sfondo */
    background: #fff;
    border-radius: 0px;
    box-shadow: none;
    border: 0px;
  }

  #viaggioForm .giorno-block { padding: 14px; }
  #viaggioForm #bloccoMezzi { padding: 14px; }

  /* ancora più prudenza con i gutter su mobile */
  #viaggioForm .row {
    --bs-gutter-x: 0.75rem;
    margin-left: 0;
    margin-right: 0;
  }
}

/* Tablet: se 3 colonne risultano strette, portale a 2 */
@media (min-width: 768px) and (max-width: 991.98px) {
  #viaggioForm .col-md-4 { flex: 0 0 50%; max-width: 50%; }
}
