/* assets/css/lola-slot.css */
:root {
  --color-vip-gold: #d4af37;
  --color-vip-red: #b22222;
  --color-vip-black: #0a0a0a;
  --color-vip-white: #fffdf7;
}

body {
  background: url('../media/textures/red-carpet.jpg') center/cover fixed;
  color: var(--color-vip-white);
  font-family: 'Montserrat', 'Arial', sans-serif;
  min-height: 100vh;
  margin: 0;
  padding: 0;
  background-attachment: fixed;
}

/* Overlay de lujo */
body::before {
  content: '';
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: radial-gradient(circle at center, transparent 40%, rgba(0,0,0,0.7) 120%);
  z-index: -1;
}

/* Contenedor principal */
.slot-container {
  max-width: 500px;
  margin: 20px auto;
  padding: 25px;
  background: rgba(10, 10, 10, 0.85);
  border: 3px solid var(--color-vip-gold);
  border-radius: 20px;
  box-shadow: 
    0 0 20px rgba(212, 175, 55, 0.5),
    inset 0 0 15px rgba(0,0,0,0.8);
  position: relative;
  overflow: hidden;
}

/* Contenedor loggin */
.slot-container-login {
    position: absolute;
    left: 50%;
    top: 0;
    transform: translateX(-50%) translateY(-50%);
  max-width: 500px;
  margin: 20px auto;
  padding: 25px;
  background: rgba(10, 10, 10, 0.85);
  border: 3px solid var(--color-vip-gold);
  border-radius: 20px;
  box-shadow: 
    0 0 20px rgba(212, 175, 55, 0.5),
    inset 0 0 15px rgba(0,0,0,0.8);
  position: relative;
  overflow: hidden;
}

/* Brillo de borde */
.slot-container::after {
  content: '';
  position: absolute;
  top: -2px; left: -2px; right: -2px; bottom: -2px;
  border-radius: 22px;
  background: linear-gradient(45deg, 
    transparent, 
    var(--color-vip-gold), 
    transparent, 
    var(--color-vip-gold)
  );
  z-index: -1;
  animation: rotateBorder 3s linear infinite;
}

@keyframes rotateBorder {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Título */
.slot-title {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 800;
  margin-bottom: 20px;
  color: var(--color-vip-gold);
  text-shadow: 0 0 10px rgba(212, 175, 55, 0.7);
  letter-spacing: 1px;
}

/* Escáner */
#reader {
  width: 100%;
  height: 320px;
  background: rgba(0,0,0,0.6);
  border-radius: 12px;
  margin: 15px 0;
  position: relative;
  overflow: hidden;
}

/* Línea de escaneo (efecto slot) */
#reader::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(to right, transparent, var(--color-vip-gold), transparent);
  animation: scanLine 2s infinite;
}

@keyframes scanLine {
  0% { top: 0; }
  100% { top: 100%; }
}

/* Resultado con animación de "giro" */
.resultado {
  min-height: 180px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 20px;
  border-radius: 15px;
  margin-top: 15px;
  background: rgba(20, 20, 20, 0.7);
}

/* Animación de giro al mostrar resultado */
@keyframes spinIn {
  0% { transform: rotateY(0) scale(0.8); opacity: 0; }
  100% { transform: rotateY(360deg) scale(1); opacity: 1; }
}

.spin-result {
  animation: spinIn 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

/* Botones estilo casino */
.btn-slot {
  background: linear-gradient(to bottom, var(--color-vip-gold), #b8860b);
  color: var(--color-vip-black);
  font-weight: bold;
  border: none;
  padding: 12px 25px;
  font-size: 1.1rem;
  border-radius: 50px;
  box-shadow: 0 4px 0 #8b6914;
  transition: all 0.1s;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.btn-slot:hover {
  transform: translateY(2px);
  box-shadow: 0 2px 0 #8b6914;
}

.btn-slot:active {
  transform: translateY(4px);
  box-shadow: none;
}

/* Responsive */
@media (max-width: 500px) {
  .slot-container {
    margin: 10px;
    padding: 15px;
  }
  .slot-title {
    font-size: 1.5rem;
  }
}