h2 { font-weight:600; text-align:center; color:#073DA3; margin-bottom:28px; }

/* Inputs y selects */
label { font-weight:600; font-size:14px; display:block; margin-bottom:6px; background-color: transparent;
 }
input[type="text"], input[type="email"], input[type="number"], input[type="tel"], input[type="date"], select {
  width:100%; background-color:#F7F7F7; border:1px solid #EDEEEE; border-radius:8px; padding:10px 13px; font-size:16px; color:#212529; min-height:48px; box-sizing:border-box; transition:all .3s ease; appearance:none;
}
input::placeholder, select:invalid { color:#A6A8A9; }
input::date, select:invalid { color:#A6A8A9; }
input:focus, select:focus { outline:none; border:1px solid #8EA1FF; box-shadow:0 0 4px rgba(142,161,255,0.4); background-color:#fff; }


/* Flecha dropdown */
select { background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" fill="%238EA1FF" viewBox="0 0 24 24"><path d="M7 10l5 5 5-5z"/></svg>'); background-repeat:no-repeat; 
background-position:right 13px center; background-size:20px; }
select { color:#A6A8A9; }
/* Mensajes de error */
.invalid-feedback { color:#E0115F; font-size:12px; display:none; margin-top:4px; }
.is-invalid + .invalid-feedback { display:block; }

/* Grid */
.form-row { display:flex; flex-wrap:wrap; gap:16px; }
.form-col { flex:1; min-width:220px; }
.checkbox-group { margin-top:12px; }
.checkbox-group label { font-size:12px; font-weight:400; color:#212529; display:flex; align-items:flex-start; gap:8px; }
.checkbox-group input[type="checkbox"] { accent-color:#8EA1FF; margin-top:3px; }
.checkbox-group a { color:#E0115F; text-decoration:none; font-weight:600; }
.checkbox-group {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.checkbox-group input[type="checkbox"] {
  margin: 0;
  accent-color: #073DA3;
}

.checkbox-label {
  font-size: 16px;
  line-height: 1.4;
}



/* Botón */
button { width:100%; background-color:#073DA3; color:#fff; border:none; border-radius:8px; padding:16px; font-size:14px; font-weight:600; cursor:pointer; transition:background-color .3s ease; margin-top:16px; }
button:hover { background-color:#052F7B; }
.form-group { margin-bottom:16px; }

/* Flatpickr fixes */
.flatpickr-calendar { font-family:"Open Sans", sans-serif !important; z-index:9999 !important; }
.form-group .invalid-feedback { display:none; }
.form-group input.is-invalid ~ .invalid-feedback { display:block !important; }

.invalid-feedback {
  display: none;
  color: #E0115F;
  font-size: 12px;
  margin-top: 4px;
}

.is-invalid ~ .invalid-feedback {
  display: block;
}

@media (max-width: 480px) {
  select,
  input[type="text"],
  input[type="email"],
  input[type="number"],
  input[type="tel"],
  input[type="date"] {
    font-size: 14px;
  }

  input::placeholder,
  select:invalid {
    font-size: 13px;
  }

  .checkbox-label {
    font-size: 14px;
  }

  button {
    font-size: 13px;
    padding: 14px;
  }

  label {
    font-size: 13px;
  }
}