/* ====================================================================
   FAQ — página de perguntas frequentes
   ==================================================================== */

.faq-page {
    background-color: var(--semantics-colors-fill-neutral);
    padding: var(--semantics-spacing-vast) 0;
}

.faq-page__inner {
    width: 100%;
    max-width: var(--semantics-container-max);
    margin: 0 auto;
    padding: 0 var(--semantics-spacing-large);
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* ----- Header ----- */
.faq-page__header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--semantics-spacing-medium);
    text-align: center;
    max-width: 560px;
}

.faq-page__title {
    color: var(--semantics-colors-text-accent-petunia);
    margin: 0;
}

.faq-page__subtitle {
    color: var(--semantics-colors-text-secondary);
    margin: 0;
    max-width: 480px;
}

/* ----- Categorias ----- */
.faq-page__categories {
    width: 100%;
    max-width: 960px;
    margin-top: var(--semantics-spacing-wide);
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-wider);
}

.faq-cat {
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-big);
}

.faq-cat__title {
    color: var(--semantics-colors-text-accent-petunia);
    margin: 0;
}

/* ----- CTA Final ----- */
.faq-cta {
    background-color: var(--semantics-colors-fill-accent-petunia);
    border-radius: var(--semantics-radius-big);
    padding: var(--semantics-padding-wider) var(--semantics-padding-broad);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--semantics-spacing-big);
    text-align: center;
    margin-top: var(--semantics-spacing-wider);
    width: 100%;
    max-width: 960px;
}

.faq-cta__title {
    color: var(--semantics-colors-text-on-dark);
    margin: 0;
}

.faq-cta__desc {
    color: var(--semantics-colors-text-on-dark);
    margin: 0;
    max-width: 800px;
}

/* Responsive */
@media (max-width: 1024px) {
    .faq-cta { padding: var(--semantics-padding-bigger) var(--semantics-padding-wide); }
}
@media (max-width: 768px) {
    .faq-page { padding: var(--semantics-spacing-wider) 0; }
    .faq-page__title { font-size: var(--semantics-typography-heading-x-large); }
    .faq-cta { padding: var(--semantics-padding-bigger) var(--semantics-padding-big); }
}
@media (max-width: 576px) {
    .faq-page { padding: var(--semantics-spacing-wide) 0; }
    .faq-page__title { font-size: var(--semantics-typography-heading-large); }
    .faq-cta__title { font-size: var(--semantics-typography-heading-medium); }
}
