/* ─── FAQ — Steps block ─────────────────────────────────────── */

.cb-faq-steps {
    background: var(--cb-fqs-bg, #0f0f0f);
    color: #fff;
    padding: min(5rem, 7vh) clamp(1.25rem, 5vw, 3rem);
}

.cb-faq-steps__wrap {
    max-width: var(--cb-fqs-max-width, 900px);
    margin: 0 auto;
}

/* ── Header ── */

.cb-faq-steps__header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: end;
    margin-bottom: min(3.5rem, 5vh);
    padding-bottom: min(3.5rem, 5vh);
    border-bottom: 2px solid var(--cb-fqs-divider, rgba(255,255,255,0.12));
}

.cb-faq-steps__headline {
    font-size: var(--cb-fqs-headline-size, 54px);
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1.08;
    color: var(--cb-fqs-headline, #fff);
    margin: 0;
}

.cb-faq-steps__sub {
    color: var(--cb-fqs-sub, rgba(255,255,255,0.5));
    font-size: 1rem;
    line-height: 1.7;
    margin: 0;
}

/* ── Steps list ── */

.cb-faq-steps__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.cb-faq-steps__step {
    display: grid;
    grid-template-columns: 4.5rem 1fr;
    gap: 2rem;
    padding: min(2.5rem, 3.5vh) 0;
}

.cb-faq-steps__step + .cb-faq-steps__step {
    border-top: 1px solid var(--cb-fqs-step-border, rgba(255,255,255,0.07));
}

/* ── Step number (optional) ── */

/* `accentColor` is labelled "Accent colour (rule + number)" in the CP,
   so the step number reads from --cb-fqs-accent like the rule does.
   Hardcoding rgba(255,255,255,0.08) ignored the editor's choice and
   made the label misleading; color-mix keeps the subtle watermark feel
   while honouring whatever colour the editor picked. */
.cb-faq-steps__num {
    font-size: clamp(2.5rem, 4vw, 3.5rem);
    font-weight: 900;
    color: color-mix(in srgb, var(--cb-fqs-accent, #c1272d) 22%, transparent);
    letter-spacing: -0.05em;
    line-height: 1;
    padding-top: 0.1rem;
    align-self: start;
    user-select: none;
}

/* ── Step body ── */

.cb-faq-steps__body {
    padding-top: 0.35rem;
}

.cb-faq-steps__body--no-num {
    grid-column: 1 / -1;
    padding-top: 0;
}

/* When no numbers, collapse the grid to single column */
.cb-faq-steps__step:not(:has(.cb-faq-steps__num)) {
    grid-template-columns: 1fr;
}

.cb-faq-steps__title {
    font-size: clamp(1.2rem, 2vw, 1.5rem);
    font-weight: 700;
    color: var(--cb-fqs-title, rgba(255,255,255,0.92));
    margin: 0 0 0.75rem;
    letter-spacing: -0.02em;
}

/* ── Accent rule (width animated by GSAP) ── */

.cb-faq-steps__rule {
    width: 100%;
    max-width: 3rem;
    height: 2px;
    background: var(--cb-fqs-accent, #c1272d);
    margin: 0 0 1rem;
    border: none;
    will-change: transform;
    box-shadow: 0 0 8px color-mix(in srgb, var(--cb-fqs-accent, #c1272d) 40%, transparent);
}

.cb-faq-steps__desc {
    font-size: 0.975rem;
    color: var(--cb-fqs-desc, rgba(255,255,255,0.55));
    line-height: 1.75;
    margin: 0;
    max-width: 55ch;
}

/* ── Responsive ── */

@media (max-width: 640px) {
    .cb-faq-steps__header {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .cb-faq-steps__headline {
        font-size: clamp(2rem, 8vw, 2.8rem);
    }

    .cb-faq-steps__step {
        grid-template-columns: 3.5rem 1fr;
        gap: 1rem;
    }
}

@media (max-width: 480px) {
    .cb-faq-steps {
        padding: min(3rem, 5vh) 1rem;
    }

    .cb-faq-steps__step {
        grid-template-columns: 1fr;
        gap: 0.5rem;
        padding: min(2rem, 3vh) 0;
    }

    .cb-faq-steps__num {
        font-size: clamp(1.75rem, 11vw, 2.5rem);
        padding-top: 0;
    }

    .cb-faq-steps__body {
        padding-top: 0;
    }

    .cb-faq-steps__desc {
        max-width: none;
    }
}
