/* Shortcode [flip_faq] — FAQ par catégorie avec bascules */

.flip-faq {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* ===== Filtres (pills catégories) ===== */
.flip-faq__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.flip-faq__filter {
    background: #fff;
    border: 1px solid #E0E7F0;
    border-radius: 999px;
    padding: 8px 16px;
    font: inherit;
    font-size: 0.95rem;
    color: #161618;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.flip-faq__filter:hover {
    border-color: #0076FF;
}

.flip-faq__filter.is-active {
    background: #0076FF;
    border-color: #0076FF;
    color: #fff;
}

.flip-faq__filter:focus-visible {
    outline: 2px solid #FFD166;
    outline-offset: 2px;
}

.flip-faq__sep {
    border: 0;
    border-top: 1px solid rgb(0 118 255 / 0.15);
    margin: 0;
}

/* ===== Catégorie : titre à gauche + items à droite ===== */
.flip-faq__category {
    display: grid;
    grid-template-columns: minmax(180px, 280px) 1fr;
    gap: 48px;
    align-items: start;
}

.flip-faq__category[hidden] {
    display: none;
}

/* Séparateur visuel entre deux catégories visibles (= état "toutes affichées").
   Quand un seul filtre est actif, une seule catégorie est visible → aucun
   séparateur appliqué car le sélecteur ne matche pas. */
.flip-faq__category:not([hidden]) + .flip-faq__category:not([hidden]) {
    border-top: 1px solid rgb(0 118 255 / 0.15);
    padding-top: 24px;
    margin-top: 24px;
}

.flip-faq__category-title {
    position: sticky;
    top: 100px;
}

.flip-faq__category-title h2 {
    margin: 0;
    font-family: 'DM serif display', Georgia, serif;
    font-weight: 400;
    color: #161618;
}

.flip-faq__items {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
}

@media (max-width: 900px) {
    .flip-faq__category {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .flip-faq__category-title {
        position: static;
    }
}

/* ===== Item bascule ===== */
.flip-faq__item {
    background: #FAFAF8;
    border: 1px solid transparent;
    border-radius: 12px;
    overflow: hidden;
    transition: border-color 0.2s ease;
}

.flip-faq__item.is-open {
    border-color: rgb(0 118 255 / 0.2);
}

.flip-faq__question {
    width: 100%;
    background: transparent;
    border: 0;
    padding: 18px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    text-align: left;
    cursor: pointer;
    color: inherit;
    font: inherit;
}

.flip-faq__question-label {
    flex: 1;
    font-family: 'DM serif display', Georgia, serif;
    font-weight: 400;
    color: #161618;
}

.flip-faq__question-arrow {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    color: #0076FF;
    border-radius: 50px;
    transition: all 0.3s ease;
}

.flip-faq__item .flip-faq__question:hover .flip-faq__question-arrow{
    transform: rotate(-90deg);
    background: #0076FF;
    color: #F4F5F5;
}

.flip-faq__item.is-open .flip-faq__question-arrow, .flip-faq__item.is-open .flip-faq__question:hover .flip-faq__question-arrow  {
    background: #0076FF;
    color: #F4F5F5;

    transform: rotate(-180deg);
}

.flip-faq__answer[hidden] {
    display: none;
}

.flip-faq__answer-inner {
    padding: 0 24px 20px;
    color: #4b5563;
    line-height: 1.6;
}

.flip-faq__answer-inner p { margin: 0 0 0.75rem; }
.flip-faq__answer-inner p:last-child { margin-bottom: 0; }

/* Animation d'ouverture */
.flip-faq__answer:not([hidden]) {
    animation: flip-faq-expand 0.3s ease both;
}

@keyframes flip-faq-expand {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
    .flip-faq__answer:not([hidden]) { animation: none; }
    .flip-faq__question-arrow { transition: none; }
}

/* Focus visible accessible */
.flip-faq__question:focus-visible {
    outline: 2px solid #FFD166;
    outline-offset: 2px;
}
