/* ============================================
   CTA Banner Component
   ============================================ */

.cta-banner {
    padding: var(--space-3xl) 0;
    background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 50%, var(--color-accent) 100%);
    background-size: 200% 200%;
    animation: gradientShift 8s ease-in-out infinite;
    text-align: center;
    position: relative;
    overflow: hidden;
}

/* Subtle pattern overlay */
.cta-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        45deg,
        transparent,
        transparent 10px,
        rgba(255, 255, 255, 0.03) 10px,
        rgba(255, 255, 255, 0.03) 20px
    );
}

.cta-banner__content {
    position: relative;
    z-index: 1;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

.cta-banner__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-extrabold);
    color: var(--color-text-white);
    margin-bottom: var(--space-sm);
}

.cta-banner__subtitle {
    font-size: var(--font-size-lg);
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: var(--space-xl);
}

.cta-banner__actions {
    display: flex;
    gap: var(--space-lg);
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.cta-banner__phone {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-extrabold);
    color: var(--color-text-white);
    transition: transform var(--transition-fast);
}

.cta-banner__phone:hover {
    transform: scale(1.05);
}

.cta-banner__phone svg {
    width: 28px;
    height: 28px;
}

.cta-banner .btn--outline {
    border-color: rgba(255, 255, 255, 0.6);
}

@media (max-width: 768px) {
    .cta-banner__title {
        font-size: var(--font-size-2xl);
    }

    .cta-banner__phone {
        font-size: var(--font-size-xl);
    }

    .cta-banner__actions {
        flex-direction: column;
    }
}
