/* Estilos específicos para la página de desafío de reconocimiento */

.desafio-container {
    text-align: center;
    max-width: 800px; /* Limitar ancho máximo */
    margin: 0 auto; /* Centrar */
    padding: 1rem; /* Espacio interno */
}

.consigna-container {
    margin-bottom: 2rem;
}

.consigna-display {
    font-size: 2.5rem;
    font-weight: bold;
    color: var(--color-primary);
    padding: 1rem;
    background-color: var(--color-light);
    border-radius: var(--border-radius);
    display: inline-block;
    min-width: 100px;
    box-shadow: var(--shadow);
}

/* --- NUEVO: Estilo para el contenedor de las cámaras --- */
.camara-container {
    margin: 1.5rem 0;
    display: flex; /* Activa el layout flexible */
    justify-content: center; /* Centra horizontalmente los elementos hijos si no llenan todo el ancho */
    align-items: flex-start; /* Alinea los elementos hijos al principio verticalmente (puedes usar 'center' también) */
    gap: 1rem; /* Espacio entre el video y el canvas */
    flex-wrap: wrap; /* Permite que los elementos se envuelvan si el contenedor es muy angosto */
    width: 100%; /* Asegura que el contenedor ocupe el ancho disponible */
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); /* Degradado de ejemplo */
}

/* Opcional: Si decides envolver video y canvas en divs separados */
.camara-container .video-wrapper,
.camara-container .canvas-wrapper {
    flex: 1; /* Hace que ambos divs crezcan y ocupen espacio equitativamente */
    min-width: 300px; /* Ancho mínimo para cada vista, ajusta según necesites */
    max-width: 50%; /* Ancho máximo para evitar que uno se vuelva demasiado grande */
    text-align: center; /* Centra el contenido dentro de cada div (video/canvas) */
}

/* Aplica estilos comunes a video y canvas */
.camara-container video,
.camara-container canvas {
    width: 100%; /* Hace que el video/canvas se ajuste al ancho de su contenedor padre inmediato */
    max-width: 500px; /* Limita el ancho máximo de cada elemento */
    border-radius: var(--border-radius);
    box-shadow: var(--shadow);
    display: block; /* Asegura que no haya espacios extra debajo del elemento */
}
/* --- FIN NUEVO --- */


.resultado-container {
    margin: 1.5rem 0;
}

.mensaje-result {
    font-size: 1.5rem;
    font-weight: bold;
    padding: 0.5rem;
    border-radius: var(--border-radius);
    margin-bottom: 0.5rem;
}

.mensaje-result.correcto {
    background-color: #e8f5e9;
    color: #2e7d32;
}

.mensaje-result.incorrecto {
    background-color: #ffebee;
    color: #c62828;
}

.senal-reconocida {
    margin-top: 0.5rem;
    font-style: italic;
    color: #555;
    font-size: 1.1rem;
}

.controles-container {
    margin: 1.5rem 0;
}

.puntuacion-container {
    margin-top: 1.5rem;
    padding: 1rem;
    background-color: var(--color-white);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow);
    text-align: center;
}

.puntuacion-container p {
    margin: 0.25rem 0; /* Espacio entre líneas */
    font-size: 1.1rem;
}

/* --- RESPONSIVE: En pantallas pequeñas, vuelve a vertical --- */
@media (max-width: 768px) {
    .camara-container {
        display: block; /* Cambia a bloque para que se apilen verticalmente */
    }

    .camara-container video,
    .camara-container canvas {
        max-width: 100%; /* Asegura que se ajusten al ancho del contenedor móvil */
        margin: 0 auto 1rem auto; /* Centra y agrega margen inferior */
        display: block;
    }

    .consigna-display {
        font-size: 2rem; /* Reducir tamaño de texto en móvil */
    }
    .mensaje-result {
        font-size: 1.2rem; /* Reducir tamaño de texto en móvil */
    }
    .senal-reconocida {
        font-size: 1rem; /* Reducir tamaño de texto en móvil */
    }
}