/**
 * FAQ Accordion - shared front-end + editor styles.
 * Colours resolve from Black Sheep theme tokens and are overridable per block
 * via inline vars set from the editor controls.
 */
.wp-block-blacksheep-faq-accordion {
    --faq-accent: var(--primary-button-color, var(--primary-color, #69b828));
    --faq-header-bg: var(--surface-alt-color, #f4f4f4);
    --faq-question: var(--theme-black, #202020);
    --faq-answer: var(--body-text-color, #3a3a3a);
    --faq-display: var(--header-font, "Poppins", Arial, sans-serif);
    --faq-body: var(--body-font, "Inter", Arial, sans-serif);
    --faq-radius: 4px;

    display: block;
}

.wp-block-blacksheep-faq-accordion .faq {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-inline: auto;
    max-width: 1024px;
    width: 100%;
}

.wp-block-blacksheep-faq-accordion .faq__item {
    background: var(--faq-header-bg);
    border: 1px solid var(--faq-accent);
    border-radius: var(--faq-radius);
    overflow: hidden;
}

.wp-block-blacksheep-faq-accordion .faq__q {
    align-items: center;
    background: transparent;
    border: 0;
    color: var(--faq-question);
    cursor: pointer;
    display: flex;
    font-family: var(--faq-display);
    font-size: clamp(17px, 1.6vw, 20px);
    font-weight: 600;
    gap: 16px;
    justify-content: space-between;
    line-height: 1.3;
    padding: 18px 22px;
    text-align: left;
    width: 100%;
}

.wp-block-blacksheep-faq-accordion .faq__q:focus-visible {
    outline: 2px solid var(--faq-accent);
    outline-offset: -2px;
}

.wp-block-blacksheep-faq-accordion .faq__icon {
    color: var(--faq-accent);
    flex: 0 0 auto;
    height: 22px;
    transition: transform 0.3s ease;
    width: 22px;
}

.wp-block-blacksheep-faq-accordion .faq__icon svg {
    display: block;
    height: 100%;
    stroke: currentColor;
    width: 100%;
}

.wp-block-blacksheep-faq-accordion .faq__item.is-open .faq__icon {
    transform: rotate(180deg);
}

/* Collapsible body: animate grid rows from 0fr to 1fr. */
.wp-block-blacksheep-faq-accordion .faq__a {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.3s ease;
}

.wp-block-blacksheep-faq-accordion .faq__item.is-open .faq__a {
    grid-template-rows: 1fr;
}

.wp-block-blacksheep-faq-accordion .faq__a-inner {
    overflow: hidden;
}

.wp-block-blacksheep-faq-accordion .faq__a-inner p {
    color: var(--faq-answer);
    font-family: var(--faq-body);
    font-size: 16px;
    line-height: 1.55;
    margin: 0;
    padding: 4px 22px 20px;
    white-space: pre-line;
}

@media (prefers-reduced-motion: reduce) {
    .wp-block-blacksheep-faq-accordion .faq__a,
    .wp-block-blacksheep-faq-accordion .faq__icon {
        transition: none;
    }
}
