/* Mobile First - Estilos responsivos para o gráfico */

/* Estilos base para mobile */
.chart-section {
    margin: 20px -10px 0 -10px !important;
    padding: 15px !important;
    background: #f9f9f9 !important;
    border-radius: 8px 8px 0 0 !important;
    box-shadow: none !important;
    text-align: center !important;
}

.chart-section h4 {
    margin-bottom: 15px !important;
    color: #1976d2 !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
}

.chart-container {
    position: relative !important;
    width: 100% !important;
    min-height: 260px !important; /* Altura mínima fixa */
    aspect-ratio: 1 !important; /* Proporção quadrada fixa */
    margin: 0 auto !important;
    padding: 5px !important;
    contain: layout !important; /* Contenção de layout */
    transform: translateZ(0) !important; /* Força camada de composição */
}

.chart-help {
    margin-top: 10px !important;
    margin-bottom: 0 !important;
    font-size: 12px !important;
    color: #666 !important;
    font-style: italic !important;
}

/* Unificação visual dos resultados - CLS otimizado */
.result-container {
    background: #f9f9f9 !important;
    border-radius: 8px !important;
    margin: 20px -10px !important;
    padding: 0 !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1) !important;
    min-height: 600px !important; /* Altura mínima fixa para evitar CLS */
    contain: layout !important;
    transform: translateZ(0) !important;
}

.result-container h3 {
    margin: 0 0 20px 0 !important;
    padding: 15px 15px 0 15px !important;
    color: #1976d2 !important;
    font-size: 20px !important;
}

.result-grid {
    background: #fff !important;
    margin: 0 15px !important;
    border-radius: 6px !important;
    padding: 15px !important;
}

#goals-content {
    background: #fff !important;
    margin: 0 15px !important;
    border-radius: 6px !important;
    padding: 15px !important;
    margin-bottom: 15px !important;
}

/* Tablet */
@media (min-width: 480px) {
    .chart-section {
        margin: 25px -5px 0 -5px !important;
        padding: 18px !important;
        border-radius: 10px 10px 0 0 !important;
    }

    .chart-section h4 {
        font-size: 17px !important;
    }

    .chart-container {
        width: 100% !important;
        max-width: 280px !important;
        min-height: 280px !important; /* Altura fixa para tablet */
        aspect-ratio: 1 !important;
        padding: 8px !important;
        contain: layout !important;
        transform: translateZ(0) !important;
    }

    .chart-help {
        font-size: 13px !important;
        margin-top: 12px !important;
    }

    .result-container {
        margin: 25px -5px !important;
        border-radius: 10px !important;
    }

    .result-container h3 {
        padding: 18px 18px 0 18px !important;
        font-size: 21px !important;
    }

    .result-grid, #goals-content {
        margin: 0 18px !important;
        padding: 18px !important;
    }

    #goals-content {
        margin-bottom: 18px !important;
    }
}

/* Desktop */
@media (min-width: 768px) {
    .chart-section {
        margin: 30px 0 0 0 !important;
        padding: 20px !important;
        border-radius: 12px 12px 0 0 !important;
        box-shadow: none !important;
    }

    .chart-section h4 {
        margin-bottom: 20px !important;
        font-size: 18px !important;
    }

    .chart-container {
        max-width: 400px !important;
        padding: 10px !important;
    }

    .chart-help {
        margin-top: 15px !important;
        font-size: 14px !important;
    }

    .result-container {
        margin: 30px auto !important;
        border-radius: 12px !important;
        box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    }

    .result-container h3 {
        padding: 20px 20px 0 20px !important;
        font-size: 22px !important;
    }

    .result-grid, #goals-content {
        margin: 0 20px !important;
        padding: 20px !important;
    }

    #goals-content {
        margin-bottom: 20px !important;
    }
}

/* Extra Large */
@media (min-width: 1200px) {
    .chart-container {
        max-width: 450px !important;
    }
}

/* Estilos para FAQ acessível */
.faq-question {
    background: none !important;
    border: none !important;
    width: 100% !important;
    text-align: left !important;
    cursor: pointer !important;
    font-family: inherit !important;
    font-size: inherit !important;
    color: inherit !important;
    margin: 0 !important;
    outline: none !important;
}

.faq-question:focus {
    outline: 2px solid #1976d2 !important;
    outline-offset: 2px !important;
}

.faq-question:hover {
    background-color: rgba(25, 118, 210, 0.05) !important;
}

.faq-question h3 {
    pointer-events: none !important;
}

.faq-icon {
    pointer-events: none !important;
}
