﻿.svip_ppn-carousel {
    /* ══════════════════════════════════════
   PPN Plus Promo Carousel (full cards)
   ══════════════════════════════════════ */

    & .SVIP_Swiper

{
    width: 100%;
    padding: 20px 0 50px;
}

/* ── Slide wrapper ── */
& .SVIP_Swiper .swiper-wrapper {
    align-items: stretch;
}

& .SVIP_Swiper .swiper-slide {
    height: auto;
    transition: transform 0.3s, opacity 0.3s;
    opacity: 0.5;
    transform: scale(0.92);
}

    & .SVIP_Swiper .swiper-slide.swiper-slide-active {
        opacity: 1;
        transform: scale(1);
    }

    /* ── Promo card ── */
    & .SVIP_Swiper .swiper-slide .svip-promo-card {
        background: var(--bs-gray-100, #f1f3f5);
        border: 1px solid var(--bs-border-color, #dee2e6);
        border-radius: 12px;
        padding: 2rem 1.5rem;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0.75rem;
        height: 100%;
        overflow: hidden;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
        transition: box-shadow 0.3s;
    }

    & .SVIP_Swiper .swiper-slide.swiper-slide-active .svip-promo-card {
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    }

    /* ── Logo ── */
    & .SVIP_Swiper .swiper-slide .svip-promo-card .svip-promo-logo {
        width: 80px;
        height: 80px;
        border-radius: 50%;
        background: var(--bs-white, #fff);
        display: flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
        flex-shrink: 0;
    }

        & .SVIP_Swiper .swiper-slide .svip-promo-card .svip-promo-logo img {
            max-width: 60px;
            max-height: 60px;
            object-fit: contain;
        }

    /* ── Title ── */
    & .SVIP_Swiper .swiper-slide .svip-promo-card .svip-promo-title {
        font-size: 1.15rem;
        font-weight: 600;
        color: var(--bs-body-color, #212529);
        margin: 0;
        flex-shrink: 0;
    }

    /* ── Blurb (hard clamped to 2 lines) ── */
    & .SVIP_Swiper .swiper-slide .svip-promo-card .svip-promo-blurb {
        font-size: 0.9rem;
        color: var(--bs-secondary-color, #6c757d);
        line-height: 1.45;
        margin: 0;
        width: 100%;
        height: 2.61em;
        max-height: 2.61em;
        overflow: hidden;
        word-break: break-word;
        flex-shrink: 0;
        flex-grow: 0;
    }

    /* ── Link ── */
    & .SVIP_Swiper .swiper-slide .svip-promo-card .svip-promo-link {
        display: inline-block;
        margin-top: auto;
        padding: 0.5rem 1.5rem;
        font-size: 0.875rem;
        font-weight: 600;
        color: var(--bs-white, #fff);
        background: var(--bs-primary);
        border-radius: 6px;
        text-decoration: none;
        transition: background 0.2s, transform 0.15s;
        flex-shrink: 0;
    }

        & .SVIP_Swiper .swiper-slide .svip-promo-card .svip-promo-link:hover {
            background: var(--bs-primary-emphasis, var(--bs-primary));
            transform: translateY(-1px);
            color: var(--bs-white, #fff);
        }

/* ── Pagination ── */
& .SVIP_Swiper .swiper-pagination-bullet.swiper-pagination-bullet-active {
    background: var(--bs-primary);
}


/* ══════════════════════════════════════
   Basic-Plan Logo Strip
   ══════════════════════════════════════ */

& .svip-logo-strip-heading {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--bs-secondary-color, #6c757d);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

& .SVIP_LogoSwiper {
    width: 100%;
    padding: 10px 0 40px;
}

    & .SVIP_LogoSwiper .swiper-wrapper {
        align-items: center;
    }

    /* All slides start at low opacity */
    & .SVIP_LogoSwiper .swiper-slide {
        height: auto;
        display: flex;
        justify-content: center;
        transition: opacity 0.3s;
        opacity: 0.45;
    }

        /*
     * Use swiper-slide-visible (requires watchSlidesProgress: true in JS).
     * This correctly targets every slide that is actually in the viewport
     * regardless of centeredSlides setting — unlike active/next/prev which
     * only ever highlight the first 3 positions when centeredSlides is false.
     */
        & .SVIP_LogoSwiper .swiper-slide.swiper-slide-visible {
            opacity: 1;
        }

    & .SVIP_LogoSwiper .svip-logo-pill {
        width: 72px;
        height: 72px;
        border-radius: 50%;
        background: var(--bs-white, #fff);
        border: 1px solid var(--bs-border-color, #dee2e6);
        display: flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
    }

        & .SVIP_LogoSwiper .svip-logo-pill img {
            max-width: 48px;
            max-height: 48px;
            object-fit: contain;
        }

    & .SVIP_LogoSwiper .swiper-pagination-bullet.swiper-pagination-bullet-active {
        background: var(--bs-secondary, #6c757d);
    }
}
