.sp-seo-faq {
    --faq-accent: #8123ff;
    --faq-bg: #fff;
    --faq-bg-soft: #F7F8FB;
    --faq-text: #000;
    --faq-muted: rgba(0, 0, 0, 0.76);
    --faq-border: rgba(129, 35, 255, 0.2);
    --faq-border-strong: rgba(129, 35, 255, 0.46);
    --faq-shadow: 0 5px 14px rgba(0, 0, 0, 0.05);
    --faq-shadow-strong: 0 7px 18px rgba(0, 0, 0, 0.08);
    margin: clamp(26px, 4vw, 44px) 0 24px;
    padding-top: clamp(8px, 1.2vw, 16px);
}

.sp-seo-faq .sp-seo-faq-block {
    position: relative;
    padding: clamp(14px, 2vw, 24px);
    border: 1px solid rgba(129, 35, 255, 0.14);
    border-radius: 8px;
    background: linear-gradient(180deg, #fff 0%, #F7F8FB 100%);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.05);
}

.sp-seo-faq .faq-title {
    margin: 0 0 clamp(14px, 1.8vw, 22px);
    padding: 0 8px;
    color: var(--faq-text);
    text-align: center;
    font-weight: 700;
    font-size: clamp(20px, 2.2vw, 28px);
    line-height: 1.25;
    text-wrap: balance;
}

.sp-seo-faq .sp-seo-faq-block > ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    grid-template-columns: 1fr;
    align-items: start;
    gap: 12px;
}

@media (min-width: 1024px) {
    .sp-seo-faq .sp-seo-faq-block > ul {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }
}

.sp-seo-faq .faq-question {
    list-style: none;
    position: relative;
    align-self: start;
    overflow: hidden;
    border: 1px solid rgba(129, 35, 255, 0.24);
    border-radius: 8px;
    background: linear-gradient(180deg, #fff 0%, #fcfbff 100%);
    box-shadow: var(--faq-shadow);
    transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease, background-color 0.25s ease;
    break-inside: avoid;
}

.sp-seo-faq .faq-question:hover {
    border-color: var(--faq-border-strong);
    box-shadow: var(--faq-shadow-strong);
    transform: translateY(-1px);
}

.sp-seo-faq .faq-question:focus-within {
    border-color: var(--faq-border-strong);
    box-shadow: 0 0 0 2px rgba(129, 35, 255, 0.14), var(--faq-shadow);
}

.sp-seo-faq .faq-link {
    position: relative;
    display: block;
    cursor: pointer;
    margin: 0;
    padding: 15px 56px 15px 16px;
    font-weight: 650;
    font-size: clamp(15px, 1.1vw, 18px);
    line-height: 1.42;
    color: var(--faq-text);
    transition: color 0.2s ease;
}

.sp-seo-faq .faq-question:hover .faq-link {
    color: #3f138c;
}

.sp-seo-faq .faq-link:before {
    content: "";
    position: absolute;
    top: 50%;
    right: 22px;
    z-index: 1;
    width: 8px;
    height: 8px;
    border-right: 2px solid var(--faq-accent);
    border-bottom: 2px solid var(--faq-accent);
    transform: translateY(-50%) rotate(45deg);
    transform-origin: 50% 50%;
    transition: transform 0.25s ease;
    pointer-events: none;
}

.sp-seo-faq .faq-link:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 14px;
    width: 24px;
    height: 24px;
    margin-top: -12px;
    border: 1px solid rgba(129, 35, 255, 0.36);
    border-radius: 50%;
    background: rgba(129, 35, 255, 0.1);
    transition: background-color 0.25s ease, border-color 0.25s ease;
    pointer-events: none;
}

.sp-seo-faq .faq-link.faq-open:before {
    transform: translateY(-50%) rotate(-135deg);
}

.sp-seo-faq .faq-link.faq-open:after {
    background: rgba(129, 35, 255, 0.2);
    border-color: rgba(129, 35, 255, 0.55);
}

.sp-seo-faq .faq-link.faq-open + .faq-text {
    border-top-color: rgba(129, 35, 255, 0.3);
}

.sp-seo-faq .faq-text {
    margin: 0;
    padding: 0 16px 15px;
    font-size: 15px;
    line-height: 1.65;
    color: var(--faq-muted);
    background: linear-gradient(180deg, rgba(247, 248, 251, 0.84) 0%, rgba(247, 248, 251, 1) 100%);
    border-top: 1px solid transparent;
}

.sp-seo-faq .faq-text > [itemprop="text"] {
    padding-top: 13px;
}

.sp-seo-faq .faq-text a {
    color: var(--faq-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.sp-seo-faq .faq-text a:hover {
    color: #5e0fe4;
}

.sp-seo-faq .faq-text ul,
.sp-seo-faq .faq-text ol {
    margin: 8px 0 0;
    padding-left: 18px;
}

.sp-seo-faq .faq-text li {
    margin: 4px 0;
}

.sp-seo-faq .faq-text ul li::marker {
    color: var(--faq-accent);
}

.sp-seo-faq .faq-text ol li {
    list-style: decimal;
}

.sp-seo-faq .faq-link:focus-visible,
.sp-seo-faq a:focus-visible {
    outline: 2px solid var(--faq-accent);
    outline-offset: 2px;
    border-radius: 4px;
}

@media (max-width: 767.98px) {
    .sp-seo-faq {
        margin: 22px 0 18px;
        padding-top: 8px;
    }

    .sp-seo-faq .sp-seo-faq-block {
        padding: 12px;
    }

    .sp-seo-faq .faq-title {
        margin-bottom: 14px;
        font-size: 20px;
        line-height: 1.3;
    }

    .sp-seo-faq .sp-seo-faq-block > ul {
        gap: 10px;
    }

    .sp-seo-faq .faq-link {
        padding: 13px 50px 13px 12px;
        font-size: 15px;
    }

    .sp-seo-faq .faq-link:before {
        right: 21px;
    }

    .sp-seo-faq .faq-link:after {
        right: 14px;
        width: 22px;
        height: 22px;
        margin-top: -11px;
    }

    .sp-seo-faq .faq-text {
        padding: 0 12px 12px;
        font-size: 14px;
        line-height: 1.6;
    }
}

@media (prefers-reduced-motion: reduce) {
    .sp-seo-faq .faq-question,
    .sp-seo-faq .faq-link:before,
    .sp-seo-faq .faq-link:after {
        transition: none !important;
    }
}
