/* virtual-keyboard.css */
.virtual-keyboard {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: rgba(0, 0, 0, 0.9);
  z-index: 10000;
  padding: 10px;
  box-sizing: border-box;
}

/* Estilos para navegação por foco */
[data-focused] {
  outline: 3px solid #58c119;
  transform: scale(1.05);
  transition: transform 0.2s ease;
}

/* Estilos para SPA */
main section {
  transition: opacity 0.3s ease;
}

/* Media queries para TV */
@media (orientation: landscape) and (min-width: 1200px) {
  /* Ajustes específicos para TV */
  body {
    font-size: 1.2em;
  }
  
  .swiper-slide {
    min-width: 300px;
  }
}