/* --- FUENTES & BASES --- */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=VT323&family=Roboto:wght@400;700&display=swap');

:root {
    --neon-green: #0f0;
    --neon-pink: #f0f;
    --neon-cyan: #0ff;
    --neon-yellow: #ff0;
    --bg-color: #050505;
}

body {
    background-color: var(--bg-color);
    font-family: 'Roboto', sans-serif;
    color: white;
    height: 100dvh; 
    width: 100vw;
    overflow: hidden;
    position: fixed;
    touch-action: none;
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
    transition: background-color 0.3s ease, color 0.3s ease; /* Transición suave de tema */
}

/* --- TEMA LIGHT NEON (OVERRIDE) --- */
body.light-theme {
    --bg-color: #f3f4f6; /* Gris muy claro */
    background-color: var(--bg-color) !important;
    color: #111827 !important; /* Texto oscuro */
}

/* Forzar fondos blancos en modo Light */
body.light-theme #home-screen,
body.light-theme #create-screen,
body.light-theme #join-screen,
body.light-theme #waiting-screen,
body.light-theme #game-over-screen,
body.light-theme .neon-header,
body.light-theme #confirm-modal > div,
body.light-theme #vote-modal > div {
    background-color: #ffffff !important;
    background-image: none !important; /* Quitar patrones oscuros */
}

/* Ajustes de Texto y Bordes en Light Mode */
body.light-theme .neon-header {
    border-bottom: 2px solid var(--neon-cyan);
    box-shadow: 0 2px 10px rgba(0, 255, 255, 0.2);
}

body.light-theme h1, 
body.light-theme h2, 
body.light-theme h3 {
    text-shadow: none !important; /* Quitar glow excesivo en textos grandes */
}

/* Inputs en modo claro */
body.light-theme input {
    background-color: #f9fafb !important;
    color: #111 !important;
    border-bottom: 2px solid #ccc !important;
}

/* Cartas y Contenedores */
body.light-theme .toxic-card,
body.light-theme .flip-card-front {
    background-color: #ffffff !important;
    border: 2px solid #e5e7eb !important; /* Borde gris suave */
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1) !important;
}

/* Mantener neón en la carta activa pero más sutil */
body.light-theme .toxic-card {
    border-color: var(--neon-green) !important;
}

body.light-theme .toxic-header {
    background: #f3f4f6 !important;
    color: #111 !important;
    border-bottom: 1px solid #e5e7eb !important;
}

body.light-theme #challenge-header-title {
    color: #111 !important;
    text-shadow: none !important;
}

body.light-theme .card-instructions-area {
    background: #f9fafb !important;
    border-top: 1px solid #e5e7eb !important;
}
body.light-theme .card-instructions-area p {
    color: #374151 !important;
}

/* Scorebox Light */
body.light-theme .score-box,
body.light-theme .score-pill,
body.light-theme #timer-display {
    background: #ffffff !important;
    color: #111 !important;
    border-color: #111 !important;
    box-shadow: none !important; /* Estilo más limpio */
}

/* Botones Acción */
body.light-theme .btn-action-bar {
    background: #ffffff !important;
    color: #111 !important;
    border-color: #111 !important;
    box-shadow: 0 -5px 20px rgba(0,0,0,0.1) !important;
}

/* Excepciones de texto blanco (Botones solidos) */
body.light-theme button.bg-pink-600,
body.light-theme button.bg-green-600 {
    color: white !important;
}

/* --- FIN TEMA LIGHT --- */


/* --- CONTENEDOR PRINCIPAL --- */
#main-game-area {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-start; 
    /* Reducimos el padding superior ya que el header es más chico */
    padding: 60px 15px 100px 15px !important; 
    gap: 0.5rem; /* Menos espacio entre elementos */
    overflow-y: auto; 
    height: 100%;
}

/* --- TIPOGRAFÍA --- */
.font-digital { font-family: 'VT323', monospace; } 
.font-tech { font-family: 'Orbitron', sans-serif; } 

/* --- HEADER (Compacto) --- */
.neon-header {
    background: #000;
    border-bottom: 2px solid var(--neon-cyan);
    box-shadow: 0 0 10px var(--neon-cyan); /* Menos glow */
    z-index: 50;
    padding: 0.5rem 1rem; /* Padding reducido */
    padding-top: max(0.5rem, env(safe-area-inset-top));
    height: auto;
    transition: background 0.3s;
}

#room-display {
    color: var(--neon-green);
    text-shadow: 0 0 5px var(--neon-green);
    /* CAMBIO UX: Usamos Orbitron en lugar de VT323 para consistencia */
    font-family: 'Orbitron', sans-serif;
    font-weight: 700;
    font-size: 1rem; /* Ajustado ligeramente porque Orbitron es más ancha */
    letter-spacing: 2px;
}

#my-team-display {
    color: var(--neon-pink);
    border: 1px solid var(--neon-pink);
    box-shadow: 0 0 5px var(--neon-pink), inset 0 0 5px var(--neon-pink);
    padding: 2px 6px;
    border-radius: 4px;
    font-family: 'Orbitron', sans-serif;
    font-size: 0.6rem; /* Achicado */
}

/* --- SCOREBOARD (REDDISEÑADO) --- */
.score-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 5px; 
    gap: 10px; /* Espacio entre cajas */
    flex-shrink: 0; 
}

/* CAMBIO DISEÑO: .score-box ahora imita a .score-pill (recuadrado) */
.score-box { 
    flex: 1;
    background: #000;
    border: 2px solid; /* Color definido por ID abajo */
    padding: 5px;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    transition: background 0.3s;
}

.score-box h2 {
    font-family: 'Orbitron', sans-serif; 
    font-size: 0.6rem; 
    /* Quitamos el stroke anterior para que se vea limpio dentro de la caja */
    margin-bottom: 0; 
    letter-spacing: 1px;
    opacity: 0.9;
}

.score-num {
    /* CAMBIO UX: Usamos Orbitron en lugar de VT323 */
    font-family: 'Orbitron', sans-serif;
    font-size: 1.8rem; /* Ajustado: Orbitron es más grande y ancha que VT323 */
    line-height: 1; 
    text-shadow: 0 0 10px currentColor;
    font-weight: 900; /* Extra bold para impacto numérico */
}

/* Estilos Específicos por Equipo (Colores de borde y sombra) */
#team-renos { 
    border-color: white; 
    color: white;
    box-shadow: 0 0 5px white; 
}

#team-grinch { 
    border-color: var(--neon-cyan); 
    color: var(--neon-cyan);
    box-shadow: 0 0 5px var(--neon-cyan);
}

.vs-section { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 50px; }
.vs-text { font-family: 'Orbitron', sans-serif; font-weight: 900; color: var(--neon-yellow); text-shadow: 1px 1px 0 #ff0000; font-size: 1rem; margin-bottom: 2px; }

#timer-display { 
    background: #000; 
    color: var(--neon-yellow); 
    border: 1px solid var(--neon-yellow); 
    box-shadow: 0 0 5px var(--neon-yellow); 
    /* CAMBIO UX: Timer también en Orbitron para consistencia total */
    font-family: 'Orbitron', sans-serif; 
    font-weight: 700;
    font-size: 0.9rem; /* Ajuste de tamaño */
    padding: 2px 6px; 
    border-radius: 4px; 
}

/* --- CONTENEDOR DE CARTA --- */
.phone-card-container {
    flex-grow: 1;
    display: flex;
    flex-direction: column; 
    justify-content: flex-start; 
    align-items: center;
    width: 100%;
    min-height: 0; 
    gap: 10px; 
}

/* --- FLIP CARD LOGIC (NUEVO) --- */
.flip-card-scene {
    width: 85%; /* Mismo ancho que la carta original */
    flex-grow: 1;
    min-height: 300px;
    max-height: 100%;
    margin: 0 auto;
    perspective: 1000px; /* Crea el entorno 3D */
}

.flip-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    text-align: center;
    transition: transform 0.8s;
    transform-style: preserve-3d;
}

/* Clase que se añade con JS para girar */
.flip-card-inner.is-flipped {
    transform: rotateY(180deg);
}

/* UX IMPROVEMENT: Cuando la carta está girada, ocultamos la TAPA para evitar transparencias */
.flip-card-inner.is-flipped .flip-card-front {
    pointer-events: none; /* Evitar clics fantasmas */
    opacity: 0; /* Desaparece visualmente */
    transition: opacity 0s 0.4s; /* Esperar medio giro (0.4s) antes de ocultar */
}

/* Caras de la carta */
.flip-card-front, .flip-card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden; /* Oculta la parte de atrás al girar */
    border-radius: 15px; /* Mismo radio que .toxic-card */
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* CARA FRONTAL (TAPA - BOCA ABAJO) */
.flip-card-front {
    background-color: #050505;
    border: 2px solid #333;
    box-shadow: 0 0 20px rgba(0,255,255,0.1), inset 0 0 50px rgba(0,0,0,0.8);
    color: white;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    background-image: radial-gradient(circle at center, #111 0%, #000 100%);
}

.cover-content {
    z-index: 10;
    padding: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* CARA TRASERA (CONTENIDO REVELADO) */
.flip-card-back {
    transform: rotateY(180deg);
}

/* Reutilizamos .toxic-card pero aseguramos que llene el espacio */
.toxic-card {
    /* Eliminamos el width fijo porque ahora lo maneja el padre flip-card-scene */
    width: 100%; 
    height: 100%;
    /* UX CHANGE: Fondo SÓLIDO (#050505) en lugar de transparente para que no se vea la tapa de fondo */
    background-color: #050505; 
    border: 2px solid var(--neon-green);
    box-shadow: 0 0 15px var(--neon-green), inset 0 0 30px rgba(0, 255, 0, 0.1);
    display: flex;
    flex-direction: column;
    position: relative;
    margin: 0;
}

/* Header Carta */
.toxic-header {
    text-align: center;
    margin-bottom: 0;
    border-bottom: 1px solid rgba(255,255,255,0.2);
    padding: 0.6rem;
    flex-shrink: 0;
}
#challenge-header-title {
    font-family: 'Orbitron', sans-serif; font-weight: 700; color: white; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 1px;
}

/* Contenido Carta */
.toxic-content {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0.8rem;
    gap: 0.8rem;
    overflow-y: auto; 
}

/* Ajuste de iconos internos */
.toxic-content .fa-brands, .toxic-content .fa-solid {
    font-size: 2.5rem; color: #000; -webkit-text-stroke: 2px var(--neon-green); filter: drop-shadow(0 0 5px var(--neon-green));
}
.toxic-content #icon-2 { -webkit-text-stroke: 2px var(--neon-cyan); filter: drop-shadow(0 0 5px var(--neon-cyan)); }

.bubble-neon {
    background: rgba(0, 255, 0, 0.1); border: 1px solid var(--neon-green); color: white; padding: 12px; border-radius: 10px; font-family: 'Roboto', sans-serif; font-size: 1rem; text-align: center; position: relative; box-shadow: 0 0 10px rgba(0,255,0,0.1); width: 100%;
}
.bubble-neon::after {
    content: ''; position: absolute; bottom: -8px; left: 50%; transform: translateX(-50%); border-width: 8px 8px 0; border-style: solid; border-color: var(--neon-green) transparent transparent transparent;
}

/* NUEVA AREA DE INSTRUCCIONES (FOOTER DE CARTA) */
.card-instructions-area {
    background: rgba(255, 255, 255, 0.05);
    border-top: 1px solid rgba(255,255,255,0.2);
    padding: 0.8rem;
    text-align: center;
    flex-shrink: 0; 
}

.card-instructions-area p {
    font-size: 0.8rem; /* Texto de instrucciones un poco más chico */
    color: #ccc;
    font-family: 'Orbitron', sans-serif;
    line-height: 1.3;
    margin: 0;
}

/* CONTENEDOR DE PUNTAJE EXTERNO (Alineado con el ancho de la carta) */
.scoring-external-container {
    width: 85%; /* Mismo ancho que la carta */
    display: flex;
    gap: 10px;
    flex-shrink: 0;
    margin-bottom: 5px;
    margin-left: auto;
    margin-right: auto;
}

.score-pill {
    flex: 1;
    background: #000;
    border: 2px solid;
    padding: 5px; /* Padding reducido */
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
    font-family: 'Orbitron', sans-serif;
}

.score-lose {
    border-color: var(--neon-pink);
    color: var(--neon-pink);
    box-shadow: 0 0 5px var(--neon-pink);
}

.score-win {
    border-color: var(--neon-green);
    color: var(--neon-green);
    box-shadow: 0 0 5px var(--neon-green);
}

.score-pill .label { font-size: 0.6rem; opacity: 0.8; margin-bottom: 0px; }
.score-pill .val { font-size: 1.1rem; font-weight: bold; line-height: 1; }


/* --- BOTÓN DE ACCIÓN PRINCIPAL (Ajustado) --- */
.btn-action-bar {
    position: fixed; 
    bottom: max(15px, env(safe-area-inset-bottom) + 5px); 
    left: 50%; transform: translateX(-50%);
    width: 85%; /* Mismo ancho que la carta */
    max-width: 400px;
    background: #000;
    color: white;
    border: 2px solid white;
    padding: 12px; /* Menos padding */
    font-family: 'Orbitron', sans-serif;
    font-weight: 900;
    font-size: 1rem; /* Letra un poco más chica */
    text-transform: uppercase;
    box-shadow: 0 0 10px white;
    border-radius: 8px;
    z-index: 100;
    background-color: rgba(0,0,0,0.95);
}
.btn-action-bar.waiting { border-color: var(--neon-yellow); color: var(--neon-yellow); box-shadow: 0 0 10px var(--neon-yellow); }
.btn-action-bar.playing { border-color: var(--neon-pink); color: var(--neon-pink); box-shadow: 0 0 10px var(--neon-pink); }

/* --- UTILS --- */
.hidden { display: none !important; }