/* ============================================================
   PAGE FAQ — Questions / Réponses
   Frame Figma : FAQ (359:2334). 2 colonnes : 440px de questions,
   reste pour le panneau réponse. JS toggle .is-active.
   ============================================================ */

body.faq {
    background: var(--color-primary-light-grey);
}

.faqPage {
    background: var(--color-primary-light-grey);
    padding: 0 var(--content-gutter) var(--space-10);
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

/* ----- Titre tab ("15 Questions clés / pour comprendre ESOP 2026") --- */
.faqPage__title {
    align-self: flex-start;
    background: var(--color-primary-white);
    padding: var(--space-10);
    margin-bottom: -10px;
    z-index: 1;
    position: relative;
}

.faqPage__titleMain,
.faqPage__titleSub {
    font-family: var(--font-family-base);
    font-size: var(--font-size-h1);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
}

.faqPage__titleMain {
    color: var(--color-primary-dark-blue);
}

/* Sub : Italic Regular (Figma utilise Ubuntu:Italic, pas Bold Italic) */
.faqPage__titleSub {
    color: var(--color-secondary-teal);
    font-style: italic;
    font-weight: var(--font-weight-regular);
}

.faqPage__titleMain p,
.faqPage__titleSub p {
    margin: 0;
    font: inherit;
    color: inherit;
}

/* Sous-titre inline (<em> dans la clé BDD title_main) :
   Figma => teal italic Regular, alors que le titre principal est dark blue Bold. */
.faqPage__titleMain em {
    color: var(--color-secondary-teal);
    font-style: italic;
    font-weight: var(--font-weight-regular);
}

.faqPage__empty {
    padding: var(--space-10);
    text-align: center;
    color: var(--color-primary-dark-blue);
    font-style: italic;
}

/* ----- Layout 2 colonnes ---------------------------------------------- */
.faqLayout {
    padding: 0 var(--content-gutter);
    display: flex;
    gap: 30px;
    align-items: flex-start;
    z-index: 2;
    position: relative;
}

/* ----- Colonne gauche : liste des questions --------------------------- */
.faqList {
    width: 440px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.faqItem {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    width: 100%;
    background: var(--color-secondary-lilac);
    border: 0;
    padding: var(--space-3);
    text-align: left;
    cursor: pointer;
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-regular);
    line-height: var(--line-height-tight);
    color: var(--color-primary-dark-blue);
    transition: background-color 0.15s ease, color 0.15s ease;
}

.faqItem__text {
    flex: 1 1 0;
    min-width: 0;
}

.faqItem__arrow {
    flex-shrink: 0;
    width: 30px;
    height: 14px;
    opacity: 0;
    transition: opacity 0.15s ease;
}

.faqItem:hover,
.faqItem:focus-visible {
    background: var(--color-primary-dark-blue);
    color: var(--color-primary-white);
    outline: none;
}

.faqItem.is-active {
    background: var(--color-primary-dark-blue);
    color: var(--color-primary-white);
    font-weight: var(--font-weight-bold);
}

.faqItem.is-active .faqItem__arrow {
    opacity: 1;
}

/* ----- Colonne droite : panneau réponse ------------------------------ */
.faqAnswers {
    flex: 1 1 0;
    min-width: 0;
    position: relative;
}

.faqAnswer {
    display: none;
    background: var(--color-primary-white);
    padding: var(--space-5);
    flex-direction: column;
    gap: var(--space-5);
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.10);
}

.faqAnswer.is-active {
    display: flex;
}

.faqAnswer__title {
    margin: 0;
    font-family: var(--font-family-base);
    font-size: var(--font-size-h1);
    font-weight: var(--font-weight-bold);
    color: var(--color-secondary-teal);
    line-height: var(--line-height-tight);
}

.faqAnswer__body {
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    color: var(--color-primary-dark-blue);
    line-height: 1.5;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.faqAnswer__body p {
    margin: 0;
}

.faqAnswer__body strong {
    font-weight: var(--font-weight-bold);
}

.faqAnswer__body em {
    font-style: italic;
}

.faqAnswer__body a {
    color: var(--color-primary-blue);
    text-decoration: underline;
}

.faqAnswer__body ul,
.faqAnswer__body ol {
    margin: 0;
    padding-left: var(--space-6);
}

.faqAnswer__body ul {
    list-style: disc;
}

.faqAnswer__body ol {
    list-style: decimal;
}

.faqAnswer__body li {
    margin-bottom: var(--space-1);
}

/* Conteneurs spéciaux (boxes) qu'un admin peut insérer via TinyMCE :
   classe sur un <div> dans le contenu. */
.faqAnswer__body .faq-box-grey {
    background: var(--color-primary-light-grey);
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.faqAnswer__body .faq-box-lilac {
    background: var(--color-secondary-lilac);
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

/* ----- Responsive ----------------------------------------------------- */
@media (max-width: 1024px) {
    .faqPage {
        padding: 0 var(--space-5) var(--space-6);
    }

    .faqLayout {
        padding: 0;
        flex-direction: column;
        gap: var(--space-5);
    }

    .faqList {
        width: 100%;
    }

    .faqPage__titleMain,
    .faqPage__titleSub {
        font-size: 24px;
    }

    .faqAnswer__title {
        font-size: 24px;
    }
}
