/*!********************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[0].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./assets/src/css/page-home/home-identidad.css ***!
  \********************************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
/* ESTILOS GENERALES Y LAYOUT */
.section-wrapper,
.confirmacion {
  max-width: 900px;
  margin: auto;
  text-align: center;
}

.confirmacion * {
  box-sizing: border-box;
}

.page-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
}

.page-container {
  padding: 284px 24px;
  text-align: center;
}

.hide {
  display: none;
}

/* TIPOGRAFÍA */
/* Títulos */
.section-title {
  font-size: clamp(19px, 1.2rem + 1.5vw, 32px);
  line-height: 1.2;
  font-weight: lighter;
  color: var(--color-azul-movistar);
  margin-bottom: 5px;
}

.start-validation .section-title {
  font-size: clamp(24px, 1.2rem + 2.5vw, 45px);
}

.section-subtitle {
  font-size: 1rem;
  color: var(--color-azul-oscuro-movistar);
  margin-bottom: 15px;
}

/* Variantes de Títulos */
.title-blue,
.text-azul-movistar,
.text-nom-aprobado {
  color: var(--color-azul-movistar);
}

.title-blue,
.text-title,
.text-subtitle {
  font-weight: 700;
}

.text-title,
.text-subtitle {
  color: var(--color-azul-movistar);
}

.text-subtitle {
  margin-top: 100px;
  font-size: 2.12rem;
}

.text-subtitle2 {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--color-gris-6-movistar);
}

.text-ul {
  font-size: 1.13rem;
  font-weight: 400;
  color: var(--color-gris-5-movistar);
}

.text-vista {
  font-size: 20px;
  color: var(--color-gris-4-movistar);
}

.text-recomendacion {
  color: var(--color-gris-4-movistar);
  font-weight: 400;
  margin-top: 10px;
  max-width: 700px;
}

.text-error {
  color: var(--color-rojo-movistar);
  display: block;
}

.linea-separadora {
  border-top: 2px solid var(--color-gris-5-movistar);
}

/* Headers Específicos */
.gif-spinner .section-subtitle,
.gif-spinner h2,
.page-wrapper h2,
.confirmacion .page-header h1 {
  color: var(--color-azul-movistar);
}

.gif-spinner h2,
.page-wrapper h2 {
  font-weight: lighter;
  margin-top: 5px;
  margin-bottom: 5px;
}

.gif-spinner h2 {
  font-size: clamp(28px, 2.54vw + 19.8px, 32px);
}

.page-wrapper h2 {
  font-size: 32px;
  margin-bottom: 0px;
}

.confirmacion .page-header {
  text-align: center;
  margin-bottom: 30px;
}

.confirmacion .page-header h1 {
  font-size: clamp(1.5rem, 2.55vw, 2rem);
  margin-bottom: 0.5rem;
  font-weight: lighter;
}

.confirmacion .page-header p {
  color: var(--color-azul-oscuro-movistar);
  font-size: 1rem;
}

/* BOTONES */
/* Estilos Base de Botones */
.btn,
.btn-primary,
.confirmacion .btn-primary,
.confirmacion .btn-secondary {
  font-weight: normal;
  font-size: 14px;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.btn {
  min-width: 160px;
  max-width: 200px;
}

/* Botones Principales */
.btn-primary,
.confirmacion .btn-primary,
.btn.btn-enviar-foto,
.btn.btn-frontal-foto {
  background: var(--color-azul-digital-movistar) !important;
  color: var(--color-blanco-movistar);
  border: none;
  height: 44px;
  width: 240px;
  min-width: 160px;
  max-width: 240px;
}

/* Hover compartido botones azules */
.btn-primary:hover,
.confirmacion .btn-primary:hover,
.btn.btn-enviar-foto:hover,
.btn.btn-frontal-foto:hover,
.btn.btn-retake-blue:hover {
  background-color: var(--color-azul-digital-claro-movistar) !important;
  color: var(--color-blanco-movistar) !important;
}

/* Botones Secundarios */
.confirmacion .btn-secondary {
  background: var(--color-azul-digital-movistar);
  color: var(--color-blanco-movistar);
  border: none;
  height: 32px;
  width: 160px;
  min-width: 130px;
  max-width: 160px;
  white-space: nowrap;
  border-radius: 4px;
}

.confirmacion .btn-secondary:hover {
  background: var(--color-azul-digital-claro-movistar);
}

/* Botón Capturar Foto */
.btn.btn-capturar-foto {
  margin: 100px 0;
  border: 2px solid var(--color-azul-digital-movistar);
  color: var(--color-azul-digital-movistar);
  border-radius: 14px;
  width: 30%;
  height: 100px;
  background-color: transparent;
}

.btn.btn-capturar-foto:hover {
  background-color: var(--color-azul-digital-movistar);
  color: var(--color-blanco-movistar);
}

.btn.btn-capturar-foto svg {
  fill: var(--color-azul-digital-movistar);
}

.btn.btn-capturar-foto:hover svg {
  fill: var(--color-blanco-movistar);
}

/* Botón Tomar Foto */
.btn.btn-tomar-foto {
  width: 100%;
  height: auto;
  min-height: 47px;
  color: var(--color-blanco-movistar);
  background-color: var(--color-azul-movistar) !important;
}

.btn.btn-tomar-foto:hover {
  background-color: var(--color-azul-digital-claro-movistar) !important;
}

/* Estados Activos (Verde) */
.foto-frente.activo,
.foto-trasera.activo {
  color: var(--color-verde-movistar);
}

.btn.btn-tomar-foto.foto-frente.activo,
.btn.btn-tomar-foto.foto-trasera.activo {
  background-color: var(--color-verde-movistar) !important;
}

.boton-tomar-foto {
  width: 18%;
}

/* Botones Retake (Reintentar) */
.btn.btn-retake,
.btn.btn-retake-blue {
  height: 44px;
  width: 240px;
  min-width: 160px;
  max-width: 240px;
  margin-top: 15px;
  border-radius: 6px;
}

.btn.btn-retake {
  background-color: var(--color-blanco-movistar);
  border: 2px solid var(--color-azul-digital-movistar);
  color: var(--color-azul-digital-movistar);
}

.btn.btn-retake:hover {
  background-color: var(--color-azul-digital-claro-movistar);
  color: var(--color-blanco-movistar);
}

.btn.btn-retake-blue {
  background-color: var(--color-azul-digital-movistar);
  border: 1px solid var(--color-azul-digital-movistar);
  color: var(--color-blanco-movistar);
}

.btn.btn-retake-blue:hover {
  border: 1px solid var(--color-azul-digital-claro-movistar) !important;
}

/* Botón Continuar */
.btn.boton-continuar {
  background-color: var(--color-verde-movistar);
  color: var(--color-blanco-movistar);
  border-radius: 10px;
  padding: 10px 20px;
}

.btn.boton-continuar:hover {
  background-color: var(--color-verde-claro);
  color: var(--color-blanco-movistar);
}

.button-panel {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  -moz-column-gap: 6rem;
       column-gap: 6rem;
  row-gap: 0rem;
}

.action-footer {
  text-align: center;
  margin-top: 30px;
}

.btn.btn-frontal-foto {
  margin-top: 15px;
  padding: 12px 30px;
  border-radius: 6px;
}

/* CÁMARA, VIDEO Y CAPTURA */
.container-capture-photo,
.capture-photo {
  width: 100%;
}

.capture-photo {
  border-radius: 8px;
}

.container-capture-photo .capture-photo {
  padding: 75px 16px;
}

#capturePhotoBlock .text-subtitle2.text-photo {
  font-size: 30px;
}

.vista-frontal {
  border-width: 2px;
  border-radius: 8px !important;
  color: var(--color-gris-3-movistar);
}

.camera,
.img-preview-captura {
  position: relative;
  aspect-ratio: 85.6/53.98;
  border-radius: 8px;
}

.cont-vista-foto {
  max-width: 1000px;
}

#spinnerCamara,
#seccionErrorCamara {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

#seccionErrorCamara {
  display: flex;
  flex-direction: column;
}

#videoDocumentoFrontal,
#videoDocumentoPosterior {
  border-radius: 8px;
}

.vista-frontal.camera {
  color: var(--color-azul-movistar) !important;
  max-width: 700px;
  padding: 11px;
  line-height: 0;
}

/* Video y Canvas compartidos */
#videoFrontal,
#canvas {
  max-width: 520px;
  max-height: 346.67px;
  width: 100%;
  height: 100%;
}

.identidad-aprobada {
  margin-top: 100px;
}

.loadingMovistarAnimate svg {
  width: 200px;
}

/* GIF Spinner */
.gif-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 160px;
  width: 100%;
  padding: 0 20px 20px;
}

.centered-gif {
  width: 100%;
  max-width: 200px;
  height: auto;
}

/* CARDS DE CONFIRMACIÓN */
.confirmacion .review-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 700px;
}

.confirmacion .review-card {
  display: flex;
  border: 1px solid var(--color-gris-3-movistar);
  border-radius: 8px;
  padding: 1rem;
  gap: 1rem;
  box-shadow: 0px 0px 2px rgb(0 0 0/30%);
  height: 110px;
  align-items: center;
}

.confirmacion .card-left {
  display: flex;
  -moz-column-gap: 0.6rem;
       column-gap: 0.6rem;
  flex-wrap: wrap;
  align-items: center;
  flex: 1;
}

.confirmacion .file-icon {
  font-size: 2rem;
  color: var(--color-azul-movistar);
}

.confirmacion .file-info {
  display: flex;
  flex-direction: column;
}

.confirmacion .file-info p {
  font-size: 1rem;
  margin-bottom: 0;
}

.confirmacion .file-info span {
  font-size: 0.85rem;
  color: var(--color-gris-4-movistar);
}

.confirmacion .card-image img {
  border-radius: 12px;
  height: auto;
  min-height: 76px;
  min-width: 110px;
}

/* ESTILOS MARCO DE VIDEO (GLASS) */
.video-wrapper {
  position: relative;
  width: 100%;
  max-width: 682px;
  border-radius: 8px;
  overflow: hidden;
  margin: 0 auto;
  padding: 12px 0;
}

.video-element {
  display: block;
  width: 100%;
  height: 100%;
}

.glass-frame {
  position: absolute;
  inset: 0;
  z-index: 2;
  padding: 30px 35px;
  background: rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 8px;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
          mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}

/* MEDIA QUERIES (RESPONSIVO) */
/* Tablet Landscape & Small Desktop */
@media (max-width: 1199.98px) {
  .btn.btn-capturar-foto {
    width: 40%;
  }
}
/* Tablet Portrait */
@media (max-width: 991.98px) {
  .btn.btn-capturar-foto {
    width: 50%;
  }
  .vista-frontal.camera {
    width: 90%;
  }
  .boton-tomar-foto {
    width: 30%;
  }
  .text-recomendacion {
    max-width: 90%;
  }
}
/* Mobile Standard */
@media (max-width: 768px) {
  .section-subtitle {
    font-size: 0.9rem;
  }
  .confirmacion .review-list {
    width: 100%;
  }
  .confirmacion .card-image {
    display: flex;
    align-items: center;
  }
  .confirmacion .card-image img {
    max-width: 100%;
  }
  .confirmacion .btn-secondary {
    width: 110px;
    font-size: 10px;
  }
  .confirmacion .file-info p {
    font-size: 14px;
  }
  .btn.btn-capturar-foto {
    width: 80%;
  }
  .boton-tomar-foto {
    width: 100%;
  }
  .item-cargar-foto {
    margin-top: 10px;
  }
}
/* Mobile Small */
@media (max-width: 600px) {
  .main-title {
    font-size: 1.6rem;
  }
  .subtitle {
    font-size: 0.9rem;
  }
  .text-title {
    font-size: 2rem;
  }
  .text-subtitle {
    margin-top: 50px;
    font-size: 1.5rem;
  }
  .text-ul {
    font-size: 1rem;
  }
  .btn.btn-capturar-foto {
    width: 80%;
    height: auto;
    font-size: 1.5rem;
  }
  #capturePhotoBlock .text-subtitle2.text-photo {
    font-size: 25px;
  }
}
/* Mobile Tiny */
@media (max-width: 367px) {
  .btn.btn-capturar-foto {
    width: 100%;
    height: auto;
    font-size: 1.5rem;
  }
  #capturePhotoBlock .text-subtitle2.text-photo {
    font-size: 1.5rem;
  }
  .text-vista {
    font-size: 1rem;
  }
  .item-cargar-foto svg {
    width: 50px;
    height: 40px;
  }
  .btn.btn-retake,
  .btn.btn-retake-blue {
    width: 90%;
  }
}
/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .btn,
  .btn-primary,
  .confirmacion .btn-primary,
  .confirmacion .btn-secondary {
    transition: none;
  }
}

/*# sourceMappingURL=home-identidad.bundle.css.map*/