@import url('https://fonts.googleapis.com/css?family=Poppins:400,500,600,700&display=swap');
*{
  margin: 0;
  padding: 0;
  outline: none;
  font-family: 'Poppins', sans-serif;
}
body{
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  overflow: scroll;
  /*background-color: #06468A;*/
}
::selection{
  color: #fff;
  background: #17A8E3;
}
.container{
  width: 650px;
  max-width: 85%;
  background: #fff;
  text-align: center;
  border-radius: 5px;
  padding: 50px 35px 10px 35px;
}
.container header{
  font-size: 35px;
  font-weight: 600;
  margin: 0 0 30px 0;
}
.container .form-outer{
  width: 100%;
  overflow: hidden;
}
.container .form-outer form{
  display: flex;
  width: 400%;
}
.form-outer form .page{
  width: 25%;
  transition: margin-left 0.3s ease-in-out;
}
.form-outer form .page .title{
  text-align: left;
  font-size: 25px;
  font-weight: 500;
}
.form-outer form .page .field{
  width: 600px;
  height: 45px;
  margin: 45px 0;
  display: flex;
  position: relative;
}
form .page .field .label{
  position: absolute;
  top: -30px;
  font-weight: 500;
}
form .page .field input:not([type="checkbox"]):not([type="radio"]) {
  height: 100%;
  width: 100%;
  border: 1px solid lightgrey;
  border-radius: 5px;
  padding-left: 15px;
  font-size: 18px;
}
form .page .field select{
  width: 100%;
  padding-left: 10px;
  font-size: 17px;
  font-weight: 500;
}
form .page .field button{
  width: 100%;
  height: calc(100% + 5px);
  border: none;
  background: #1ABCA1;
  margin-top: -20px;
  border-radius: 5px;
  color: #fff;
  cursor: pointer;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: 0.5s ease;
}
.envio{
  width: 100%;
  height: 110% !important;
  border: none;
  background: #1ABCA1;
  margin-top: -20px;
  border-radius: 5px;
  color: #fff;
  cursor: pointer;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: 0.5s ease;
}
form .page .field button:hover{
  background: #000;
}
form .page .btns button{
  margin-top: -20px!important;
}
form .page .btns button.prev{
  margin-right: 3px;
  font-size: 17px;
}
form .page .btns button.next{
  margin-left: 3px;
}
.container .progress-bar{
  display: flex;
  margin: 40px 0;
  user-select: none;
}
.container .progress-bar .step{
  text-align: center;
  width: 100%;
  position: relative;
}
.container .progress-bar .step p{
  font-weight: 500;
  font-size: 18px;
  color: #000;
  margin-bottom: 8px;
}
.progress-bar .step .bullet{
  height: 25px;
  width: 25px;
  border: 2px solid #000;
  display: inline-block;
  border-radius: 50%;
  position: relative;
  transition: 0.2s;
  font-weight: 500;
  font-size: 17px;
  line-height: 25px;
}
.progress-bar .step .bullet.active{
  border-color: #17A8E3;
  background: #17A8E3;
}
.progress-bar .step .bullet span{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.progress-bar .step .bullet.active span{
  display: none;
}
.progress-bar .step .bullet:before,
.progress-bar .step .bullet:after{
  position: absolute;
  content: '';
  bottom: 11px;
  right: -51px;
  height: 3px;
  width: 44px;
  background: #262626;
}
.progress-bar .step .bullet.active:after{
  background: #17A8E3;
  transform: scaleX(0);
  transform-origin: left;
  animation: animate 0.3s linear forwards;
}
@keyframes animate {
  100%{
    transform: scaleX(1);
  }
}
.progress-bar .step:last-child .bullet:before,
.progress-bar .step:last-child .bullet:after{
  display: none;
}
.progress-bar .step p.active{
  color: #17A8E3;
  transition: 0.2s linear;
}
.progress-bar .step .check{
  position: absolute;
  left: 50%;
  top: 70%;
  font-size: 15px;
  transform: translate(-50%, 0%);
  display: none;
}
.progress-bar .step .check.active{
  display: block;
  color: #fff;
}




.custom-select {
  position: relative;

  display: inline-block;
}

.custom-select select {
  display: none;
}

.custom-select .search-input {
  width: 100%;
  padding: 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
}

.custom-select.show select {
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 1;
}
#select2-paisfactura-container{
  width:570px;
}
#select2-pais-container{
  width:570px;
}
#si{
  height: 60%;
}
#no{
  height: 60%;
}

@media only screen and (min-width: 360px) and (max-width: 760px) {
  .container{
    width: 350px;
    background: #fff;
    text-align: center;
    border-radius: 5px;
    padding: 50px 35px 10px 35px;
  }
  .form-outer form .page .field{
    width: 300px;
    height: 45px;
    margin: 45px 0;
    display: flex;
    position: relative;
  }
  #select2-paisfactura-container{
    width:300px;
  }
  #select2-pais-container{
    width:300px;
  }
}

/* Añadir reglas de estilo específicas para dispositivos más pequeños */
@media only screen and (max-width: 600px) {
  /* Hacer los input y select ocupar el 100% del ancho */
  .field{
      max-width: 100% !important;
  }

}
input[type="radio"] {
  z-index: 10;
  position: relative;
}
#nombres, #nombres2{
  text-transform: capitalize !important;
}
/* Resto de tus estilos aquí... */

/* =====================================================
   Nuevo look profesional formulario CSC
   Color principal: #c10230
   Optimizado para iframe
===================================================== */

:root {
  --udla-red: #c10230;
  --udla-red-dark: #8f001f;
  --udla-red-light: #fbe8ed;
  --text-main: #1f2933;
  --text-muted: #6b7280;
  --border: #d8dee6;
  --bg-soft: #f6f7f9;
  --white: #ffffff;
}

html,
body {
  width: 100%;
  min-height: 100%;
  background: transparent !important;
  overflow-x: hidden;
}

body {
  display: block !important;
  padding: 20px;
  color: var(--text-main);
  font-family: 'Poppins', sans-serif;
}

/* Contenedor principal */
.container {
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  background: var(--white);
  border-radius: 18px;
  padding: 34px 36px 28px;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.12);
  border: 1px solid rgba(193, 2, 48, 0.10);
  text-align: left;
}

/* Título */
.container header {
  font-size: 28px;
  line-height: 1.2;
  font-weight: 700;
  color: var(--udla-red);
  margin-bottom: 28px;
  text-align: center;
}

/* Barra de progreso */
.container .progress-bar {
  margin: 28px 0 42px;
  background: transparent;
}

.container .progress-bar .step p {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
}

.progress-bar .step p.active {
  color: var(--udla-red);
}

.progress-bar .step .bullet {
  border: 2px solid var(--border);
  background: var(--white);
  color: var(--text-muted);
}

.progress-bar .step .bullet.active {
  border-color: var(--udla-red);
  background: var(--udla-red);
  color: #fff;
}

.progress-bar .step .bullet:before,
.progress-bar .step .bullet:after {
  background: var(--border);
}

.progress-bar .step .bullet.active:after {
  background: var(--udla-red);
}

/* Páginas */
.form-outer form .page .title {
  font-size: 20px;
  font-weight: 700;
  color: var(--text-main);
  margin-bottom: 26px;
}

/* Campos */
.form-outer form .page .field {
  width: 100%;
  height: auto;
  min-height: 48px;
  margin: 30px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

form .page .field .label {
  position: static;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-main);
}

form .page .field input:not([type="checkbox"]):not([type="radio"]),
form .page .field select,
form .page .field textarea {
  width: 100%;
  height: 48px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0 14px;
  font-size: 15px;
  font-weight: 400;
  color: var(--text-main);
  background: #fff;
  transition: all 0.2s ease;
}

form .page .field textarea {
  min-height: 90px;
  padding-top: 12px;
}

form .page .field input:focus,
form .page .field select:focus,
form .page .field textarea:focus {
  border-color: var(--udla-red);
  box-shadow: 0 0 0 4px rgba(193, 2, 48, 0.12);
}

/* Select2 */
.select2-container {
  width: 100% !important;
}

.select2-container .select2-selection--single {
  height: 48px !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--text-main) !important;
  line-height: 48px !important;
  padding-left: 14px !important;
}

.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default .select2-selection--single:focus {
  border-color: var(--udla-red) !important;
}

#select2-paisfactura-container,
#select2-pais-container {
  width: 100% !important;
}

/* Botones */
form .page .field button,
.envio {
  width: 100%;
  height: 50px !important;
  margin-top: 0;
  border: none;
  border-radius: 14px;
  background: var(--udla-red);
  color: #fff;
  cursor: pointer;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  transition: all 0.25s ease;
}

form .page .field button:hover,
.envio:hover {
  background: var(--udla-red-dark);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(193, 2, 48, 0.28);
}

form .page .field button.prev {
  background: #eef1f5;
  color: var(--text-main);
}

form .page .field button.prev:hover {
  background: #dfe4ea;
  box-shadow: none;
}

/* Botones agrupados */
form .page .btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

form .page .btns button.prev,
form .page .btns button.next {
  margin: 0 !important;
}

/* Radio y checkbox */
input[type="radio"],
input[type="checkbox"] {
  accent-color: var(--udla-red);
}

/* Bloques dinámicos */
#classcb1,
#classcb2,
#datosinsfactura,
#facturacion,
#codigoConvenioField,
#adicional {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  margin-top: 12px;
}

/* Mensajes visuales */
.is-loading {
  opacity: 0.75;
  cursor: not-allowed !important;
}

/* Iframe friendly */
* {
  box-sizing: border-box;
}

.form-outer {
  overflow: hidden;
}

.container .form-outer form {
  width: 400%;
}

/* Responsive */
@media only screen and (max-width: 760px) {
  body {
    padding: 12px;
  }

  .container {
    max-width: 100%;
    padding: 26px 20px 22px;
    border-radius: 14px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.10);
  }

  .container header {
    font-size: 23px;
  }

  .container .progress-bar .step p {
    font-size: 11px;
  }

  .form-outer form .page .field {
    width: 100%;
    margin: 26px 0;
  }

  form .page .btns {
    grid-template-columns: 1fr;
  }

  #select2-paisfactura-container,
  #select2-pais-container {
    width: 100% !important;
  }
}