/* ── ECP360 CTA Section ── */

.cta-section {
    position: relative;
    overflow: hidden;
    padding: 5rem 2rem;
}

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

.cta-gradient {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 600px;
    height: 300px;
    background: radial-gradient(ellipse, rgba(168, 85, 247, 0.08), transparent 70%);
}

.cta-wrapper {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    z-index: 1;
    padding: 4rem 3rem;
    border-radius: var(--radius-2xl);
    background: var(--bg-card);
    border: 1px solid rgba(168, 85, 247, 0.15);
}

.cta-wrapper::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: radial-gradient(ellipse at 50% 0%, rgba(168, 85, 247, 0.08), transparent 70%);
    pointer-events: none;
}

.cta-title {
    font-family: var(--font-heading);
    font-size: clamp(1.6rem, 3.5vw, 2.6rem);
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 1rem;
    position: relative;
}

.cta-desc {
    font-size: 1.05rem;
    color: var(--text-muted);
    line-height: 1.7;
    max-width: 560px;
    margin: 0 auto 2rem;
    position: relative;
}

.cta-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
    position: relative;
}

/* Responsive */
@media (max-width: 640px) {
    .cta-wrapper { padding: 2.5rem 1.5rem; }
    .cta-actions { flex-direction: column; }
    .cta-actions .btn-primary,
    .cta-actions .btn-secondary { width: 100%; text-align: center; justify-content: center; }
}
