/* ================================================================== */
/* === ARQUIVO DE ESTILO - FERRAMENTA MAPA DOS VALORES            === */
/* ================================================================== */

/* ================================================================== */
/* === ETAPA 1: SELEÇÃO DE VALORES E FORMULÁRIO DE ADIÇÃO         === */
/* ================================================================== */

#values-list-container {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    margin-top: 20px;
}

.value-card {
    background-color: #fff;
    border: 2px solid var(--border-color);
    border-radius: 20px;
    padding: 8px 16px;
    cursor: pointer;
    font-weight: 600;
    color: var(--secondary-color);
    transition: all 0.2s ease-in-out;
    user-select: none;
}

.value-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
}

.value-card.selected {
    background-color: var(--primary-color);
    color: #fff;
    border-color: var(--primary-color);
}

.add-value-form {
    display: flex;
    gap: 10px; /* --- AJUSTE --- Aumenta o espaçamento. */
    align-items: stretch; /* --- AJUSTE --- Faz o botão e o input terem a mesma altura. */
    margin-top: 30px;
    /* --- AJUSTE --- Ocupa 100% da largura no mobile por padrão. */
    width: 100%; 
    max-width: 100%;
}

.add-value-form input[type="text"] {
    flex-grow: 1;
    margin-top: 0;
    padding: 10px 12px; /* --- AJUSTE --- Aumenta o padding para melhor toque. */
    font-size: 1rem; /* --- AJUSTE --- Tamanho de fonte padrão para legibilidade. */
}

.add-value-form button {
    padding: 10px 15px;
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    background-color: var(--secondary-color);
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.2s;
    flex-shrink: 0;
}

.add-value-form button:hover {
    background-color: var(--primary-color);
}

/* ================================================================== */
/* === ETAPA 2: PRIORIZAÇÃO (DRAG AND DROP)                       === */
/* ================================================================== */

.prioritization-container {
    display: flex;
    /* --- AJUSTE --- Quebra as colunas em telas pequenas. */
    flex-direction: column; 
    gap: 30px;
    margin-top: 20px;
}

.column {
    flex: 1;
    background-color: #f9f9f9;
    padding: 15px;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    min-height: 200px; /* --- AJUSTE --- Reduz a altura mínima para mobile. */
}

.column h3 {
    text-align: center;
    margin-top: 0;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
}

#selected-values-pool .value-card,
#top-5-list .value-card {
    display: block;
    margin-bottom: 10px;
    text-align: center;
    cursor: grab;
}

#selected-values-pool .value-card:active,
#top-5-list .value-card:active {
    cursor: grabbing;
}

.drop-zone {
    position: relative;
    background-color: #efefef;
    border: 2px dashed #ccc;
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 10px;
    text-align: center;
    min-height: 50px;
}

.drop-zone::before {
    content: attr(data-placeholder);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #aaa;
    font-style: italic;
    font-size: 14px;
    width: 90%; /* --- AJUSTE --- Garante que o texto do placeholder não transborde. */
}

.drop-zone:has(.value-card) {
    border-style: solid;
    border-color: var(--border-color);
}

.drop-zone:has(.value-card)::before {
    display: none;
}

/* ================================================================== */
/* === ETAPA 3 & 4: DEFINIÇÃO E LUZ/SOMBRA                        === */
/* ================================================================== */

.definition-group, .duality-group {
    margin-bottom: 25px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 20px;
}

.definition-group label, .duality-group h4, .duality-group label {
    display: block;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 8px;
    line-height: 1.4; /* Melhora a legibilidade. */
}

.duality-group h4 {
    font-size: clamp(1.25rem, 5vw, 1.5rem);
    padding-bottom: 15px;
    border-bottom: 1px solid var(--border-color);
    margin-top: 0;
    margin-bottom: 20px;
}

.duality-group label {
    font-size: 1rem;
    font-weight: 600;
}

.duality-group .form-group:first-of-type {
    margin-bottom: 25px;
}

.example-box {
    background-color: #fffbe6;
    border: 1px solid #ffe58f;
    border-radius: 8px;
    padding: 15px 20px;
    margin: 25px 0;
    font-size: 15px;
}
.example-box p { margin-top: 0; }
.example-box ul { padding-left: 20px; margin-bottom: 0; }
.example-box li { margin-bottom: 10px; }

/* ================================================================== */
/* === ETAPA 5: CONFRONTO DE PARES                                === */
/* ================================================================== */

#confrontation-counter {
    text-align: center;
    font-size: 1em;
    color: #888;
    margin-bottom: 15px;
}

.confrontation-box {
    display: flex;
    /* --- AJUSTE --- Quebra os botões em coluna no mobile. */
    flex-direction: column; 
    align-items: stretch;
    gap: 15px;
    margin: 30px 0;
}

.confrontation-box button {
    flex: 1;
    padding: 15px; /* --- AJUSTE --- Padding um pouco menor para mobile. */
    font-size: clamp(1rem, 4vw, 1.2rem); /* --- AJUSTE --- Fonte responsiva. */
    font-weight: 700;
    color: var(--primary-color);
    background-color: #fff;
    border: 2px solid var(--border-color);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    min-height: 80px;
}

.confrontation-box button:hover {
    transform: translateY(-3px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    border-color: var(--accent-color);
}

.confrontation-box span {
    font-size: 1.2em;
    font-weight: 700;
    color: #aaa;
    align-self: center;
    /* --- AJUSTE --- Rotaciona o "vs" para economizar espaço vertical. */
    transform: rotate(90deg);
    margin: 10px 0;
}

.confrontation-box button .scenario {
    display: block;
    font-size: 0.8em;
    font-weight: 400;
    color: #555;
    margin-top: 8px;
    line-height: 1.4;
    white-space: normal;
}

/* ================================================================== */
/* === MEDIA QUERIES PARA AJUSTES EM DESKTOP                      === */
/* ================================================================== */

/* As regras abaixo só se aplicam em telas maiores que 768px. */
@media (min-width: 768px) {
    
    /* Devolve o layout de 2 colunas para o drag-and-drop. */
    .prioritization-container {
        flex-direction: row;
    }

    /* Devolve o layout de 2 colunas para o confronto de pares. */
    .confrontation-box {
        flex-direction: row;
    }

    /* Restaura a rotação do "vs". */
    .confrontation-box span {
        transform: rotate(0deg);
    }

    /* Devolve o layout do formulário de adicionar valor. */
    .add-value-form {
        max-width: 50%;
        margin-left: auto;
    }
}
