/* ---------- CTA SECTION ---------- */
.cta-section {
    position: relative;
    padding: 6rem 1.5rem;
    text-align: center;
    overflow: hidden;
}

.cta-bg {
    position: absolute;
    inset: 0;
}

    .cta-bg img,
    .cta-bg video {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .cta-bg::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg, rgba(13,10,31,0.82) 0%, rgba(13,10,31,0.95) 100%);
    }

.cta-inner {
    position: relative;
    z-index: 1;
    max-width: 820px;
    margin: 0 auto;
}

.cta-heading {
    font-size: clamp(2.2rem, 4.5vw, 3.2rem);
    font-weight: 700;
    color: var(--accent-purple-soft);
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0 0 1.25rem;
}

.cta-body {
    font-size: 1.1rem;
    color: var(--text-main);
    line-height: 1.5;
    margin: 0 auto 2.25rem;
    max-width: 56ch;
}

.cta-buttons {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
}

@media (min-width: 768px) {
    .cta-section {
        padding: 8rem 2rem;
    }
}
