/* Layout base del modal (lo dejamos) */
#mlsc_modal{position:fixed;inset:0;display:none;z-index:10000;}
#mlsc_modal.is-open{display:block;}
#mlsc_modal .mlsc-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);}
#mlsc_modal .mlsc-modal-dialog{position:relative;max-width:1200px; width:90vw;margin:5vh auto;background:#fff;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.12);padding:28px;height:90vh;max-height:800px}
#mlsc_modal .mlsc-modal-close{position:absolute;top:10px;right:12px;border:0;background:transparent;font-size:26px;cursor:pointer;opacity:.6;}
#mlsc_modal .mlsc-modal-body{height:100%;max-height:750px;overflow:auto}
div.mlsc-modal-body {
    display: flex;
    align-items: stretch;
    align-content: stretch;
    justify-content: space-between;
}
div.mlsc-modal-body > form {
    flex:0 0 50% !important

}
/* TIPOGRAFÍA Y CONTENEDOR */
.mlsc-form {font-family: 'Quicksand', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color:#222;}
.mlsc-form .section-title {text-align:center; font-weight:600; font-size:clamp(20px, 2.2vw, 34px); margin:4px 0 22px}
.mlsc-form .subtitle {text-align:center; color:#666; margin-bottom:18px;}

/* GRID → hacemos los grupos verticales, tipo login moderno */
.mlsc-form .form-group {margin: 14px 0;display: flex;gap:.5rem !important;width:95%}
.mlsc-form .form-group label {display:block; font-size:14px; color:#666; margin:0 0 8px 2px;}

/* CONTENEDOR CON ICONO */
.mlsc-form .input-container {position:relative;}
.mlsc-form .input-container .input-icon {
  position:absolute; inset:0 auto 0 14px; display:flex; align-items:center;
  font-size:20px; color:#9aa0a6; pointer-events:none;
}

/* INPUTS estilo “pill” */
.mlsc-form input[type="text"],
.mlsc-form input[type="email"],
.mlsc-form input[type="password"],
.mlsc-form textarea,
/* Estilo base de selects */
.mlsc-form select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: #f7f8fa;
    background-image: none;
    border-radius: .5rem;
    border: 1px solid var(--bs-gray-200);
    padding: 0.5rem 1.25rem 0.5rem 3rem !important;
    width: 100%;  /* espacio a la derecha para la flecha */
}

/* Contenedor del select para la flechita */
.mlsc-form .input-container.select-wrapper {
  position: relative;
}

.mlsc-form .input-container.select-wrapper::after {
  content: "▾"; /* ▼ flechita básica, puedes usar ▸, ▿, ▾, etc. */
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
  color: #777;
  pointer-events: none; /* que no tape el click */
}

/* Deja espacio a la izquierda cuando hay icono */
.mlsc-form .input-container input,
.mlsc-form .input-container textarea,
.mlsc-form .input-container select {
  padding-left:46px;
}

/* Focus suave */
.mlsc-form input:focus,
.mlsc-form textarea:focus,
.mlsc-form select:focus {
  outline:0; border-color:#dbe2f2;
  box-shadow:0 0 0 3px rgba(4,31,132,.12);
  background:#fff;
}

/* TEXTAREA */
.mlsc-form textarea {min-height:120px; resize:vertical}

/* HELP & ALERTS */
.mlsc-form .help-block{font-size:12px; color:#7a8593; margin-top:6px;word-wrap: break-word;}
.mlsc-form .alert {padding:12px 14px; border-radius:10px; font-size:14px; margin:12px 0}
.mlsc-form .alert-danger{background:#fff1f0; border:1px solid #ffd4d1; color:#b10000}
.mlsc-form .alert-success{background:#effaf3; border:1px solid #c9ecd6; color:#18794e}

/* CHECKBOX RGPD inline */
.mlsc-form .rgpd {display:flex; gap:10px; align-items:flex-start; color:#666; font-size:14px}
.mlsc-form .rgpd input[type="checkbox"]{margin-top:3px}

/* BOTÓN degradado */
.mlsc-form .btn-primary,
.mlsc-form button[type="submit"]{
  width:100%; border:0; border-radius:12px; padding:14px 18px;
  font-weight:600; font-size:16px; color:#fff; cursor:pointer;
  background: linear-gradient(90deg, #3a7bd5 0%, #003d8f 100%);
  box-shadow: 0 6px 16px rgba(0,61,143,.22);
  transition: transform .08s ease, box-shadow .2s ease;
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.mlsc-form .btn-primary:hover{box-shadow:0 8px 22px rgba(0,61,143,.28)}
.mlsc-form .btn-primary:active{transform:translateY(1px)}

/* DIVIDER (si lo usas) */
.mlsc-divider{display:flex; align-items:center; gap:12px; color:#7a8593; font-size:14px; margin:22px 0}
.mlsc-divider:before,.mlsc-divider:after{content:""; flex:1; height:1px; background:#e6ebf2}

/* SOCIAL BUTTONS (opcional, si los añades bajo el formulario) */
.mlsc-social{display:grid; gap:10px}
.mlsc-social .social-login-link{
  width:100%; display:flex; align-items:center; justify-content:center; gap:10px;
  border:1px solid #e8ecf3; background:#fff; border-radius:12px; padding:12px 14px;
  font-weight:600; color:#222;
}
.mlsc-social .social-login-link:hover{background:#f8fafc}

.mlsc_copy {
    flex: 0 1 49% !important;
    padding: 1rem .5rem 1rem 1.5rem;
    background-image:url('../img/background_proyecto1.webp');
    background-size: cover;
    background-position: center center;
    position:relative;
}
.mlsc_copy .mlsc_overlay {
  position: absolute;
  width: 100%;
  height:100%;
  inset:0;
  background:rgba(255,255,255,0.6);
  backdrop-filter: blur(4px);
  z-index: 0;
  padding: 1rem .5rem 1rem 1.5rem;
}
.mlsc_copy_content {
  z-index: 2;
  position: relative;
}
.mlsc_copy h2, 
.mlsc_copy p {
  z-index:2;
}
.mlsc_copy h2 {
    font-size: 1.7rem !important;
    font-weight:500;
}
.mlsc_copy p {
    font-size:.9rem
}
.mlsc_copy a.tel {
  font-weight: 600;
  color:var(--bs-primary, lightblue);
}


/* Responsive: reduce márgenes laterales en pantallas estrechas */
@media (max-width: 575px){
  #mlsc_modal .mlsc-modal-dialog{margin:0; min-height:100vh; border-radius:0}
  #mlsc_modal .mlsc-modal-dialog {
    max-width: 100%;
    width: 99vw;
    box-shadow: none !important;
    height: 100dvh;
    max-height: 100%;
  }
  .mlsc-modal-body {
    flex-direction: column;
  }
  .mlsc-form .form-group {
    align-items: center
  }
  
  .mlsc-form .form-group > label {
    flex: 0 0 33% !important;
  }
  .mlsc-form .form-group > div {
    flex: 0 0 66%
  }
  .mlsc-form .form-group input[type="file"] {
    max-width:85% !important;
  }
}
