/* ===== Cotizador estilo "barra" (desktop) + apilado (mobile) ===== */

#quoteForm.quote-form {
  border: 0;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 14px 35px rgba(0, 0, 0, 0.18);
  border-radius: 28px;
  overflow: hidden;
}

#quoteForm.quote-form .card-body {
  padding: 18px 18px;
}

/* Inputs base */
#quoteForm.quote-form .form-control { height: calc(1.5em + .75rem + 2px); }
#quoteForm.quote-form label { font-weight: 600; }

/* Botonera "Tipo de viaje" */
#quoteForm.quote-form .quote-triptype { gap: .25rem; }
#quoteForm.quote-form .quote-triptype .btn { white-space: normal; line-height: 1.2; }
#quoteForm.quote-form .quote-triptype .btn input { position: absolute; clip: rect(0,0,0,0); } /* accesibilidad */
#quoteForm.quote-form .quote-triptype.btn-group { display: flex; }

/* Barra principal */
#quoteForm.quote-form .quote-bar{
  background: #fff;
  border-radius: 999px;
  padding: 10px 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

#quoteForm.quote-form .quote-seg{
  padding: 6px 14px;
  flex: 1 1 180px;
  min-width: 160px;
}

#quoteForm.quote-form .quote-seg + .quote-seg{
  border-left: 1px solid rgba(0,0,0,.08);
}

/* Dentro de la barra, inputs sin borde para look tipo “segmento” */
#quoteForm.quote-form .quote-bar .form-control{
  border: 0;
  border-radius: 0;
  box-shadow: none !important;
  padding-left: 0;
  padding-right: 0;
}

#quoteForm.quote-form .quote-days{
  line-height: 1.1;
  margin-top: 4px;
}

/* Botón Buscar */
#quoteForm.quote-form .quote-seg--btn{
  flex: 0 0 160px;
  min-width: 150px;
  border-left: 0 !important;
  padding: 6px 6px;
  display: flex;
  align-items: center;
}

#quoteForm.quote-form .btn-search{
  width: 100%;
  border-radius: 999px;
  padding: 12px 14px;
  font-weight: 700;
}

/* Contacto */
#quoteForm.quote-form .quote-contact .form-control{
  border-radius: 10px;
}

/* Mobile: apilar y evitar separadores */
@media (max-width: 767.98px){
  #quoteForm.quote-form{
    border-radius: 18px;
  }
  #quoteForm.quote-form .quote-bar{
    border-radius: 18px;
    padding: 10px;
  }
  #quoteForm.quote-form .quote-seg{
    flex: 1 1 100%;
    min-width: 100%;
    border-left: 0 !important;
    padding: 8px 10px;
  }
  #quoteForm.quote-form .quote-seg + .quote-seg{
    border-left: 0;
    border-top: 1px solid rgba(0,0,0,.08);
  }
  #quoteForm.quote-form .quote-seg--btn{
    flex: 1 1 100%;
    padding: 10px;
  }
}

.phone-wrap{
  display:flex;
  align-items:stretch;
  gap:8px;
}
.phone-country{
  max-width:120px;
  border-radius:10px;
}
.phone-input{
  flex:1;
  border-radius:10px;
}
