/* ============================================================
   PRICING.CSS – Social Care Pricing Section
   Convention: 1rem = 10px (html font-size: 62.5%)
   ============================================================ */

/* ---------- Section wrapper ---------- */
.pricing {
    background: #ffffff;
    position: relative;
    overflow: hidden;
}

/* Subtle decorative gradient top */
.pricing::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% -10%,
            rgba(12, 94, 255, 0.05) 0%,
            transparent 70%);
    pointer-events: none;
}

/* ---------- Section header ---------- */
.pricing__header {
    text-align: center;
    margin-bottom: var(--space-2xl);
}

.pricing__eyebrow {
    font-size: var(--font-lg);
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: 0.8rem;
    display: block;
}

.pricing__title {
    font-size: clamp(2.4rem, 4vw, 3.6rem);
    font-weight: 700;
    color: var(--color-text-primary);
    line-height: 1.25;
    margin-bottom: 1.6rem;
}

.pricing__subtitle {
    font-size: var(--font-base);
    color: var(--color-text-secondary);
    line-height: 1.7;
    max-width: 54rem;
    margin-inline: auto;
}

/* ---------- Cards grid ---------- */
.pricing__swiper {
    overflow: unset;
}

.pricing__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    align-items: stretch;
}

/* Pagination: ẩn trên desktop */
.pricing__swiper-pagination {
    display: none;
}

/* ---------- Individual card ---------- */
.pricing-card {
    /* Default: light grey background */
    background: #F7F7F7;
    border: 1.5px solid #E6E6E6;
    border-radius: 1.8rem;
    padding: 3rem 3rem 3.2rem;
    display: flex;
    flex-direction: column;
    position: relative;
    cursor: pointer;
    transition:
        background var(--transition-base),
        border-color var(--transition-base),
        box-shadow var(--transition-base),
        transform var(--transition-base);
}

.pricing-card:hover {
    background: #EDF6FF;
    border-color: rgba(12, 94, 255, 0.25);
    box-shadow: 0 0.6rem 2.4rem rgba(12, 94, 255, 0.09);
}

/* Active state – toggled by JS click */
.pricing-card--active {
    background: #EDF6FF;
    border-color: var(--color-primary);
    border-width: 0.2rem;
    box-shadow: 0 0.8rem 3.2rem rgba(12, 94, 255, 0.16);
    transform: translateY(0);
}

.pricing-card--active:hover {
    box-shadow: 0 1.4rem 4.8rem rgba(12, 94, 255, 0.22);
}

/* ---------- Card header (name + badge) ---------- */
.pricing-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.6rem;
    flex-wrap: wrap;
    gap: 0.8rem;
}

.pricing-card__name {
    font-size: var(--font-base);
    font-weight: 600;
    color: var(--color-text-primary);
}

/* "Phổ biến nhất" badge – warm gradient pill */
.pricing-card__badge {
    display: inline-flex;
    align-items: center;
    padding: 0.45rem 1.2rem;
    border-radius: var(--radius-full);
    font-size: 1.15rem;
    font-weight: 700;
    background: linear-gradient(135deg, #FFB547 0%, #FF6BCB 100%);
    color: #ffffff;
    white-space: nowrap;
    letter-spacing: 0.01em;
    line-height: 1;
}

/* ---------- Price block ---------- */
.pricing-card__price-wrap {
    margin-bottom: 0.6rem;
}

.pricing-card__price {
    font-size: clamp(2.6rem, 3.2vw, 3.4rem);
    font-weight: 600;
    color: var(--color-text-primary);
    line-height: 1.1;
}

.pricing-card__price-unit {
    font-size: var(--font-sm);
    font-weight: 400;
    color: #6B7A95;
    margin-left: 0.1rem;
}

.pricing-card__tagline {
    font-size: var(--font-sm);
    color: #6B7A95;
    margin-top: 0.6rem;
}

/* ---------- Divider ---------- */
.pricing-card__divider {
    border: none;
    height: 0.1rem;
    background: #E4EAF5;
    margin-block: 2.4rem;
}

/* ---------- Feature list ---------- */
.pricing-card__benefits-label {
    font-size: var(--font-base);
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 1.4rem;
}

.pricing-card__features {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    flex: 1;
    /* push CTA to bottom */
}

.pricing-card__feature {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    font-size: var(--font-sm);
    color: var(--color-text-primary);
    line-height: 1.5;
}

/* Checkmark icon */
.pricing-card__feature-icon {
    width: 1.8rem;
    height: 1.8rem;
    flex-shrink: 0;
    margin-top: 0.1rem;
    color: var(--color-primary);
}

/* ---------- CTA button ---------- */
.pricing-card__cta {
    margin-top: 3.2rem;
}

.pricing-card__btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 1.4rem 2rem;
    border-radius: var(--radius-full);
    font-size: var(--font-base);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-base);
    background: var(--color-primary);
    color: #ffffff;
    border: none;
    letter-spacing: 0.01em;
    text-decoration: none;
}

.pricing-card__btn:hover {
    background: var(--color-primary-dark);
    transform: translateY(-0.2rem);
    box-shadow: 0 0.6rem 2rem rgba(12, 94, 255, 0.38);
}

/* ---------- Responsive ---------- */

/* Desktop (>1024px): Swiper disabled, CSS grid controls layout */
@media (min-width: 1025px) {

    /* Override Swiper's transform/flex so CSS grid works */
    .pricing__grid.swiper-wrapper {
        display: grid;
        transform: none !important;
        flex-wrap: wrap;
    }

    .pricing__grid .swiper-slide {
        width: auto !important;
        height: auto;
        display: flex;
        flex-direction: column;
    }

    /* Căng pricing-card theo chiều cao của slide */
    .pricing__grid .swiper-slide .pricing-card {
        flex: 1;
    }
}

/* Tablet + Mobile (≤1024px): Swiper chiếm quyền điều khiển */
@media (max-width: 1024px) {
    .pricing__grid {
        display: flex;
        /* Swiper cần flex */
    }

    .pricing__swiper {
        overflow: hidden;
    }

    .pricing__swiper-pagination {
        display: block;
        margin-top: 2.4rem;
        position: static;
        text-align: center;
    }

    .pricing__swiper {
        padding-bottom: 4rem;
        overflow: visible;
    }

    /* Mỗi slide = 1 card, full width */
    .pricing__grid .swiper-slide {
        height: auto;
    }

    .pricing__grid .swiper-slide .pricing-card {
        height: 100%;
    }

    /* Featured card nên xuất hiện dưới dạng initial slide 1 (JS set initialSlide) */
    .pricing-card--active,
    .pricing-card--featured {
        order: 0;
    }

    .pricing__grid {
        gap: 0;
    }
}

@media (max-width: 640px) {
    .pricing-card {
        padding: 2.4rem 2rem 2.4rem;
    }

    .pricing-card__divider {
        margin-block: 1.6rem;
    }

    .pricing-card__features {
        gap: 0.9rem;
    }

    .pricing-card__cta {
        margin-top: 2.4rem;
    }

    .pricing-card__price {
        font-size: 2.8rem;
    }
}