:root {
  --modal-w: 20rem;
  --modal-h: calc((var(--modal-w)/2));
}

.modal-idioma {
  align-items: center;
  background-color: rgba(255,221,174,0.25);
  border-radius: 1rem;
  display: flex;
  flex-direction: column;
  height: var(--modal-h);
  justify-content: center;
  padding: 1rem;
  position: absolute;
  width: var(--modal-w);
  transform: translateX(calc(50vw - var(--modal-w) / 2)) translateY(calc(50vh - var(--modal-h) / 2));
  z-index: 100;
  animation: modalFadeIn 0.45s cubic-bezier(0.34,1.56,0.64,1) forwards;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.backdrop {
  animation: backdropIn 0.35s ease forwards;
  transition: opacity 0.3s ease;
}

@keyframes modalFadeIn {
  from {
    opacity: 0;
    transform: translateX(calc(50vw - var(--modal-w) / 2))
               translateY(calc(50vh - var(--modal-h) / 2))
               scale(0.88);
  }
  to {
    opacity: 1;
    transform: translateX(calc(50vw - var(--modal-w) / 2))
               translateY(calc(50vh - var(--modal-h) / 2))
               scale(1);
  }
}

@keyframes backdropIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.modal-idioma .selector {
  cursor: pointer;
  display: inline-block;
}

.modal-idioma.oculto {
  display: none;
}

.backdrop {
  position: fixed;
  z-index: 90;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.3);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
}

/* E6 – Clase .closing para animación de cierre del modal */
.modal-idioma.closing {
  opacity: 0 !important;
  transform: translateX(calc(50vw - var(--modal-w) / 2))
             translateY(calc(50vh - var(--modal-h) / 2))
             scale(0.88) !important;
}
.backdrop.closing {
  opacity: 0 !important;
}

/* S8 – Shake del modal al hacer click en el backdrop */
@keyframes modalShake {
  0%, 100% { transform: translateX(calc(50vw - var(--modal-w) / 2)) translateY(calc(50vh - var(--modal-h) / 2)) rotate(0deg); }
  20%       { transform: translateX(calc(50vw - var(--modal-w) / 2 - 6px)) translateY(calc(50vh - var(--modal-h) / 2)) rotate(-1.5deg); }
  40%       { transform: translateX(calc(50vw - var(--modal-w) / 2 + 6px)) translateY(calc(50vh - var(--modal-h) / 2)) rotate(1.5deg); }
  60%       { transform: translateX(calc(50vw - var(--modal-w) / 2 - 4px)) translateY(calc(50vh - var(--modal-h) / 2)) rotate(-1deg); }
  80%       { transform: translateX(calc(50vw - var(--modal-w) / 2 + 4px)) translateY(calc(50vh - var(--modal-h) / 2)) rotate(0.5deg); }
}
.modal-idioma.shake {
  animation: modalShake 0.42s ease;
}

/* # sourceMappingURL=entrada.css.map */