
/* =========================================================
   FAQ • Component Layer
========================================================= */

.pro-faq {
    background: var(--pro-card);
}

.pro-faq__accordion {
    --bs-accordion-bg: transparent;
    --bs-accordion-border-color: transparent;
    --bs-accordion-btn-focus-box-shadow: none;
    --bs-accordion-btn-padding-x: 22px;
    --bs-accordion-btn-padding-y: 18px;
    --bs-accordion-body-padding-x: 22px;
    --bs-accordion-body-padding-y: 0;
}

.pro-faq__item {
    border: 0;
    background: var(--pro-card);
    border-radius: 16px;
    margin-bottom: 16px;
    overflow: hidden;
    box-shadow: 0 18px 45px rgba(16,24,40,.08), 0 8px 18px rgba(16,24,40,.06);
    border: 1px solid rgba(0,0,0,.06);
}

.pro-faq__btn {
    background: var(--pro-card) !important;
    color: var(--pro-text) !important;
    font-weight: 600;
    font-size: 1.25rem;
    border: 0;
}

    /* + / - */
    .pro-faq__btn::after {
        background-image: none !important;
        content: "+";
        width: auto;
        height: auto;
        font-size: 22px;
        font-weight: 700;
        color: var(--pro-text);
        transform: none !important;
    }

    .pro-faq__btn:not(.collapsed)::after {
        content: "–";
    }

.pro-faq__body {
    padding: 0 22px 18px;
}

/* Mobile: reduce paddings */
@media (max-width: 575.98px) {
    .pro-faq__accordion {
        --bs-accordion-btn-padding-x: 18px;
        --bs-accordion-btn-padding-y: 16px;
        --bs-accordion-body-padding-x: 18px;
    }

    .pro-faq__body {
        padding: 0 18px 16px;
    }

    .pro-faq__btn {
        font-size: 1.05rem;
    }
}


/* =========================================================
   CTA • Component Layer
========================================================= */

.pro-cta {
    background: var(--pro-card);
}

.pro-cta__wrap {
    position: relative;
    border-radius: 26px;
    padding: clamp(22px, 3vw, 44px);
    overflow: hidden;
    /*background: linear-gradient( 135deg, rgba(var(--bs-primary-rgb), .16) 0%, rgba(var(--bs-warning-rgb), .22) 45%, rgba(var(--bs-danger-rgb), .14) 100% );*/
    background: linear-gradient(135deg, #dfd2ff 0%, #f6d7b0 45%, #f7c6d7 100%);
    box-shadow: 0 30px 70px rgba(16,24,40,.10), 0 10px 25px rgba(16,24,40,.06);
}

    .pro-cta__wrap::after {
        content: "";
        position: absolute;
        right: -180px;
        top: 50%;
        width: 720px;
        height: 720px;
        transform: translateY(-50%);
        border-radius: 999px;
        pointer-events: none;
        background: radial-gradient(circle at center, rgba(255,255,255,0.0) 0 34%, rgba(255,255,255,0.35) 34% 34.4%, rgba(255,255,255,0.0) 34.4% 46%, rgba(255,255,255,0.28) 46% 46.4%, rgba(255,255,255,0.0) 46.4% 58%, rgba(255,255,255,0.20) 58% 58.4%, rgba(255,255,255,0.0) 58.4% 70%, rgba(255,255,255,0.12) 70% 70.4%, rgba(255,255,255,0.0) 70.4% 100% );
        opacity: .7;
    }

.pro-cta__btn {
    border: 1px solid rgba(0,0,0,.28);
    background: rgba(255,255,255,.25);
    color: var(--pro-text);
    font-weight: 700;
}

    .pro-cta__btn:hover,
    .pro-cta__btn:focus {
        background: rgba(255,255,255,.45);
        border-color: rgba(0,0,0,.40);
        color: var(--pro-text);
    }

.pro-cta__art img {
    max-width: 460px;
}

@media (max-width: 991.98px) {
    .pro-cta__wrap::after {
        right: -260px;
        width: 620px;
        height: 620px;
        opacity: .55;
    }

    .pro-cta__art img {
        max-width: 360px;
    }
}



/* =========================================================
   BLOGS • Component Layer
========================================================= */

.pro-blogs {
    background: var(--pro-card);
}

.pro-blog-card {
    background: var(--pro-card);
    border-radius: var(--pro-radius);
    overflow: hidden;
    border: 1px solid rgba(0,0,0,.06);
    box-shadow: 0 18px 45px rgba(16,24,40,.08);
    transition: transform .25s ease, box-shadow .25s ease;
}

    .pro-blog-card:hover {
        transform: translateY(-6px);
        box-shadow: 0 24px 60px rgba(16,24,40,.12);
    }

.pro-blog-card__image {
    width: 100%;
    height: 260px;
    object-fit: cover;
    display: block;
}

/* Mobile: reduce image height a bit */
@media (max-width: 575.98px) {
    .pro-blog-card__image {
        height: 220px;
    }
}