﻿/* ProTemplate2 • Final CTA — amped version (drop-in) */
.pro2-finalcta-section.finalcta {
    --cta-bg: var(--secondary-bg, var(--primary-bg, #071d32));
    --cta-fg: var(--text-color, #f4f7fb);
    --cta-muted: color-mix(in srgb, var(--cta-fg) 70%, transparent);
    --cta-accent: var(--accent, #c96d36);
    --cta-accent-2: var(--accent-2, #d88346);
    --cta-panel: color-mix(in srgb, var(--cta-bg) 78%, #ffffff 22%);
    --cta-border: color-mix(in srgb, var(--cta-accent) 42%, #000 20%);
    --cta-maxw: min(1160px, 94vw);
    --cta-radius: 18px;
    --cta-padY: clamp(56px, 9vw, 96px);
    --cta-gap: clamp(16px, 3vw, 28px);
    position: relative;
    padding: var(--cta-padY) 0;
    color: var(--cta-fg);
    background: radial-gradient(1200px 400px at 80% -10%, color-mix(in srgb, var(--cta-accent) 22%, transparent), transparent 70%), linear-gradient(180deg, color-mix(in srgb, var(--cta-bg) 90%, #000 10%), var(--cta-bg));
    border-top: 1px solid color-mix(in srgb, var(--cta-fg) 10%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--cta-fg) 12%, transparent);
    overflow: clip;
    isolation: isolate; /* keeps confetti/effects contained */
}

    /* scanlines + mask gradient */
    .pro2-finalcta-section.finalcta::before {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(transparent 31px, color-mix(in srgb, var(--cta-fg) 6%, transparent) 32px) 0 0/100% 32px, linear-gradient(90deg, transparent 31px, color-mix(in srgb, var(--cta-fg) 6%, transparent) 32px) 0 0/32px 100%;
        opacity: .16;
        pointer-events: none;
        mask: linear-gradient(0deg, transparent, #000 18%, #000 82%, transparent);
    }

    /* copper plasma ring */
    .pro2-finalcta-section.finalcta::after {
        content: "";
        position: absolute;
        inset: -40% -10% auto -10%;
        height: 120%;
        translate: 0 -40%;
        background: conic-gradient(from 0deg, color-mix(in srgb, var(--cta-accent) 40%, transparent), transparent 25% 60%, color-mix(in srgb, var(--cta-accent-2) 40%, transparent) 85%, transparent);
        filter: blur(40px) saturate(1.2);
        opacity: .25;
        animation: finalCtaRing 18s linear infinite;
        pointer-events: none;
        z-index: 0;
    }

@keyframes finalCtaRing {
    to {
        transform: rotate(360deg)
    }
}

.finalcta-inner {
    max-width: var(--cta-maxw);
    margin: 0 auto;
    padding: 0 clamp(16px,3vw,28px);
    text-align: center;
    position: relative;
    z-index: 1; /* above effects */
}

/* Heading with interactive foil sheen */
.finalcta-heading {
    --sheenX: 50%;
    --sheenY: 50%;
    margin: 0 0 10px;
    font-size: clamp(1.6rem, 4vw, 2.2rem);
    font-weight: 900;
    letter-spacing: .2px;
    line-height: 1.15;
    background: radial-gradient(220px 80px at var(--sheenX) var(--sheenY), #fff, color-mix(in srgb, var(--cta-fg) 85%, #fff 15%) 40%, transparent 65%) no-repeat, linear-gradient(90deg, #fff, color-mix(in srgb, var(--cta-fg) 85%, #fff 15%));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    transition: background-position .15s;
}

.finalcta-sub {
    margin: 0 auto 18px;
    max-width: 680px;
    color: var(--cta-muted);
    font-size: clamp(1rem,2.1vw,1.08rem);
}

/* Stats grid */
.finalcta-stats {
    margin: 22px auto 20px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: var(--cta-gap);
    max-width: 980px;
}

/* Stat cards with tilt + shine */
.stat-card {
    position: relative;
    padding: 16px 14px;
    border-radius: var(--cta-radius);
    background: linear-gradient(180deg, color-mix(in srgb, var(--cta-panel) 70%, transparent), color-mix(in srgb, var(--cta-panel) 50%, transparent));
    border: 1px solid color-mix(in srgb, var(--cta-fg) 12%, transparent);
    box-shadow: 0 10px 30px rgba(0,0,0,.25);
    backdrop-filter: saturate(1.15) blur(6px);
    text-align: left;
    overflow: hidden;
    will-change: transform, box-shadow;
    transform-style: preserve-3d;
    transition: transform .2s ease, box-shadow .2s ease;
}

    .stat-card::after {
        content: "";
        position: absolute;
        inset: -40% -40% auto -40%;
        height: 120%;
        background: radial-gradient(220px 60px at 50% 0%, color-mix(in srgb, var(--cta-accent) 18%, transparent), transparent 60%);
        pointer-events: none;
        opacity: .8;
    }

    .stat-card::before {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(120deg, transparent 40%, rgba(255,255,255,.08) 48%, transparent 56%);
        transform: translateX(-120%);
        transition: transform .6s ease;
        pointer-events: none;
    }

    .stat-card:hover::before {
        transform: translateX(120%);
    }

.stat-title {
    font-size: clamp(1.1rem,2.4vw,1.35rem);
    font-weight: 800;
    color: #fff;
    line-height: 1.2;
}

.stat-text {
    margin-top: 6px;
    color: var(--cta-muted);
    font-size: .95rem;
}

/* Hide only when animating in */
.pro2-finalcta-section.finalcta.js-animate .finalcta-heading,
.pro2-finalcta-section.finalcta.js-animate .finalcta-sub,
.pro2-finalcta-section.finalcta.js-animate .stat-card {
    opacity: 0;
    transform: translateY(18px);
}

/* CTA button (magnetic + spotlight + comet orbit) */
.finalcta-actions {
    margin-top: 18px;
}

.cta-btn {
    --glowX: 50%;
    --glowY: 50%;
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: #fff;
    font-weight: 800;
    padding: 12px 18px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--cta-accent) 30%, #000 10%);
    background: radial-gradient(120px 120px at var(--glowX) var(--glowY), color-mix(in srgb, #fff 24%, transparent), transparent 60%), linear-gradient(90deg, var(--cta-accent), var(--cta-accent-2));
    box-shadow: 0 14px 28px color-mix(in srgb, var(--cta-accent) 35%, transparent);
    transition: transform .15s ease, box-shadow .2s ease, filter .2s ease;
}

    .cta-btn:hover {
        transform: translateY(-2px);
        box-shadow: 0 18px 36px color-mix(in srgb, var(--cta-accent) 50%, transparent);
        filter: saturate(1.05);
    }

    .cta-btn:focus-visible {
        outline: 2px solid color-mix(in srgb, var(--cta-accent-2) 80%, #fff 20%);
        outline-offset: 3px;
        box-shadow: 0 0 0 4px color-mix(in srgb, var(--cta-accent) 25%, transparent);
    }

.cta-arrow {
    transform: translateX(0);
    transition: transform .15s ease;
}

.cta-btn:hover .cta-arrow {
    transform: translateX(3px);
}

/* comet orbit */
.cta-btn::after {
    content: "";
    position: absolute;
    inset: -6px;
    border-radius: inherit;
    background: radial-gradient(6px 6px at 50% 0, #fff, transparent 60%);
    animation: ctaOrbit 2.6s linear infinite;
    opacity: .4;
    pointer-events: none;
    mask: conic-gradient(from 0deg, #000 0 98%, transparent 98% 100%), radial-gradient(20px 20px at 50% 0, #000 0 60%, transparent 61%);
    -webkit-mask-composite: destination-out;
    mask-composite: subtract;
}

@keyframes ctaOrbit {
    to {
        transform: rotate(360deg)
    }
}

/* Ripple */
.cta-btn .ripple {
    position: absolute;
    inset: 0 auto auto 0;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: color-mix(in srgb, #ffffff 50%, var(--cta-accent) 0%);
    transform: translate(-50%, -50%) scale(0);
    animation: ctaRipple .6s linear forwards;
    pointer-events: none;
}

@keyframes ctaRipple {
    to {
        transform: translate(-50%, -50%) scale(12);
        opacity: 0;
    }
}

/* Responsive */
@media (max-width: 900px) {
    .finalcta-stats {
        grid-template-columns: 1fr;
        max-width: 680px;
    }
}

/* Motion-reduced */
@media (prefers-reduced-motion: reduce) {
    .pro2-finalcta-section.finalcta.js-animate * {
        transition: none !important;
    }
}
