/* ==========================================================================
   CSS ESPECÍFICO DO JOGO (Complementa o style.css)
   ========================================================================== */

[v-cloak] { display: none; }

body {
    /* Garante a cor de fundo padrão */
    background-color: var(--bg-dark);
    
    /* Aplica a exata nuance azul (radial gradient) do topo do seu blog */
    background-image: radial-gradient(circle at 50% 0%, rgba(62, 142, 255, 0.15), transparent 60%);
    background-repeat: no-repeat;
    
    /* Fixa o brilho no topo, mesmo se a página rolar */
    background-attachment: fixed; 
}

/* Sobrescreve o botão branco do Menu para deixá-ado minimalista nesta página */
.override-btn {
    background-color: transparent !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border-color);
}
.override-btn:hover {
    border-color: var(--accent-blue);
    color: var(--accent-blue) !important;
}

/* Container que empurra o jogo para baixo do Menu Fixo */
.game-container-wrapper {
    padding-top: 130px; 
    padding-bottom: 50px;
    max-width: 800px;
    margin: 0 auto;
    width: 90%;
    display: flex;
    flex-direction: column;
}

/* HEADER DO JOGO */
.game-header {
    background-color: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    padding: 30px;
    margin-bottom: 30px;
    /* Efeito de hover idêntico aos cards da página inicial */
    transition: all 0.3s ease;
}

.game-header:hover {
    border-color: var(--accent-blue);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
}

/* Estatísticas do Header */
.stats-area { display: flex; gap: 30px; }
.stat-item { display: flex; flex-direction: column; align-items: flex-end; }
.stat-item .label { font-size: 11px; color: var(--text-secondary); text-transform: uppercase; font-weight: 500; letter-spacing: 1px; }
.stat-item .value { font-size: 24px; font-weight: 700; font-family: 'Courier New', monospace; color: var(--text-primary); }
.stat-item .value.highlight { color: var(--accent-blue); }

.progress-container {
    height: 4px;
    background: rgba(255,255,255,0.05);
    border-radius: 4px;
    overflow: hidden;
}
.progress-bar {
    height: 100%;
    background: var(--accent-blue);
    transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ==========================================================================
   ÁREA DO PUZZLE E PEÇAS
   ========================================================================== */
.puzzle-area {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.scenario-context { text-align: center; margin-bottom: 10px; }
.scenario-context h3 { color: var(--accent-blue); margin-bottom: 10px; font-size: 13px; text-transform: uppercase; letter-spacing: 1px; font-weight: 700; }
.scenario-context .scenario-desc { font-size: 18px; font-weight: 500; color: var(--text-primary); max-width: 90%; margin: 0 auto; line-height: 1.4; }
.scenario-context .instruction { font-size: 14px; color: var(--text-secondary); margin-top: 15px; }

.drag-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    position: relative;
    padding-bottom: 10px;
}

/* PEÇAS DO PUZZLE (Estilo Card Minimalista) */
.puzzle-piece {
    background-color: transparent;
    border: 1px solid var(--border-color);
    padding: 16px 20px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 16px;
    cursor: grab;
    transition: transform 0.2s, border-color 0.2s, background-color 0.2s;
    user-select: none;
}

.puzzle-piece:hover:not(.frozen) {
    background-color: rgba(255, 255, 255, 0.02);
    border-color: rgba(255, 255, 255, 0.2);
}

.puzzle-piece:active { cursor: grabbing; }

.puzzle-piece.dragging {
    opacity: 0.3;
    background: transparent;
    border: 1px dashed var(--accent-blue);
}

.puzzle-piece.drag-over {
    border: 1px solid var(--accent-blue);
    transform: scale(1.01);
    z-index: 10;
    background-color: rgba(62, 142, 255, 0.05);
}

.puzzle-piece.frozen { cursor: default; }

.grip { color: var(--text-secondary); opacity: 0.3; font-size: 20px; display: flex; }
.text { font-family: 'Courier New', monospace; font-weight: 400; font-size: 14px; flex-grow: 1; color: var(--text-primary); line-height: 1.5; }

/* Feedback Visual (Apenas borda colorida e leve fundo translúcido para manter o minimalismo) */
.puzzle-piece.correct { border-color: #10B981; background: rgba(16, 185, 129, 0.02); }
.puzzle-piece.wrong { border-color: #EF4444; background: rgba(239, 68, 68, 0.02); }

.status-icon { font-size: 18px; }
.puzzle-piece.correct .status-icon { color: #10B981; }
.puzzle-piece.wrong .status-icon { color: #EF4444; }

.flip-list-move { transition: transform 0.4s ease; }

/* ==========================================================================
   BOTÕES GHOST MINIMALISTAS
   ========================================================================== */
.controls { display: flex; justify-content: center; gap: 15px; margin-top: 15px; }

.btn-minimalist {
    background-color: transparent;
    color: var(--text-secondary);
    border: 1px solid var(--border-color);
    padding: 12px 28px;
    border-radius: 12px;
    font-weight: 500;
    cursor: pointer;
    font-family: 'Satoshi', sans-serif;
    transition: all 0.3s ease;
    font-size: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.btn-minimalist:hover {
    border-color: var(--accent-blue);
    color: var(--accent-blue);
    background-color: rgba(62, 142, 255, 0.03);
}

.chances-text {
    margin-left: 5px; 
    opacity: 0.6; 
    font-size: 11px;
    text-transform: none;
    letter-spacing: 0;
}

/* ==========================================================================
   FEEDBACK MENSAGENS E TELA FINAL
   ========================================================================== */
.feedback-msg { 
    text-align: center; 
    font-weight: 400; 
    padding: 16px; 
    border-radius: 12px; 
    font-size: 14px;
    animation: fadeIn 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 10px;
    border: 1px solid var(--border-color);
    background-color: transparent;
}
.feedback-msg.success { color: #10B981; border-color: rgba(16, 185, 129, 0.3); }
.feedback-msg.error { color: #EF4444; border-color: rgba(239, 68, 68, 0.3); }

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.end-screen {
    text-align: center;
    padding: 60px 30px;
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.trophy-icon { font-size: 50px; color: var(--accent-blue); margin-bottom: 20px; }
.end-screen h2 { font-size: 28px; color: var(--text-primary); margin-bottom: 15px;}
.end-screen p { color: var(--text-secondary); max-width: 400px; margin-bottom: 40px; font-size: 15px; }
.final-actions { display: flex; gap: 15px; }

/* FAB EXPORT (Botão flutuante de download) */
.fab-export {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    padding: 0;
    font-size: 20px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    z-index: 100;
    cursor: pointer;
    transition: all 0.3s ease;
}
.fab-export:hover { 
    border-color: var(--accent-blue);
    color: var(--accent-blue); 
    transform: translateY(-5px);
}

/* ==========================================================================
   RESPONSIVIDADE (MOBILE)
   ========================================================================== */
@media (max-width: 768px) {
    .game-container-wrapper {
        padding-top: 100px; /* Reduz espaço em telas menores */
    }
    
    .game-header { 
        padding: 20px; 
    }
    
    .header-content {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }
    
    .stats-area {
        width: 100%;
        justify-content: flex-start;
        gap: 25px;
    }
    
    .stat-item {
        align-items: flex-start;
    }

    .section-title { font-size: 22px; }
    
    .text { font-size: 13px; line-height: 1.4; }
    .puzzle-piece { padding: 14px; gap: 12px; }
    
    .controls { flex-direction: column; gap: 10px; }
    .btn-minimalist { width: 100%; }
    
    .final-actions { flex-direction: column; width: 100%; }
}

/* Animação de erro */
@keyframes shake {
    0%, 100% { transform: translateX(0); }
    20%, 60% { transform: translateX(-6px); }
    40%, 80% { transform: translateX(6px); }
}

.shake-animation {
    animation: shake 0.4s cubic-bezier(.36,.07,.19,.97) both;
    border-color: #EF4444 !important; 
}