body.bg-img {
    font-family: 'Nunito', sans-serif;
}

.container.p-4.bg-white.mt-4.rounded.shadow {
    background-color: white;
    margin-top: 1rem;
    padding: 1rem;
    border-radius: 0.25rem;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.imgppa {
    max-width: 100%;
    height: auto;
}

.text-center.mb-4 h1.text-primary.fw-bold {
    color: #0d6efd;
    font-weight: bold;
}

.tituloppa {
    font-size: 2rem;
    font-weight: bold;
    color: #0d6efd;
    text-align: center;
    margin-bottom: 1.5rem;
    margin-top: 0.5rem;
    letter-spacing: 0.01em;
}

@media (max-width: 576px) {
    .tituloppa {
        font-size: 1.4rem;
        margin-bottom: 1rem;
    }
}

.text-center.mb-4 p.text-muted {
    color: #6c757d;
}

.text-secondary {
    color: #6c757d;
}

.img-fluid.rounded {
    border-radius: 0.25rem;
    max-width: 100%;
    height: auto;
}

.text-center.mt-5 .btn.btn-lg.btn-primary.shadow-sm {
    font-size: 1.25rem;
    color: #fff;
    background-color: #0d6efd;
    border-color: #0d6efd;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.dashboard-title {
    font-size: 2.2rem;
}

.ppa-stats-box {
    background: #f8f9fa;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    padding: 1.2rem 0.5rem;
    text-align: match-parent;
    margin-bottom: 1.5rem;
    margin-bottom: 1rem;
}
.ppa-stats-label {
    font-size: 1.1rem;
}
.ppa-stats-value {
    font-size: 2.2rem;
    font-weight: bold;
}

.question-box {
    background: #f8f9fa;
    border-radius: 14px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.06);
    margin-bottom: 1.5rem;
    padding: 1.5rem 1.2rem;
}
.question-box h3 {
    font-size: 1.35rem;
    line-height: 1.5;
    min-height: 70px;
    margin-bottom: 1.5rem;
    text-align: center;
}
.chart-box {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.07);
    padding: 0;
    height: 340px;
    min-height: 340px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.chart-box > div {
    width: 95%;
    height: 95%;
}

@media (min-width: 992px) {
    .ppa-stats-box {
        min-height: 120px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .row.mb-4 .col-lg-4 {
        display: flex;
        align-items: stretch;
    }
    .question-box {
        height: 100%;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
    }
    .question-box .chart-box {
        flex: 1 1 auto;
    }
    /* Centraliza e aumenta a imagem apenas no desktop */
    .imgppa-desktop-center {
        display: flex;
        justify-content: center;
        align-items: flex-start;
        /* Mantém a posição Y original */
        height: 100%;
    }
    .imgppa {
        max-width: 600px !important;
        width: 100% !important;
    }
}

.navigation-buttons {
    display: flex;
    flex-direction: row;
    justify-content: center;
}