﻿/* ProTemplate1 • FAQ (scoped, theme-driven, no layout surprises) */
.pt1-faq,
.pt1-faq * {
    --_bg: var(--primary-bg, #0b1b2b);
    --_text: var(--text-color, #e7eef6);
    --_accent: var(--accent, #c96d36);
    --_accent2: var(--accent-2, #d88346);
    --_panel: color-mix(in srgb, var(--_bg) 85%, #ffffff 15%);
}

.pt1-faq {
    background: color-mix(in srgb, var(--_bg) 90%, #fff 10%);
    color: var(--_text);
    padding: clamp(42px, 6vw, 84px) 24px;
    text-align: center;
}

.pt1-faq__title {
    font-weight: 800;
    letter-spacing: .2px;
    margin: 0 auto clamp(20px, 3vw, 32px);
    max-width: 900px;
}

/* ── Accordion ─────────────────────────────────────────── */
.fq-accordion {
    max-width: 920px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.fq-item {
    border: 2px solid color-mix(in srgb, var(--_accent) 35%, transparent);
    border-radius: 10px;
    background: var(--_panel);
    overflow: hidden;
}

/* Question row */
.fq-question {
    display: flex;
    align-items: center;
    gap: .8rem;
    cursor: pointer;
    padding: 1.15rem 1.6rem;
    font-weight: 600;
    color: color-mix(in srgb, var(--_text) 92%, #ffffff);
    user-select: none;
    width: 100%;
    text-align: left;
    background: transparent;
    border: none;
}

    .fq-question:focus-visible {
        outline: 2px solid var(--_accent);
        outline-offset: 2px;
        border-radius: 6px;
    }

/* Plus / minus icon */
.fq-icon {
    margin-left: auto;
    inline-size: 24px;
    block-size: 24px;
    position: relative;
    border-radius: 6px;
}

    .fq-icon::before,
    .fq-icon::after {
        content: "";
        position: absolute;
        inset: 0;
        margin: auto;
        background: var(--_accent);
        border-radius: 2px;
        transition: transform .25s ease, opacity .25s ease, background .2s ease;
    }

    .fq-icon::before {
        width: 14px;
        height: 2px;
    }
    /* minus bar */
    .fq-icon::after {
        width: 2px;
        height: 14px;
    }
/* plus stem */

.fq-item.open .fq-icon::after,
.fq-item[aria-expanded="true"] .fq-icon::after {
    transform: scaleY(0); /* plus → minus */
    opacity: 0;
}

/* Answer box – animated to intrinsic height, no clipping */
.fq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s ease;
    background: color-mix(in srgb, var(--_bg) 92%, #000 8%);
    position: relative;
}

.fq-water {
    height: 4px;
    width: 0;
    background: linear-gradient(90deg, var(--_accent), var(--_accent2));
    transition: width .6s ease;
}

.fq-item.open .fq-water,
.fq-item[aria-expanded="true"] .fq-water {
    width: 100%;
}

.fq-atext {
    padding: 1.2rem 1.6rem 1.4rem;
    color: color-mix(in srgb, var(--_text) 85%, #bfd6eb);
    text-align: left;
    line-height: 1.55;
    font-size: .95rem;
}

/* Empty state */
.fq-empty {
    opacity: .7;
    margin-top: .5rem;
}

/* Accessibility: motion-reduced */
@media (prefers-reduced-motion: reduce) {
    .fq-answer {
        transition: none;
    }

    .fq-icon::before, .fq-icon::after {
        transition: none;
    }

    .fq-water {
        transition: none;
    }
}

/* Mobile */
@media (max-width: 600px) {
    .fq-question {
        padding: .95rem 1.2rem;
    }

    .fq-atext {
        padding: 1rem 1.2rem 1.2rem;
    }
}
