/**
 * Subscription Landing – plain CSS, no SCSS.
 * Scale: max(minPx, Xvw) – second value is vw for 1920px. Convert: px/1920*100 (e.g. 28px → 1.458vw).
 */
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap');

:root {
    --sl-font: 'Lato', sans-serif;
    --sl-fs-base: max(14px, 0.8333333333vw);
    --sl-fs-title: max(24px, 4.167vw);
    --sl-fs-section-title: max(24px, 2.188vw);
    --sl-fs-section-subtitle: max(16px, 1.146vw);
    --sl-bg-white: #fff;
    --sl-text: #212121;
    --sl-text-muted: #4D4D4D;
    --sl-primary-color: #FF8927;
    --sl-primary-color-light: #fff5ec;
    --sl-secondary-color: #2DBDCA;
    --sl-secondary-color-light: #edfcfd;
    --sl-bg-gray-light: #F9F9F9;
    --sl-success-color-light: #ecffee;
    --sl-plans-advantage: #2DBDCA;
    --sl-plans-premium: #293450;
}
a{
    text-decoration: none;
}
.sl {
    font-family: var(--sl-font);
    font-size: var(--sl-fs-base);
    color: var(--sl-text);
    padding: 0;
    margin: 0;
}

.sl-btn {
    display: inline-flex;
    align-items: center;
    gap: max(6px, 0.4166666667vw);
    padding: max(15px, 0.781vw) max(28px, 1.458vw);
    border: none;
    border-radius: max(50px, 2.604vw);
    font: 700 var(--sl-fs-base);
    cursor: pointer;
    text-decoration: none;
    transition: opacity 0.2s;
    line-height: max(20px, 1.25vw);
}

.sl-btn:hover {
    opacity: 0.95;
}

.sl-btn--cta {
    background: var(--sl-primary-color);
    color: var(--sl-bg-white);
}

/* Arrow button: white circle on right with img inside, integrated into capsule */
.sl-btn--cta.sl-btn--arrow {
    padding-right: max(4px, 0.2083333333vw);
    padding-block: max(4px, 0.2083333333vw);
    padding-left: max(28px, 1.4583333333vw);

}

.sl-btn--arrow span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: max(44px, 2.291vw);
    height: max(44px, 2.291vw);
    margin-left: max(10px, 0.5208333333vw);
    border-radius: 50%;
    background: var(--sl-bg-white);
}

.sl-btn--arrow span img {
    width: max(24px, 1.25vw);
    height: max(24px, 1.25vw);
    object-fit: contain;
    display: block;
}

.sl-card {
    display: flex;
    align-items: center;
    gap: max(10px, 0.625vw);
    padding: max(10px, 0.833vw);
    background: var(--sl-bg-white);
    border-radius: max(20px, 1.042vw);

}

.sl-card__icon {
    flex-shrink: 0;
    width: max(24px, 1.667vw);
    height: max(24px, 1.4583333333vw);
}

.sl-card__icon img {
    width: 100%;
}

.sl-card__text {
    font-size: max(14px, 0.938vw);
    color: #1F1851;
    font-weight: 600;
}


.sl-banner {
    margin-inline: max(8px, 2.604vw);
    background-image: url('../images/membership-plans/Hero_W.png');
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: max(20px, 2.604vw);
    overflow: hidden;
    margin-block: max(18px, 1.563vw);
    height: max(696px, 36.25vw);
}

.sl-banner__inner {
    display: flex;
    flex-direction: column;
    min-height: max(696px, 35vw);
    height: 100%;
}

.sl-banner__body {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.sl-banner__media {
    position: relative;
    overflow: hidden;
    min-height: max(200px, 12.5vw);
}

.sl-banner__media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: bottom;
    display: block;
    max-width: max(830px, 43.229vw);
    margin: auto;
    opacity: 0;
    transition: opacity 0.8s ease-in-out;
}

.sl-banner__media img.is-active {
    opacity: 1;
}

.sl-banner__content {
    padding: max(18px, 1.25vw);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.sl-banner__title {
    font: 700 var(--sl-fs-title) var(--sl-font);
    color: var(--sl-text);
    margin: 0 0 max(6px, 0.4166666667vw);
    line-height: 1.2;
}

.sl-banner__tagline {
    font-size: var(--sl-fs-section-subtitle);
    color: var(--sl-text-muted);
    margin: 0 0 max(20px, 1.042vw);
    font-weight: 700;
}

.sl-banner__disclaimer {
    font-size: max(14px, 0.938vw);
    color: var(--sl-text);
    margin: max(20px, 1.042vw) 0;
    font-weight: 600;
}

.sl-banner__cta {
    margin-bottom: max(12px, 0.8333333333vw);
}

.sl-banner__features:has(> .sl-card) {
    display: flex;
    flex-direction: column;
    gap: max(8px, 0.5208333333vw);
    padding: max(10px, 0.521vw);
    border-radius: max(30px, 1.5625vw);
    border: 1px solid var(--sl-bg-white);
    background: radial-gradient(107.32% 141.42% at 0% 0%, rgba(255, 255, 255, 0.40) 0%, rgba(255, 255, 255, 0.30) 100%);
    box-shadow: -5px -5px 250px 0 rgba(255, 255, 255, 0.02) inset;
    backdrop-filter: blur(21px);
    min-height: max(200px, 10.417vw);
    min-height: auto;
}

.sl-banner__features {
    min-height: max(50px, 5.208vw);
    background-color: transparent;
}

/* ========== Feature slider (Swiper) – after banner ========== */
.sl-features-slider {
    padding: max(20px, 1.458vw) 0;
}

/* .sl-features-slider__swiper {
    overflow: hidden;
}
 */
.sl-features-slider__swiper .swiper-slide {
    width: auto;
}

.sl-features-slider__card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: max(15px, 0.260vw);
    padding: max(10px, 0.521vw) max(16px, 0.833vw);
    background: var(--sl-bg-gray-light);
    border-radius: max(12px, 0.625vw);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.sl-features-slider__text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sl-features-slider__title {
    font: 700 max(18px, 0.938vw) var(--sl-font);
    color: #1B7179;
    line-height: 1.2;
    font-weight: 700;
}

.sl-features-slider__desc {
    font-size: max(16px, 0.833vw);
    color: var(--sl-text-muted);
    line-height: 1.3;
    font-weight: 500;
}

.sl-features-slider__icon {
    flex-shrink: 0;
    width: max(50px, 2.604vw);
    height: max(50px, 2.604vw);
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--sl-bg-white);
    border-radius: max(12px, 0.625vw);
}

.sl-features-slider__icon img {
    width: max(24px, 1.25vw);
    height: max(24px, 1.25vw);
    object-fit: contain;
}

/* ========== Why You Should Subscribe – flex grid, no Swiper ========== */
.sl-subscribe {
    padding: max(50px, 5.208vw) max(24px, 1.25vw);
    background: var(--sl-bg-gray-light);
}


.sl-subscribe__title {
    font: 700 max(24px, 2.188vw) var(--sl-font);
    color: var(--sl-text);
    text-align: center;
    margin: 0 0 max(6px, 0.521vw);
    line-height: 1.3;
}

.sl-subscribe__highlight {
    color: var(--sl-secondary-color);
}

.sl-subscribe__tagline {
    font-size: max(16px, 1.146vw);
    color: var(--sl-text);
    text-align: center;
    margin: 0 0 max(40px, 2.083vw);
    font-weight: 500;
}

/* Subscribe swiper container: when slider active, overflow hidden; when grid/stacked, see below */
.sl-subscribe__swiper {
    margin: 0 auto;
    max-width: max(1440px, 75vw);
    overflow: hidden;
}

/* Slider mode (>4 cards, web): equal-height cards via flex stretch */
.sl-subscribe__swiper:not(.sl-subscribe__swiper--grid):not(.sl-subscribe__swiper--stacked) .swiper-wrapper {
    align-items: stretch;
    height: auto !important;
}

.sl-subscribe__swiper:not(.sl-subscribe__swiper--grid):not(.sl-subscribe__swiper--stacked) .swiper-slide {
    height: auto;
    align-self: stretch;
    display: flex;
}

.sl-subscribe__swiper:not(.sl-subscribe__swiper--grid):not(.sl-subscribe__swiper--stacked) .swiper-slide .sl-subscribe__card {
    width: 100%;
    flex: 1 1 auto;
    min-height: min-content;
}

/* Desktop, ≤4 cards: no slider – same as previous grid (flex wrap, same design) */
.sl-subscribe__swiper--grid .swiper-wrapper {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: max(13px, 1.25vw);
    transform: none !important;
}

.sl-subscribe__swiper--grid .swiper-slide {
    flex: 1;
    min-width: max(320px, 16.667vw);
    height: auto;
    margin: 0 !important;
}

.sl-subscribe__swiper .swiper-slide:nth-child(1) .sl-subscribe__card {
    background: linear-gradient(180deg, var(--sl-primary-color-light, rgb(255 242 231)) 0%, var(--White-White, rgba(255, 255, 255, 0.20)) 100%), #FFF;
}

.sl-subscribe__swiper .swiper-slide:nth-child(2) .sl-subscribe__card {
    background: linear-gradient(180deg, var(--sl-secondary-color-light, rgb(255 242 231)) 0%, var(--White-White, rgba(255, 255, 255, 0.20)) 100%), #FFF;
}

.sl-subscribe__swiper .swiper-slide:nth-child(3) .sl-subscribe__card {
    background: linear-gradient(180deg, rgba(239, 240, 245, 1) 0%, var(--White-White, rgba(255, 255, 255, 0.20)) 100%), #FFF;
}

.sl-subscribe__swiper .swiper-slide:nth-child(4) .sl-subscribe__card {
    background: linear-gradient(180deg, var(--sl-success-color-light, rgb(255 242 231)) 0%, var(--White-White, rgba(255, 255, 255, 0.20)) 100%), #FFF;
}

/* Mobile: no slider – stacked column (same as before) */
.sl-subscribe__swiper--stacked .swiper-wrapper {
    display: flex;
    flex-direction: column;
    gap: max(30px, 1.25vw);
    transform: none !important;
}

.sl-subscribe__swiper--stacked .swiper-slide {
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
}

/* Card – white, significantly rounded, subtle shadow (per SS) */
.sl-subscribe__card {
    padding: max(24px, 1.25vw);
    border-radius: max(30px, 1.563vw);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    background: var(--sl-bg-gray-light);
    border: max(10px, 0.521vw) solid var(--sl-bg-white);
}

.sl-subscribe__card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: max(12px, 0.625vw);
    margin-bottom: max(10px, 0.521vw);
    flex: 0;
}

.sl-subscribe__card-divider {
    flex-shrink: 0;
}

.sl-subscribe__card-line--accent {
    flex-shrink: 0;
}

.sl-subscribe__card-title {
    font: 700 max(18px, 0.938vw) var(--sl-font);
    color: var(--sl-text);
    margin: 0;
    line-height: 1.25;
    flex: 1;
}

/* Icon – rounded square, accent bg, top-right (per SS) */
.sl-subscribe__card-icon {
    flex-shrink: 0;
    width: max(30px, 1.563vw);
    height: max(30px, 1.563vw);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: max(10px, 0.521vw);
}

.sl-subscribe__card-icon img {
    width: 100%;
}

/* Dashed divider below title row – accent color per card */
.sl-subscribe__card-divider {
    display: block;
    border: none;
    border-bottom: 1px dashed currentColor;
    border-image: repeating-linear-gradient(90deg, currentColor 0 7px, transparent 1px 12px) 1;
    margin: 0 0 max(12px, 0.625vw);
    opacity: 0.4;
}

.sl-subscribe__card-line {
    margin: 0;
    line-height: 1.2;
    text-align: left;
}

.sl-subscribe__card-line--accent {
    font-weight: 700;
    font-size: max(16px, 0.833vw);
}

.sl-subscribe__card-line--muted {
    color: var(--sl-text-muted);
    font-weight: 400;
    font-size: max(14px, 0.729vw);
    margin-top: max(5px, 0.26vw);
}

/* Card variants – accent color for divider, accent line and icon bg (white cards) */
.sl-subscribe__card--orange .sl-subscribe__card-divider,
.sl-subscribe__card--orange .sl-subscribe__card-line--accent {
    color: var(--sl-primary-color);
}

/* .sl-subscribe__card--orange .sl-subscribe__card-icon { background-color: var(--sl-primary-color); } */

.sl-subscribe__card--teal .sl-subscribe__card-divider,
.sl-subscribe__card--teal .sl-subscribe__card-line--accent {
    color: var(--sl-secondary-color);
}

/* .sl-subscribe__card--teal .sl-subscribe__card-icon { background-color: var(--sl-secondary-color); } */

.sl-subscribe__card--blue .sl-subscribe__card-divider,
.sl-subscribe__card--blue .sl-subscribe__card-line--accent {
    color: #4a5a9e;
}

/* .sl-subscribe__card--blue .sl-subscribe__card-icon { background-color: #4a5a9e; } */

.sl-subscribe__card--green .sl-subscribe__card-divider,
.sl-subscribe__card--green .sl-subscribe__card-line--accent {
    color: #2d8a3e;
}

/* .sl-subscribe__card--green .sl-subscribe__card-icon { background-color: #2d8a3e; } */

/* Priority Visits: accent line in dark gray (per SS) */
.sl-subscribe__card--blue .sl-subscribe__card-line--accent {
    color: var(--sl-text);
}

/* Keyframes for subscribe cards: slide-up + fade-in (mobile only) */
@keyframes sl-subscribe-card-in {
    from {
        opacity: 0;
        transform: translateY(28px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ========== Choose A Plan that fits – web row, mobile stacked ========== */
.sl-plans {
    padding: max(50px, 5.208vw) max(16px, 0.833vw);
    background: #293450;
    text-align: center;
}


/* When third card has reached top (stacked), header scrolls up with page */
.sl-plans.sl-plans--header-unstuck .sl-plans__header {
    /* position: sticky;
    top: 0; */
}

.sl-plans__title {
    font: 700 var(--sl-fs-section-title) var(--sl-font);
    color: var(--sl-bg-white);
    text-align: center;
    margin: 0 0 max(6px, 0.521vw);
}

.sl-plans__subtitle {
    font-size: var(--sl-fs-section-subtitle);
    color: var(--sl-bg-white);
    text-align: center;
    margin: 0 0 max(22px, 1.771vw);
}

/* Toggle switch – W3Schools-style: pill track, orange when active, white knob (see https://www.w3schools.com/howto/howto_css_switch.asp) */
.sl-plans__toggle {
    display: inline-flex;
    align-items: center;
    gap: max(12px, 0.625vw);
    margin: 0 auto max(34px, 1.771vw);
    font-size: max(14px, 0.729vw);
    font-weight: 600;
    font-family: var(--sl-font);
    color: var(--sl-bg-white);
}

.sl-plans__toggle-label {
    flex-shrink: 0;
    font-size: max(16px, 0.833vw);
    font-weight: 400;
}

.sl-plans__toggle-save {
    color: #58DB65;
    font-size: max(14px, 0.729vw);
    font-weight: 400;
    font-style: italic;
}

/* The switch – box around the slider */
.sl-plans__switch {
    position: relative;
    display: inline-block;
    width: max(50px, 2.604vw);
    height: max(28px, 1.458vw);
    flex-shrink: 0;
}

/* Hide default checkbox */
.sl-plans__switch-input {
    opacity: 0;
    width: 0;
    height: 0;
}

/* The slider (pill track) */
.sl-plans__slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--sl-primary-color);
    transition: 0.3s;
}

/* White circular knob */
.sl-plans__slider::before {
    position: absolute;
    content: "";
    height: max(20px, 1.042vw);
    width: max(20px, 1.042vw);
    left: max(4px, 0.208vw);
    bottom: max(4px, 0.208vw);
    background-color: var(--sl-bg-white);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
    transition: 0.3s;
}

.sl-plans__switch-input:checked+.sl-plans__slider {
    background-color: var(--sl-secondary-color);
}

.sl-plans__switch-input:focus+.sl-plans__slider {
    box-shadow: 0 0 0 2px rgba(255, 137, 39, 0.4);
}

/* Knob moves right when Quarterly selected (distance = track width − knob − padding) */
.sl-plans__switch-input:checked+.sl-plans__slider::before {
    transform: translateX(max(22px, 1.146vw));
}

/* Rounded pill */
.sl-plans__slider--round {

    border-radius: max(36px, 1.875vw);
}

.sl-plans__slider--round::before {
    border-radius: 50%;
}

/* Grid: 3 in a row when space allows; when one would wrap, all three go to column */
.sl-plans__grid {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: max(24px, 1.25vw);
    max-width: max(1840px, 95.833vw);
    margin: 0 auto;
    text-align: left;
    justify-content: center;
}

.sl-plans__card {
    flex: 0 0 calc((100% - 2 * max(24px, 1.25vw)) / 3);
    min-width: max(330px, 17.188vw);
    max-width: calc((100% - 2 * max(24px, 1.25vw)) / 3);
    position: relative;
    border-radius: max(20px, 1.042vw);
    /* overflow: hidden; */
    perspective: 1000px;
    /* min-height: max(430px, 22.396vw); */
    /* padding: max(20px, 2.083vw) 0; */
}
@media (min-width:991px) and (max-width:1069px) {
    .sl-plans__card{
        min-width: max(390px, 20.313vw);
    }
}
/* Web only: 4 columns. Tab and mobile use the base 3-column flex rule above. */
@media (min-width: 1424px) {
    .sl-plans__card {
        flex: 0 0 calc((100% - 3 * max(24px, 1.25vw)) / 4);
        max-width: calc((100% - 3 * max(24px, 1.25vw)) / 4);
    }
}

.sl-plans__card-flip-inner {
    position: relative;
    width: 100%;
    height: 100%;
    /* height: max(598px,31.146vw); */
    transition: transform 0.5s ease;
    border-radius: max(20px, 1.042vw);
    transform-style: preserve-3d;
}

.sl-plans__card.flipped .sl-plans__card-flip-inner {
    transform: rotateY(180deg);
}

.sl-plans__card-front {
    position: relative !important;
    height: 100%;
}

.sl-plans__card-front,
.sl-plans__card-back {
    position: absolute;
    inset: 0;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    padding: max(20px, 1.042vw);
    display: flex;
    flex-direction: column;
    border-radius: inherit;
    background: var(--sl-bg-white);
    overflow: hidden;
}

.sl-plans__card-back {
    transform: rotateY(180deg);
    border: 1px solid #ddd;
}

/* 5th+ feature items are moved to back by JS when card has "more" */

/* Faint radial wave in upper corner */
.sl-plans__card-bg {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    opacity: 1;
    background-image: radial-gradient(ellipse at top right, #ffc693 0%, transparent 72%);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* Starter: show bg image only when NO badge */
.sl-plans__card--starter:not(:has(.sl-plans__card-badge)) .sl-plans__card-bg {
    background: linear-gradient(to bottom, #ffc5932e 27%, transparent 82%), url(../images/membership-plans/pb1.svg) no-repeat top right / 75%;
}
/* Starter: badge present – gradient only, no image */
.sl-plans__card--starter:has(.sl-plans__card-badge) .sl-plans__card-bg {
    background: radial-gradient(ellipse at top right, #ffffff80 27%, transparent 82%);
}
/* Starter: gradient border only when badge present */
.sl-plans__card--starter:has(.sl-plans__card-badge) .sl-plans__card-front::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    z-index: 0;
    pointer-events: none;
    padding: max(5px, 0.26vw);
    box-sizing: border-box;
    background: linear-gradient(180deg, rgb(255 184 124) 0%, rgb(255 245 236) 61%, rgb(255 137 39 / 0%) 70%, rgb(255 137 39 / 0%) 100%);
    -webkit-mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff);
    -webkit-mask-composite: xor;
    mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff);
    mask-composite: exclude;
}

/* Advantage: badge present – gradient only, no image */
.sl-plans__card--advantage .sl-plans__card-bg {
    background: radial-gradient(ellipse at top right, #ffffff61 50%, transparent 72%);
}
/* Advantage: show abstract bg image only when NO badge */
.sl-plans__card--advantage:not(:has(.sl-plans__card-badge)) .sl-plans__card-bg {
    background: linear-gradient(to bottom, #42d7e517 27%, transparent 82%), url(../images/membership-plans/pb2.svg) no-repeat top right / 60%;
    /* TODO: replace advantage-card-bg.svg with the actual image path once provided */
}
/* Advantage: gradient border only when badge present */
.sl-plans__card--advantage:has(.sl-plans__card-badge) .sl-plans__card-front::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    z-index: 0;
    pointer-events: none;
    padding: max(5px, 0.26vw);
    box-sizing: border-box;
    background: linear-gradient(180deg, rgb(162 219 224) 0%, rgb(226 233 234) 40%, rgb(45 189 202 / 0%) 70%, rgb(45 189 202 / 0%) 100%);
    -webkit-mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff);
    -webkit-mask-composite: xor;
    mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff);
    mask-composite: exclude;
}

/* Premium: show bg image only when NO badge */
.sl-plans__card--premium:not(:has(.sl-plans__card-badge)) .sl-plans__card-bg {
    background: linear-gradient(to left bottom, #29345026 7%, transparent 82%), url(../images/membership-plans/pb3.svg) no-repeat top right / 60%;
}
/* Premium: badge present – gradient only, no image */
.sl-plans__card--premium:has(.sl-plans__card-badge) .sl-plans__card-bg {
    background: radial-gradient(ellipse at top right, #8489af00 0%, transparent 72%);
}
/* Premium: gradient border only when badge present */
.sl-plans__card--premium:has(.sl-plans__card-badge) .sl-plans__card-front::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    z-index: 0;
    pointer-events: none;
    padding: max(5px, 0.26vw);
    box-sizing: border-box;
    background: linear-gradient(181deg, rgb(187 191 204) 0, rgb(211 212 218) 40%, rgb(41 52 80 / 0%) 70%, rgb(41 52 80 / 0%) 100%);
    -webkit-mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff);
    -webkit-mask-composite: xor;
    mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff);
    mask-composite: exclude;
}

/* "Most Popular" badge – top-right, light teal pill (only on Advantage card) */
.sl-plans__card-badge {
    position: absolute;
    top: max(16px, 0.833vw);
    right: max(16px, 0.833vw);
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: max(4px, 0.208vw);
    padding: max(6px, 0.313vw) max(12px, 0.625vw);
    border-radius: 0 0 0 max(20px, 1.042vw);
    background: var(--sl-secondary-color-light);
    color: var(--sl-plans-advantage);
    font-size: max(12px, 0.625vw);
    font-weight: 700;
}

/* Advantage card: badge with dark border, dark blue text, slight overlap top-right */
.sl-plans__card--advantage .sl-plans__card-badge {
    top: max(5px, 0.26vw);
    right: max(5px, 0.26vw);
    background: #BEEBEF;
    color: #1B7179;
    font-size: max(12px, 0.625vw);
    font-weight: 700;
}

.sl-plans__card--advantage .sl-plans__card-badge:before {
    content: '';
    position: absolute;
    top: 0;
    right: 108px;
    width: 18px;
    height: 18px;
    background: url(../images/membership-plans/Right_Corner.svg) no-repeat center center / contain;
    z-index: 1;
}

.sl-plans__card--advantage .sl-plans__card-badge:after {
    content: '';
    position: absolute;
    top: 30px;
    right: 0;
    width: 18px;
    height: 18px;
    background: url(../images/membership-plans/Right_Corner.svg) no-repeat center center / contain;
    z-index: 1;
}

/* Starter card badge – orange theme */
.sl-plans__card--starter .sl-plans__card-badge {
    top: max(5px, 0.26vw);
    right: max(5px, 0.26vw);
    background: #ffdbbd;
    color: #985217;
    font-size: max(12px, 0.625vw);
    font-weight: 700;
}

.sl-plans__card--starter .sl-plans__card-badge:before {
    content: '';
    position: absolute;
    top: 0;
    right: 108px;
    width: 18px;
    height: 18px;
    background: url(../images/membership-plans/orgshape.svg) no-repeat center center / contain;
    z-index: 1;
}

.sl-plans__card--starter .sl-plans__card-badge:after {
    content: '';
    position: absolute;
    top: 30px;
    right: 0;
    width: 18px;
    height: 18px;
    background: url(../images/membership-plans/orgshape.svg) no-repeat center center / contain;
    z-index: 1;
}

/* Premium card badge – dark navy theme */
.sl-plans__card--premium .sl-plans__card-badge {
    top: max(5px, 0.26vw);
    right: max(5px, 0.26vw);
    background: #bec1ca;
    color: var(--sl-plans-premium);
    font-size: max(12px, 0.625vw);
    font-weight: 700;
}

.sl-plans__card--premium .sl-plans__card-badge:before {
    content: '';
    position: absolute;
    top: 0;
    right: 108px;
    width: 18px;
    height: 18px;
    background: url(../images/membership-plans/grayshape.svg) no-repeat center center / contain;
    z-index: 1;
}

.sl-plans__card--premium .sl-plans__card-badge:after {
    content: '';
    position: absolute;
    top: 30px;
    right: 0;
    width: 18px;
    height: 18px;
    background: url(../images/membership-plans/grayshape.svg) no-repeat center center / contain;
    z-index: 1;
}

.sl-plans__card-title {
    font: 700 max(18px, 0.938vw) var(--sl-font);
    color: var(--sl-text);
    margin: 0 0 max(4px, 0.208vw);
    line-height: 1.25;
    position: relative;
}

.sl-plans__card-desc {
    font-size: max(14px, 0.729vw);
    color: var(--sl-text);
    margin: 0 0 max(16px, 0.833vw);
    line-height: 1.35;
    position: relative;

}

.sl-plans__card-price {
    margin: 0 0 max(16px, 0.833vw);
    position: relative;
}

.sl-plans__card-amount {
    font: 700 max(42px, 2.604vw) var(--sl-font);
    color: var(--sl-text);
    letter-spacing: -0.02em;
    font-weight: 700;
}

.sl-plans__card-period {
    font-size: max(16px, 0.833vw);
    color: var(--sl-text-muted);
    font-weight: 400;
}

/* Dashed line between price and features */
.sl-plans__card-divider {
    display: block;
    border: none;
    border-bottom: 1px dashed transparent;
    border-image: repeating-linear-gradient(90deg, rgba(0, 0, 0, 0.14) 0 6px, transparent 1px 10px) 1;
    margin: 0 0 max(16px, 0.833vw);
}

.sl-plans__card-features {
    list-style: none;
    margin: 0 0 0;
    padding: 0;
    position: relative;
}

.sl-plans__card-features li {
    display: flex;
    align-items: start;
    gap: max(8px, 0.417vw);
    padding: 0;
    font-size: max(14px, 0.729vw);
    line-height: 1.3;
    color: var(--sl-text);
    margin-bottom: max(16px, 0.833vw);
    word-break: break-all;
}

.sl-plans__card-features-wrap {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
    z-index: 0;
    position: relative;
}

.sl-plans__check {
    flex-shrink: 0;
    width: max(18px, 0.938vw);
    height: max(18px, 0.938vw);
    min-width: 18px;
    min-height: 18px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6em;
    color: var(--sl-bg-white);
    line-height: 1;
    font-weight: 700;
}

.sl-plans__check img{
    width: 100%;
}
.sl-plans__card--advantage .sl-plans__card-features li {
    color: var(--sl-text);
}

/* Advantage: light grey circle, teal checkmark */
.sl-plans__card--advantage .sl-plans__check {
    color: var(--sl-plans-advantage);
}

/* Only show "See more" when this card has more than 4 feature points (class set by JS) */
.sl-plans__card-more-wrap {
    display: none;
    text-align: center;
    margin-bottom: max(14px, 0.729vw);
    padding-top: max(12px, 0.625vw);
    border-top: 1px dashed transparent;
    border-image: repeating-linear-gradient(90deg, rgba(0, 0, 0, 0.14) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--starter .sl-plans__card-more-wrap {
    border-image: repeating-linear-gradient(90deg, rgba(255, 137, 39, 0.4) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--advantage .sl-plans__card-more-wrap {
    border-image: repeating-linear-gradient(90deg, rgba(27, 113, 121, 0.35) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--premium .sl-plans__card-more-wrap {
    border-image: repeating-linear-gradient(90deg, rgba(41, 52, 80, 0.35) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--has-more .sl-plans__card-more-wrap {
    display: block;
    margin-top:auto;
}

.sl-plans__card-more {
    font-size: max(14px, 0.729vw);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: max(4px, 0.208vw);
    cursor: pointer;
}
.sl-plans__card-more img{
    width:max(20px,1.042vw);
    height:auto;
}
.sl-plans__card--starter .sl-plans__card-more {
    color: var(--sl-primary-color);
}

.sl-plans__card--advantage .sl-plans__card-more {
    color: var(--sl-plans-advantage);
}

.sl-plans__card--premium .sl-plans__card-more {
    color: var(--sl-plans-premium);
}
@media (max-width:992px) {
    .sl-plans__details,.sl-plans__card-desc{
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;  
        overflow: hidden;
        /* height: 100%; */
        text-overflow: ellipsis;
    }
    .sl-plans__card-desc{
        min-height: 35px;
    }
    .sl-plans__card-flip-inner{
        height: max(581px,30.26vw);
        /* height: max(598px, 31.146vw); */
    }
    .sl-plans__card-value-box{
        min-height: max(139px, 7.24vw);
    }
}

/* Back face: more benefits */
.sl-plans__card-back-title {
    font: 700 max(17px, 0.885vw) var(--sl-font);
    color: var(--sl-text);
    margin: 0 0 max(10px, 0.521vw);
    position: relative;
}

.sl-plans__card-back-content {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
}
/* "Back to Front" button on the back face — same behavior as .sl-plans__card-less,
   but rendered as a prominent full-width pill at the top of the back content.
   Background tint follows the card variant via --sl-plans-back-btn-bg, set
   per-variant on the card root so dynamically-appended cards inherit the
   correct theme as long as they carry an .sl-plans__card--{variant} class. */

.sl-plans__card-back-btn-wrap {
    margin-bottom: max(14px, 0.729vw);
}

.sl-plans__card-back-btn {
    display: flex;
    align-items: center;
    gap: max(10px, 0.521vw);
    width: 100%;
    border: 0;
    border-radius: max(16px, 0.833vw);
    padding: max(12px, 0.625vw) max(18px, 0.781vw);
    font: 600 max(14px, 0.729vw) var(--sl-font);
    color: var(--sl-text);
    background: var(--sl-plans-back-btn-bg, rgba(0, 0, 0, 0.06));
    cursor: pointer;
    transition: filter 0.2s ease;
}

.sl-plans__card-back-btn:hover,
.sl-plans__card-back-btn:focus {
    filter: brightness(0.96);
}

.sl-plans__card-back-btn-arrow {
    width: max(18px, 0.938vw);
    height: auto;
    flex-shrink: 0;
}

/* Per-variant tint — uses each plan's primary color at low alpha */
.sl-plans__card--starter   { --sl-plans-back-btn-bg: rgba(255, 137, 39, 0.22); }
.sl-plans__card--advantage { --sl-plans-back-btn-bg: rgba(45, 189, 202, 0.22); }
.sl-plans__card--premium   { --sl-plans-back-btn-bg: rgba(41, 52, 80, 0.18);  }

.sl-plans__card-features-more {
    list-style: none;
    margin: 0 0 max(14px, 0.729vw);
    padding: 0;
    position: relative;
    flex: 1 1 auto;
    max-height: 100%;
    overflow-y: auto;
}

.sl-plans__card-features-more li {
    display: flex;
    align-items: center;
    gap: max(8px, 0.417vw);
    padding: max(5px, 0.26vw) 0;
    font-size: max(13px, 0.677vw);
    line-height: 1.3;
    color: var(--sl-text);
}


.sl-plans__card--advantage .sl-plans__card-features-more li {
    color: var(--sl-text);
}

.sl-plans__card--advantage .sl-plans__card-features-more .sl-plans__check {
    background: #e8e8e8;
    color: var(--sl-plans-advantage);
}


/* Back: "See less" link area (dashed line + link with up arrow) */
.sl-plans__card-less-wrap {
    border-top: 1px dashed transparent;
    padding-top: max(12px, 0.625vw);
    margin-top: auto;
    text-align: center;
    margin-bottom: max(14px, 0.729vw);
}

.sl-plans__card--starter .sl-plans__card-less-wrap {
    border-image: repeating-linear-gradient(90deg, rgba(255, 137, 39, 0.4) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--advantage .sl-plans__card-less-wrap {
    border-image: repeating-linear-gradient(90deg, rgba(27, 113, 121, 0.35) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--premium .sl-plans__card-less-wrap {
    border-image: repeating-linear-gradient(90deg, rgba(41, 52, 80, 0.35) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card-less {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin: 0;
    padding: 0;
    width: auto;
    border: none;
    background: none;
    font: inherit;
    font-size: max(14px, 0.729vw);
    color: var(--sl-text);
    cursor: pointer;
    text-decoration: none;
    transition: opacity 0.2s;
}

.sl-plans__card-less:hover {
    opacity: 0.85;
}

.sl-plans__card--starter .sl-plans__card-less {
    color: var(--sl-primary-color);
}

.sl-plans__card--advantage .sl-plans__card-less {
    color: var(--sl-plans-advantage);
}

.sl-plans__card--premium .sl-plans__card-less {
    color: var(--sl-plans-premium);
}

.sl-plans__card-less-arrow {
    width: max(20px, 1.042vw);
    height: auto;
    transform: rotate(180deg);
}

/* CTA: full-width, pill, pinned to bottom for equal-height alignment */
.sl-plans__card-cta {
    margin-top: auto;
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: max(12px, 0.625vw) max(18px, 0.938vw);
    border-radius: max(50px, 2.604vw);
    font-weight: 700;
    font-size: max(13px, 0.677vw);
    text-align: center;
    text-decoration: none;
    border: none;
    cursor: pointer;
    color: var(--sl-bg-white);
    box-sizing: border-box;
}
.sl-plans__card-cta img{
    width:max(24px,1.25vw);
    height:auto;
}

.sl-plans__card-cta--starter {
    background: var(--sl-primary-color);
    box-shadow: 0 8px 17px 0 var(--orange-1-light-active, #FFDABC);

}

.sl-plans__card-cta--advantage {
    background: linear-gradient(135deg, #2DBDCA 0%, #25a8b4 100%);
    box-shadow: 0 8px 17px 0 rgba(45, 189, 202, 0.25);
}

.sl-plans__card-cta--premium {
    background: var(--sl-plans-premium);
    box-shadow: 0 8px 17px 0 rgba(41, 52, 80, 0.20);

}

.sl-plans__card-cta:hover {
    opacity: 0.95;
}

.sl-plans__card-value-box {
    border-radius: max(20px, 1.042vw);
    padding: max(20px, 1.042vw);
    margin-bottom: max(16px, 0.833vw);
    position: relative;
    backdrop-filter: blur(2px);
    z-index: 1;
    /* min-height: max(139px,7.24vw); */
}

.sl-plans__card-value-box .sl-plans__card-price {
    margin-bottom: max(12px, 0.625vw);
}

.sl-plans__card-value-box .sl-plans__card-divider {
    margin-bottom: max(12px, 0.625vw);
}

.sl-plans__card--starter .sl-plans__card-value-box {
    background:linear-gradient(to bottom, rgb(252 224 199 / 45%) 0%, rgb(254 198 143 / 27%) 50%, rgb(255 201 156 / 20%) 100%);
}

.sl-plans__card--advantage .sl-plans__card-value-box {
    background: linear-gradient(to bottom, rgb(45 189 202 / 13%) 0%, rgba(45, 189, 202, 0.10) 50%, rgba(45, 189, 202, 0.10) 100%);
}

.sl-plans__card--premium .sl-plans__card-value-box {
    background: linear-gradient(to bottom, rgb(190 193 202 / 37%) 0%, rgb(190 193 202 / 38%) 50%, rgb(190 193 202 / 23%) 100%);
}

.sl-plans__card--advantage .sl-plans__card-value-box .sl-plans__card-divider {
    border-image: repeating-linear-gradient(90deg, rgba(45, 189, 202, 0.45) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--premium .sl-plans__card-value-box .sl-plans__card-divider {
    border-image: repeating-linear-gradient(90deg, rgba(41, 52, 80, 0.35) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card-activation-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: max(8px, 0.417vw);
    font-size: max(16px, 0.833vw);
    color: var(--sl-text);
}

.sl-plans__card-activation-label {
    display: inline-flex;
    align-items: center;
    gap: max(4px, 0.208vw);
    color: var(--sl-text-muted);
}

.sl-plans__card-activation-amount {
    font-weight: 600;
    color: var(--sl-text-muted);
    white-space: nowrap;
}

.sl-plans__info-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
}

.sl-plans__info-btn {
    width: max(18px, 0.938vw);
    height: max(18px, 0.938vw);
    min-width: 18px;
    min-height: 18px;
    padding: 0;
    margin: 0;
    border: none;
    border-radius: 50%;
    background: #9ca3af;
    color: var(--sl-bg-white);
    font-size: max(11px, 0.573vw);
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.sl-plans__info-btn:hover,
.sl-plans__info-btn:focus-visible {
    background: #6b7280;
    outline: none;
}

.sl-plans__info-btn:focus-visible {
    box-shadow: 0 0 0 2px var(--sl-bg-white), 0 0 0 4px var(--sl-primary-color);
}

.sl-plans__card--advantage .sl-plans__info-btn:focus-visible {
    box-shadow: 0 0 0 2px var(--sl-bg-white), 0 0 0 4px var(--sl-plans-advantage);
}

.sl-plans__card--premium .sl-plans__info-btn:focus-visible {
    box-shadow: 0 0 0 2px var(--sl-bg-white), 0 0 0 4px var(--sl-plans-premium);
}

.sl-plans__tooltip {
    position: absolute;
    left: 50%;
    z-index: 30;
    width: 100%;
    max-width: min(178px, calc(100vw - 48px));
    min-width: max(158px,8.229vw);
    box-sizing: border-box;
    transform: translateX(-50%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.15s ease, visibility 0.15s ease;
    /* background-color: #ffffff; */
}

.sl-plans__tooltip--opens-down {
    top: 100%;
    margin-top: max(6px, 0.313vw);
}

.sl-plans__tooltip--opens-up {
    bottom: 100%;
    margin-bottom: max(6px, 0.313vw);
}

.sl-plans__info-wrap:hover .sl-plans__tooltip,
.sl-plans__info-wrap:focus-within .sl-plans__tooltip,
.sl-plans__info-wrap--open .sl-plans__tooltip {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.sl-plans__tooltip-inner {
    position: relative;
    background: var(--sl-bg-white);
    border-radius: max(8px, 0.417vw);
    padding: max(8px, 0.417vw) max(10px, 0.521vw);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    text-align: left;
    box-sizing: border-box;
}

.sl-plans__tooltip--opens-down .sl-plans__tooltip-inner::before {
    content: '';
    position: absolute;
    top: -5px;
    left: 50%;
    margin-left: -5px;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-bottom: 5px solid var(--sl-bg-white);
    filter: drop-shadow(0 -1px 1px rgba(0, 0, 0, 0.05));
}

.sl-plans__tooltip--opens-up .sl-plans__tooltip-inner::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 50%;
    margin-left: -5px;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 5px solid var(--sl-bg-white);
    filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.05));
}

.sl-plans__tooltip-title {
    margin: 0 0 max(6px, 0.313vw);
    font: 800 max(14px, 0.729vw) var(--sl-font);
    color: var(--sl-text);
}

.sl-plans__tooltip-title--plain {
    margin-bottom: max(6px, 0.313vw);
}

.sl-plans__tooltip-dash {
    display: block;
    border: none;
    border-bottom: 1px dashed transparent;
    border-image: repeating-linear-gradient(90deg, rgba(0, 0, 0, 0.14) 0 6px, transparent 1px 10px) 1;
    margin: 0 0 max(6px, 0.313vw);
}

.sl-plans__tooltip-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sl-plans__tooltip-list li {
    display: flex;
    align-items: flex-start;
    gap: max(6px, 0.313vw);
    font-size: max(14px, 0.729vw);
    line-height: 1.3;
    color: var(--sl-text);
    font-weight: 400;
    margin-bottom: max(6px, 0.313vw);
}

.sl-plans__tooltip-list li:last-child {
    margin-bottom: 0;
}

.sl-plans__tooltip-check {
    flex-shrink: 0;
    width: max(18px, 0.938vw);
    height: max(18px, 0.938vw);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.sl-plans__tooltip-check img {
    width: 100%;
    height: auto;
    display: block;
}

.sl-plans__tooltip-breakdown {
    display: flex;
    flex-direction: column;
    gap: max(4px, 0.208vw);
    margin-bottom: max(6px, 0.313vw);
}

.sl-plans__tooltip-breakdown-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: max(8px, 0.417vw);
    font-size: max(14px, 0.729vw);
    font-weight: 400;
    color: var(--sl-text);
}

.sl-plans__tooltip-breakdown-row--total {
    margin-top: 0;
    margin-bottom: 0;
    font-weight: 700;
}

.sl-plans__card-divider--after-features {
    margin-top: max(4px, 0.208vw);
    margin-bottom: max(12px, 0.625vw);
}

.sl-plans__card--starter .sl-plans__card-divider--after-features {
    border-image: repeating-linear-gradient(90deg, rgba(255, 137, 39, 0.4) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--advantage .sl-plans__card-divider--after-features {
    border-image: repeating-linear-gradient(90deg, rgba(45, 189, 202, 0.45) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card--premium .sl-plans__card-divider--after-features {
    border-image: repeating-linear-gradient(90deg, rgba(41, 52, 80, 0.35) 0 6px, transparent 1px 10px) 1;
}

.sl-plans__card-due-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: max(8px, 0.417vw);
    margin-bottom: max(16px, 0.833vw);
}

.sl-plans__card-due-label {
    display: inline-flex;
    align-items: center;
    gap: max(6px, 0.313vw);
    font-size: max(18px, 0.938vw);
    font-weight: 700;
}

.sl-plans__card-due-subtext {
    font-size: max(12px, 0.677vw);
    font-weight: 400;
    margin-top: max(5px,0.26vw);
}

.sl-plans__card-due-total {
    font-size: max(18px, 0.938vw);
    font-weight: 700;
}

.sl-plans__card--starter .sl-plans__card-due-label,
.sl-plans__card--starter .sl-plans__card-due-total {
    color: var(--sl-primary-color);
}

.sl-plans__card--advantage .sl-plans__card-due-label,
.sl-plans__card--advantage .sl-plans__card-due-total {
    color: var(--sl-plans-advantage);
}

.sl-plans__card--premium .sl-plans__card-due-label,
.sl-plans__card--premium .sl-plans__card-due-total {
    color: var(--sl-plans-premium);
}

/* ========== Common Questions – web cards, mobile accordion ========== */
.sl-cq {
    padding: max(50px, 5.208vw) max(16px, 0.833vw);
    background: var(--sl-bg-gray-light);
    text-align: center;
}

.sl-cq__title {
    font: 700 var(--sl-fs-section-title) var(--sl-font);
    color: var(--sl-text);
    margin: 0 0 max(6px, 0.521vw);
}

.sl-cq__subtitle {
    font-size: var(--sl-fs-section-subtitle);
    color: var(--sl-text);
    margin: 0 0 max(30px, 2.604vw);
}

/* Web: 4 cards in a row */
.sl-cq__list {
    display: flex;
    justify-content: center;
    gap: max(16px, 1.25vw);
    margin: 0 auto max(30px, 2.604vw);
    text-align: left;
}

.sl-cq__item {
    background-color: #f3f4f7;
    border-radius: max(16px, 0.833vw);
    border: 1px solid #E9E9E9;
    overflow: hidden;
    /* padding: max(20px, 1.042vw); */
    box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.03);
    max-width: max(342px, 17.813vw);
    width: 100%;
}

.sl-cq__trigger {
    display: block;
    width: 100%;
    border: none;
    background-color: var(--sl-bg-white);
    color: var(--sl-text);
    padding: max(16px, 0.833vw);
    text-align: left;
}
.sl-cq__trigger:focus{
    outline: none;
}
.sl-cq__q {
    font-weight: 500;
    font-size: max(16px, 0.833vw);
    color: var(--sl-text);
}

.sl-cq__icon {
    display: none;
}

.sl-cq__a {
    font-size: max(16px, 0.833vw);
    color: var(--sl-text-muted);
    padding: max(16px, 0.833vw);
    font-weight: 600;
    transition: all 0.35s ease;
}

.sl-cq__cta {
    text-align: center;
    position: relative;
}

.sl-cq__cta-text {
    font-size: max(14px, 0.938vw);
    color: var(--sl-text);
    font-weight: 600;
    margin: 0 0 max(10px, 0.521vw);
}

.sl-cq__cta-line {
    height: 2px;
    background: var(--sl-primary-color);
    margin: 0 auto;
    opacity: 0.2;
    position: absolute;
    bottom: 25%;
    width: 80%;
    inset-inline: 0;
    z-index: 0;
}

.sl-cq__btn {
    display: inline-block;
    font-size: max(16px, 0.833vw);
    background: var(--sl-primary-color);
    color: var(--sl-bg-white);
    padding: max(14px, 0.729vw) max(20px, 1.042vw);
    border-radius: max(50px, 2.604vw);
    font-weight: 700;
    text-decoration: none;
    border: none;
    position: relative;
    cursor: pointer;
}

.sl-cq__btn::before,
.sl-cq__btn::after {
    content: '';
    position: absolute;
    top: 0;
    width: max(30px, 1.563vw);
    height: 100%;
    background: var(--sl-bg-gray-light);
}

.sl-cq__btn::before {
    left: min(-30px, -1.563vw);
}

.sl-cq__btn::after {
    right: min(-30px, -1.563vw);
}

.sl-cq__btn:hover {
    opacity: 0.95;
    color: var(--sl-bg-white);
}

/* ========== Review section (web + mobile) ========== */
.sl-review {
    padding: max(50px, 5.208vw) max(16px, 0.833vw);
    text-align: center;
}

.sl-review__inner {
    max-width: max(80%, 75vw);
    margin: 0 auto;
}

.sl-review__title {
    font: 700 var(--sl-fs-section-title) var(--sl-font);
    color: var(--sl-text);
    margin: 0 0 max(6px, 1.875vw);
    line-height: 1.25;
}

.sl-review__rating-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: max(8px, 0.52vw);
    margin: 0 auto max(30px, 2.604vw);
    position: relative;
}

.sl-review__line {
    flex: 1;
    height: max(2px, 0.104vw);
    background: var(--sl-primary-color);
    align-self: center;
    opacity: 0.2;
}

.sl-review__line--left {
    order: -2;
}

.sl-review__line--right {
    order: 2;
}

.sl-review__wreath {
    display: inline-flex;
    color: var(--sl-primary-color);
}

.sl-review__wreath--left {
    order: -1;
}

.sl-review__wreath--right {
    order: 1;
}

.sl-review__wreath--right svg {
    transform: scaleX(-1) rotateY(180deg);
}

.sl-review__wreath svg {
    width: max(36px, 2.5vw);
    height: auto;
}

.sl-review__count {
    font: 700 max(16px, 2.188vw) var(--sl-font);
    color: var(--sl-primary-color);
}

.sl-review__rating-stars {
    display: flex;
    align-items: center;
    gap: max(4px, 0.208vw);
    flex-direction: column;
}

.sl-review__stars {
    color: var(--sl-primary-color);
    display: flex;
    align-items: center;
    gap: max(8px, 0.417vw);
    margin-inline: max(8px, 0.417vw);
}

.sl-review__label {
    font: 700 max(16px, 2.188vw) var(--sl-font);
    color: var(--sl-text-muted);
}

.sl-review__subtitle {
    font-size: max(12px, 1.042vw);
    color: var(--sl-text-muted);
    margin: 0;
    font-weight: 400;
}

.sl-review__wreath svg {
    width: max(24px, 2.396vw);
}

.sl-review__rating-stars>div>span>span {
    width: max(16px,2.448vw);
    /* display: block; */
}

.sl-review__rating-stars svg,.sl-review__rating-stars img {
    width: 100%;
}

/* Review cards slider */
.sl-review__slider-wrap {
    margin-top: max(30px, 2.604vw);
    padding: 0 max(8px, 0.5vw);
    position: relative;
}

.sl-review__nav {
    position: absolute;
    bottom: max(24px, 1.56vw);
    right: max(32px, 2vw);
    display: flex;
    gap: max(8px, 0.5vw);
    z-index: 2;
    pointer-events: none;
}


.sl-review__swiper {
    overflow: hidden;
    padding-bottom: max(12px, 0.8vw);
}

.sl-review-card {
    display: flex;
    flex-direction: row;
    background: var(--sl-bg-white);
    border-radius: max(16px, 1.25vw);
    overflow: hidden;
    min-height: max(280px, 18vw);
    padding: max(0px, 1.042vw);
    background: var(--sl-bg-gray-light);
    gap: max(10px, 1.25vw);
}

.sl-review-card__media {
    position: relative;
    flex: 0 0 50%;
    min-height: max(280px, 24vw);
    background: #e8e8e8;
    overflow: hidden;
    border-radius: max(16px, 1.25vw);

}

.sl-review-card__media video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    cursor: pointer;
}

.sl-review-card__thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.sl-review-card__badge {
    position: absolute;
    top: max(12px, 0.8vw);
    right: max(12px, 0.8vw);
    display: inline-flex;
    align-items: center;
    gap: max(6px, 0.4vw);
    padding: max(10px, 0.729vw);
    background: var(--sl-bg-gray-light);
    color: var(--sl-text);
    font-size: max(10px, 0.833vw);
    font-weight: 700;
    border-radius: max(14px, 1.042vw);
}

.sl-review-card__badge img {
    flex-shrink: 0;
    width: max(20px, 1.25vw);
}

/* Video controls wrapper: hide after 4s of no interaction (YouTube-style) */
.sl-review-card__media-controls {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.sl-review-card__media-controls .sl-review-card__play,
.sl-review-card__media-controls .sl-review-card__pause {
    pointer-events: auto;
}

.sl-review-card__media--controls-hidden .sl-review-card__media-controls {
    opacity: 0;
    pointer-events: none;
}

.sl-review-card__media--controls-hidden .sl-review-card__media-controls .sl-review-card__play,
.sl-review-card__media--controls-hidden .sl-review-card__media-controls .sl-review-card__pause {
    pointer-events: none;
}

.sl-review-card__play,
.sl-review-card__pause {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: max(45px, 2.813vw);
    height: max(45px, 2.813vw);
    border-radius: 50%;
    background: var(--sl-primary-color);
    color: var(--sl-bg-white);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: opacity 0.2s;
}

.sl-review-card__play:hover,
.sl-review-card__pause:hover {
    opacity: 0.9;
}

.sl-review-card__play img {
    margin-left: 3px;
    width: 100%;
}

.sl-review-card__play[hidden],
.sl-review-card__pause[hidden] {
    display: none !important;
}

.sl-review-card__pause svg {
    width: 45%;
    height: 45%;
}

.sl-review-card__body {
    position: relative;
    flex: 1;
    padding: max(10px, 1.56vw);
    display: flex;
    flex-direction: column;
    min-width: 0;
    text-align: left;
    border-radius: max(16px, 1.25vw);
    overflow: hidden;
    background-color: var(--sl-bg-white);

}
.sl-review-card__details{
    margin-bottom: max(16px, 0.833vw);
}
.sl-review-card__accent {
    position: absolute;
    top: 0;
    right: 0;
    width: max(120px, 8vw);
    height: max(120px, 8vw);
    background: radial-gradient(ellipse at top right, rgba(45, 189, 202, 0.12) 0%, transparent 70%), url(../images/membership-plans/review-bg.svg) no-repeat center center / cover;
    pointer-events: none;
}

.sl-review-card__title {
    font: 700 max(22px, 1.458vw) var(--sl-font);
    color: #2C3A50;
    margin: 0 0 max(12px, 0.8vw);
    line-height: 1.3;
    max-width: 80%;
}

.sl-review-card__text {
    font-size: max(20px, 1.042vw);
    color: var(--sl-text);
    line-height: 1.5;
    margin: 0;
}

.sl-review-card__text strong {
    font-weight: 700;
}

.sl-review-card__author {
    display: flex;
    align-items: center;
    gap: max(12px, 0.8vw);
    margin-top: auto;
}

.sl-review-card__avatar {
    width: max(48px, 2.5vw);
    height: max(48px, 2.5vw);
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    overflow: hidden;
    border: 2px solid var(--sl-bg-gray-light);
}

.sl-review-card__author-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sl-review-card__name {
    font: 700 max(16px, 0.833vw) var(--sl-font);
    color: var(--sl-text);
}

.sl-review-card__location {
    font-size: max(14px, 0.729vw);
    color: var(--sl-text-muted);
}

.sl-review-card__nav {
    display: none;
    /* single nav outside swiper */
}

.sl-review-card__nav-btn {
    width: max(44px, 2.86vw);
    height: max(44px, 2.86vw);
    border-radius: 50%;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: opacity 0.2s;
    pointer-events: auto;

}

.sl-review-card__nav-btn--prev {
    background: var(--sl-bg-white);
    border: 1px solid #e0e0e0;
    color: var(--sl-text);
}

.sl-review-card__nav-btn--prev img,
.sl-review-card__nav-btn--next img {
    width: max(24px, 1.25vw);
    height: max(24px, 1.25vw);
}

.sl-review-card__nav-btn--next {
    background: var(--sl-primary-color);
    color: var(--sl-bg-white);
    transform: rotate(180deg);
}

.sl-review-card__nav-btn--next img {
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%);
}

.sl-review-card__nav-btn:hover {
    opacity: 0.9;
}

/* Testimonial cards slider: web = 4 cards, mobile = 1 card */
.sl-testimonials {
    margin-top: max(30px, 2.604vw);
}

.sl-testimonials__swiper-wrap {
    position: relative;
    margin-bottom: max(10px, 2vw);
}

/* Fade effect on both sides of the slider */
.sl-testimonials__fade {
    position: absolute;
    top: 0;
    bottom: max(16px, 1vw);
    width: max(48px, 4vw);
    max-width: 80px;
    pointer-events: none;
    z-index: 2;
}

.sl-testimonials__fade--left {
    left: 0;
    background: linear-gradient(to right, var(--sl-bg-white) 0%, rgba(255, 255, 255, 0) 100%);
}

.sl-testimonials__fade--right {
    right: 0;
    background: linear-gradient(to left, var(--sl-bg-white) 0%, rgba(255, 255, 255, 0) 100%);
}

.sl-testimonials__swiper {
    overflow: hidden;
    padding-bottom: max(16px, 1vw);
}

/* Equal height for all slider cards */
.sl-testimonials__swiper .swiper-wrapper {
    align-items: stretch;
    text-align: left;
}

.sl-testimonials__swiper .swiper-slide {
    height: auto;
    display: flex;
}

.sl-testimonials__swiper .swiper-slide .sl-testimonial-card {
    height: 100%;
    width: 100%;
    min-height: max(300px, 18.229vw);
}

.sl-testimonial-card {
    background: var(--sl-bg-gray-light);
    border-radius: max(16px, 0.833vw);
    padding: max(24px, 1.25vw);
    min-height: max(350px, 14vw);
    display: flex;
        flex-direction: column;
}

.sl-testimonial-card__stars {
    display: flex;
    gap: max(2px, 0.15vw);
    margin-bottom: max(24px, 1.25vw);
}

.sl-testimonial-card__star {
    width: max(24px, 1.25vw);
    height: max(24px, 1.25vw);
    flex-shrink: 0;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.sl-testimonial-card__star--filled {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23FF8927'%3E%3Cpath d='M21.96 10.77l-4.22 3.64.99 5.44c.07.3-.07.6-.18.74-.12.15-.39.27-.69.27-.14 0-.3-.03-.47-.1l-4.85-2.56-4.84 2.56c-.16.08-.33.11-.47.11-.3 0-.57-.12-.69-.27-.11-.14-.25-.44-.18-.74l.99-5.44-4.22-3.64c-.23-.2-.31-.5-.24-.75.07-.25.3-.43.58-.47l5.83-.53 2.36-4.78c.12-.24.35-.4.6-.4s.48.16.6.4l2.36 4.78 5.83.53c.28.04.51.22.58.47.07.25-.01.55-.24.75z'/%3E%3C/svg%3E");
}

/* Filled star with orange gradient (lighter left to deeper right) */
.sl-testimonial-card__star--gradient {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cdefs%3E%3ClinearGradient id='g' x1='0%25' y1='0%25' x2='100%25' y2='0%25'%3E%3Cstop offset='0%25' stop-color='%23FFB366'/%3E%3Cstop offset='100%25' stop-color='%23FF8927'/%3E%3C/linearGradient%3E%3C/defs%3E%3Cpath fill='url(%23g)' d='M21.96 10.77l-4.22 3.64.99 5.44c.07.3-.07.6-.18.74-.12.15-.39.27-.69.27-.14 0-.3-.03-.47-.1l-4.85-2.56-4.84 2.56c-.16.08-.33.11-.47.11-.3 0-.57-.12-.69-.27-.11-.14-.25-.44-.18-.74l.99-5.44-4.22-3.64c-.23-.2-.31-.5-.24-.75.07-.25.3-.43.58-.47l5.83-.53 2.36-4.78c.12-.24.35-.4.6-.4s.48.16.6.4l2.36 4.78 5.83.53c.28.04.51.22.58.47.07.25-.01.55-.24.75z'/%3E%3C/svg%3E");
}

.sl-testimonial-card__star--outline {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FF8927' stroke-width='1.5'%3E%3Cpath d='M12 2l3 6 6.5 1-4.7 4.6 1.1 6.4-5.9-3.1-5.9 3.1 1.1-6.4-4.7-4.6 6.5-1L12 2z'/%3E%3C/svg%3E");
}

/* Half-filled star (e.g. 4.5 rating): left half orange, right half outline */
.sl-testimonial-card__star--half {
    position: relative;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FF8927' stroke-width='1.5'%3E%3Cpath d='M12 2l3 6 6.5 1-4.7 4.6 1.1 6.4-5.9-3.1-5.9 3.1 1.1-6.4-4.7-4.6 6.5-1L12 2z'/%3E%3C/svg%3E");
}

.sl-testimonial-card__star--half::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 50%;
    height: 100%;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23FF8927'%3E%3Cpath d='M21.96 10.77l-4.22 3.64.99 5.44c.07.3-.07.6-.18.74-.12.15-.39.27-.69.27-.14 0-.3-.03-.47-.1l-4.85-2.56-4.84 2.56c-.16.08-.33.11-.47.11-.3 0-.57-.12-.69-.27-.11-.14-.25-.44-.18-.74l.99-5.44-4.22-3.64c-.23-.2-.31-.5-.24-.75.07-.25.3-.43.58-.47l5.83-.53 2.36-4.78c.12-.24.35-.4.6-.4s.48.16.6.4l2.36 4.78 5.83.53c.28.04.51.22.58.47.07.25-.01.55-.24.75z'/%3E%3C/svg%3E");
    background-size: 200% 100%;
    background-repeat: no-repeat;
    background-position: left center;
}


.sl-testimonial-card__text {
    font-size: max(20px, 1.042vw);
    color: var(--sl-text);
    margin: 0 0 max(16px, 1.04vw);
    flex: 1;
    font-weight: 500;
}

.sl-testimonial-card__author {
    display: flex;
    align-items: center;
    gap: max(10px, 0.65vw);
}

.sl-testimonial-card__icon {
    width: max(48px, 2.5vw);
    height: max(48px, 2.5vw);
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font: 700 max(18px, 1.15vw) var(--sl-font);
    color: var(--sl-bg-white);
    background-color: var(--sl-bg-white);
    overflow: hidden;
    border: 1px solid #e0e0e0;
}


.sl-testimonial-card__author-info {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.sl-testimonial-card__name {
    font: 700 max(16px, 0.833vw) var(--sl-font);
    color: var(--sl-text);
}

.sl-testimonial-card__location {
    font-size: max(14px, 0.729vw);
    color: var(--sl-text-muted);
}

/* Testimonials nav: orange line behind prev/next buttons (per design) */
.sl-testimonials__nav-wrap {
    /* padding-bottom: max(12px, 0.78vw); */
    padding-bottom: 0;
    position: relative;
    z-index: 2;
}

.sl-testimonials__nav-row {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: max(52px, 3.25vw);
}

/* Orange separator line behind the buttons (not a progress bar) */
.sl-testimonials__separator {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 100%;
    height: max(2px, 0.104vw);
    background: var(--sl-primary-color);
    border-radius: 2px;
    top: 50%;
    margin-top: max(-2px, -0.13vw);
    opacity: 0.2;
}

/* Buttons on top of the line: white (prev) + orange (next) */
.sl-testimonials__nav {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: max(16px, 1vw);
    background: var(--sl-bg-white);
    padding-inline: max(10px, 2vw);
    
}

.sl-testimonials__nav-btn {
    width: max(48px, 3vw);
    height: max(48px, 3vw);
    min-width: 48px;
    min-height: 48px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.2s;
    flex-shrink: 0;
}

.sl-testimonials__nav-btn img,
.sl-testimonials__nav-btn svg {
    width: max(22px, 1.35vw);
    height: max(22px, 1.35vw);
    display: block;
}

.sl-testimonials__nav-arrow-next {
    transform: rotate(180deg);
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%);
}

/* Prev: white circle, black left arrow */
.sl-testimonials__nav-btn--prev {
    background: var(--sl-bg-white);
    border: 1px solid #e0e0e0;
}

.sl-testimonials__nav-btn--prev img {
    filter: none;
}

/* Next: orange circle, white right arrow */
.sl-testimonials__nav-btn--next {
    background: var(--sl-primary-color);
    color: var(--sl-bg-white);
}

.sl-testimonials__nav-btn:hover {
    opacity: 0.9;
}

/* Keep testimonial nav buttons visible when Swiper adds swiper-button-lock */
.sl-testimonials__prev.swiper-button-lock,
.sl-testimonials__next.swiper-button-lock {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: none;
}

/* ========== Featured In & Trusted by (two logo sliders) ========== */
.sl-featured {
    background: var(--sl-bg-gray-light);
    padding: max(40px, 4.167vw) max(16px, 1vw);
}

.sl-featured__inner {
    max-width: max(80%, 75vw);
    margin: 0 auto;
}

.sl-featured__title {
    font: 700 max(24px, 2.188vw) var(--sl-font);
    color: var(--sl-text);
    text-align: center;
    margin: 0 0 max(12px, 1.042vw);
}

.sl-featured__subtitle,
.sl-featured__trusted {
    text-align: center;
    font-size: max(14px, 1.042vw);
    color: var(--sl-text-muted);
    margin: 0 0 max(30px, 2.5vw);
}

.sl-featured__subtitle--top {
    display: block;
}

.sl-featured__subtitle--mobile {
    display: none;
}

.sl-featured__slider-wrap {
    position: relative;
    padding: 0 max(44px, 2.86vw);
    margin-bottom: max(28px, 1.82vw);
}

.first_slider_wrap .sl-featured__logo img {
    max-height: max(70px, 3.646vw);
}

.sl-featured__swiper {
    overflow: hidden;
}

.sl-featured__swiper .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: center;
    height: max(60px, 3.9vw);
}

.sl-featured__logo {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0 max(16px, 1vw);
}

.sl-featured__logo-text {
    font: 700 max(14px, 0.9vw) var(--sl-font);
    color: var(--sl-text);
    white-space: nowrap;
}

.sl-featured__logo--muted .sl-featured__logo-text {
    color: var(--sl-text-muted);
    font-weight: 600;
}

.sl-featured__logo img {
    max-height: max(36px, 2.34vw);
    max-width: 100%;
    width: auto;
    object-fit: contain;
}

.sl-featured__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: max(36px, 1.875vw);
    height: max(36px, 1.875vw);
    border-radius: 50%;
    background: var(--sl-bg-white);
    border: 1px solid #e0e0e0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    transition: opacity 0.2s;
    filter: drop-shadow(2px 2px 20px rgba(0, 0, 0, 0.10));

}

.sl-featured__nav svg {
    width: max(18px, 1.15vw);
    height: max(18px, 1.15vw);
    color: var(--sl-text);
}

.sl-featured__nav--prev {
    left: 0;
}

.sl-featured__nav--next {
    right: 0;
}

.sl-featured__nav:hover {
    opacity: 0.9;
}

.sl-featured__divider {
    display: none;

}


/* ========== FAQ section: web = two columns, mobile = stacked ========== */
.sl-faq {
    padding: max(50px, 5.208vw) max(20px, 1.042vw);
}

.sl-faq__inner {
    max-width: 80%;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: max(24px, 4.01vw);
    align-items: start;
}

.sl-faq__head {
    display: flex;
    flex-direction: column;
    gap: max(20px, 1.042vw);
}

.sl-faq__title {
    font-size: max(24px, 2.188vw);
    font-weight: 700;
    color: var(--sl-text);
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.15em;
}



.sl-faq__video-wrap {
    position: relative;
    border-radius: max(12px, 1vw);
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
        aspect-ratio: 16 / 10;
    background: var(--sl-bg-gray-light);
    max-height: max(314px, 16.354vw);
}

.sl-faq__video-wrap .sl-faq__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    cursor: pointer;
}

/* FAQ video: reuse review section controls; hide when inactive */
.sl-faq__video-wrap--controls-hidden .sl-review-card__media-controls {
    opacity: 0;
    pointer-events: none;
}

.sl-faq__video-wrap--controls-hidden .sl-review-card__media-controls .sl-review-card__play,
.sl-faq__video-wrap--controls-hidden .sl-review-card__media-controls .sl-review-card__pause {
    pointer-events: none;
}

.sl-faq__content {
    display: flex;
    flex-direction: column;
    gap: max(16px, 1.5vw);
}

.sl-faq__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: max(22px, 1.146vw);
}

/* Show only first 5 questions when collapsed */
.sl-faq__list--collapsed .sl-faq__item:nth-child(n+6) {
    display: none;
    gap: max(22px, 1.146vw);
}

.sl-faq__item {
    background: var(--sl-bg-white);
    border-radius: max(16px, 0.833vw);
    overflow: hidden;
    border: 1px solid #D3D3D3;
}

.sl-faq__trigger {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: max(16px, 0.833vw);
    text-align: left;
    font: inherit;
    font-size: max(16px, 0.833vw);
    font-weight: 600;
    color: var(--sl-text);
    background: none;
    border: none;
    cursor: pointer;
    transition: background 0.2s;
}
.sl-faq__trigger:focus{
    outline: none;
}

.sl-faq__trigger:hover {
    background: rgba(0, 0, 0, 0.02);
}

.sl-faq__q {
    flex: 1;
    display: block;
}

.sl-faq__icon {
    flex-shrink: 0;
    width: max(24px, 1.25vw);
    height: max(24px, 1.25vw);
    border-radius: 50%;
    background: #d0d0d0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: background 0.2s;
}

.sl-faq__icon::before {
    content: '';
    width: 10px;
    height: 2px;
    background: var(--sl-bg-white);
    position: absolute;
}

.sl-faq__icon::after {
    content: '';
    width: 2px;
    height: 10px;
    background: var(--sl-bg-white);
    position: absolute;
    transition: transform 0.2s;
}

.sl-faq__item.is-open .sl-faq__icon {
    background: var(--sl-primary-color);
}

.sl-faq__item.is-open .sl-faq__icon::after {
    transform: rotate(90deg);
}

.sl-faq__icon,
.sl-faq__icon::after {
    transition: background 0.25s ease, transform 0.25s ease;
}

.sl-faq__answer {
    display: grid;
    grid-template-rows: 0fr;
    padding: 0 max(16px, 0.833vw);
    transition: grid-template-rows 0.4s cubic-bezier(0.4, 0, 0.2, 1), padding 0.35s ease;
}

.sl-faq__item.is-open .sl-faq__answer {
    grid-template-rows: 1fr;
    padding-top: 0;
    padding-bottom: max(16px, 0.833vw);
}

.sl-faq__answer-inner {
    overflow: hidden;
    min-height: 0;
}

.sl-faq__answer p {
    margin: 0;
    font-size: max(16px, 0.833vw);
    line-height: 1.5;
    color: var(--sl-text-muted);
}

.sl-faq__read-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: max(10px, 0.729vw) max(16px, 1.042vw);
    border-radius: max(50px, 2.5vw);
    border: 2px solid var(--sl-primary-color);
    background: var(--sl-bg-white);
    color: var(--sl-primary-color);
    font: inherit;
    font-weight: 700;
    font-size: var(--sl-fs-base);
    text-decoration: none;
    cursor: pointer;
    transition: opacity 0.2s, background 0.2s, color 0.2s;
}

.sl-faq__read-more:hover {
    opacity: 0.95;
    background: var(--sl-primary-color-light);
}




/* ========== Footer: web = 5 columns, mobile = 2x2 nav (Services|Popular, Products|Legal) ========== */
.sl-footer {
    position: relative;
    background: #BEEBEF;
    border-radius: max(30px, 5.208vw) max(30px, 5.208vw) 0 0;
    padding: max(30px, 7.292vw) max(16px, 1vw) 0 max(16px, 1vw);
    overflow: hidden;
}

.sl-footer__watermark {
    position: relative;

}

.sl-footer__watermark img {
    width: 80%;
    display: block;
    margin: auto;
}

.sl-footer__inner {
    position: relative;
    z-index: 1;
    max-width: 80%;
    margin: 0 auto max(25px, 2.604vw) auto;
}

.sl-footer__top {
    display: grid;
    grid-template-columns: auto auto auto auto 2fr;
    gap: max(32px, 2.8vw);
    /* align-items: start; */
    margin-bottom: 0;
}

.sl-footer__nav {
    display: contents;
}

.sl-footer__col {
    min-width: 0;
}

.sl-footer__heading {
    font-size: max(20px, 1.042vw);
    font-weight: 700;
    color: var(--sl-text);
    margin: 0 0 max(28px, 1.458vw);
}

.sl-footer__links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sl-footer__links li {
    margin-bottom: max(16px, 0.833vw);
}

.sl-footer__link {
    font-size: max(16px, 0.833vw);
    color: var(--sl-text);
    text-decoration: none;
    transition: color 0.2s;
}

.sl-footer__link:hover {
    color: var(--sl-primary-color);
}

.sl-footer__email-col {
    max-width: max(410px,21.354vw);
    justify-self: end;
    text-align: left;
    border-left: max(2px, 0.104vw) solid var(--sl-secondary-color);
    padding-left: max(40px, 2.083vw);
    padding-bottom: max(40px, 2.083vw);
    width: 100%;
}

.sl-footer__email-desc {
    font-size: max(16px, 0.833vw);
    color: var(--sl-text-muted);
    margin: 0 0 max(10px, 0.521vw);
}

.sl-footer__email-form {
    display: flex;
    align-items: stretch;
    gap: 0;
    margin-bottom: max(30px,1.563vw);
    margin-left: auto;
    margin-right: auto;
    position: relative;
}
@media (min-width:76px) {
    .sl-footer__email-form {
        margin-bottom: max(20px,1.042vw);
    }
}

.sl-footer__input {
    flex: 1;
    min-width: 0;
    padding: max(10px, 0.521vw);
    border-right: none;
    border: 0px;
    border-radius: max(14px, 0.729vw);
    font: inherit;
    font-size: max(14px, 0.85vw);
    background: var(--sl-bg-white);
    line-height: 2;
}

.sl-footer__submit {
    width: max(34px, 1.771vw);
    /* min-width: 56px; */
    border: none;
    border-radius: 0 max(12px, 0.7vw) max(12px, 0.7vw) 0;
    background: var(--sl-primary-color);
    color: var(--sl-bg-white);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: opacity 0.2s;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: max(10px, 0.521vw);
    border-radius: 12px;
    right: 0;
}

.sl-footer__submit:hover {
    opacity: 0.9;
}

/* App section: white card (web + mobile) */
.sl-footer__app-card {
    background: var(--sl-bg-white);
    border-radius: max(20px, 1.042vw);
    margin-bottom: max(30px, 1.563vw);
    margin-left: auto;
    margin-right: auto;
    border: 4px solid var(--sl-bg-white);
}
@media (min-width:992px){
    .sl-footer__app-card {
        margin-bottom: max(20px, 1.042vw);

    }
}
.sl-footer__app-desc {
    font-size: max(14px, 0.729vw);
    color: var(--sl-text);
    margin: max(13px, 0.677vw);
    text-align: center;
}

.sl-footer__app-desc--mobile {
    display: none;
}

.sl-footer__app-buttons {
    padding: max(20px, 1.042vw);
    display: flex;
    gap: max(12px, 0.8vw);
    border-radius: max(18px, 0.938vw);
    margin-bottom: 0;
    background-color: #E0F5F7;
    justify-content: center;
}

.sl-footer__app-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--sl-bg-white);
    font-size: max(12px, 0.7vw);
    font-weight: 600;
    text-decoration: none;
    border-radius: max(6px, 0.4vw);
    transition: opacity 0.2s;
    height: max(40px, 2.083vw);
}

.sl-footer__app-btn img {
    height: 100%;
}

.sl-footer__social {
    display: flex;
    flex-wrap: wrap;
    gap: max(5px, 0.8vw);
    list-style: none;
    margin: 0;
    padding: 0;
    justify-content: space-between;
}

.sl-footer__social-icon {
    width: max(40px, 2.5vw);
    height: max(40px, 2.5vw);
    border-radius: max(12px, 0.625vw);
    background: var(--sl-bg-white);
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: opacity 0.2s;
}

.sl-footer__social-icon img {
    width: max(24px, 1.25vw);
}

.sl-footer__social-icon:hover {
    opacity: 0.7;
}

/* Social icon brand colors xcvsd*/ 
.sl-footer__divider {
    display: block;
    height: max(2px, 0.104vw);
    background: var(--sl-secondary-color);
    margin-bottom: max(20px, 1.5vw);
}

.sl-footer__bottom {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: max(12px, 1vw);
}

.sl-footer__copyright,
.sl-footer__trademark {
    font-size: max(16px, 0.833vw);
    color: var(--sl-text);
    font-weight: 500;
}


/* ========== Media queries (all breakpoints at bottom, one block per breakpoint) ========== */
@media (max-width: 1400px) {
    .sl-banner {
        height: auto;
    }
}
@media (min-width: 768px) {

    /* Banner: tablet = 2x2 grid */
    .sl-banner__inner {
        flex-direction: row;
        min-height: max(280px, 17.7083333333vw);
    }

    .sl-banner__media {
        width: 50%;
        min-height: max(280px, 17.7083333333vw);
    }

    .sl-banner__body {
        width: 50%;
        padding: max(24px, 1.6666666667vw) max(28px, 2.0833333333vw);
        justify-content: center;
    }

    .sl-banner__content {
        padding: 0;
        padding-right: max(26px,2.344vw);
    }
}
@media (max-width: 992px) {
    /* Plans: Tuts+ stacking cards (mobile) – same effect at 768px and 767px */

    .sl-plans__grid {
        flex-direction: column;
        max-width: 100%;
    }

    .sl-plans__header {
        /* position: sticky; */
        /* top: max(50px, 2.604vw); */
    }

    .sl-plans__grid .sl-plans__card {
        max-width: none;
        /* width: 75%; */
        flex: 1 1 auto;
        margin: 0 auto;
        position: sticky;
        top: max(100px, 10.417vw);
        min-width: 0;
        width: 100%;
        padding-top: calc(var(--card-index, 1) * var(--sl-plans-card-offset));
        min-height: max(581px,30.26vw);
    }

    .sl-plans__grid {
        max-width: 75%;
        margin-bottom: 1rem;
    }

    .sl-plans__grid .sl-plans__card:nth-child(1) {
        --card-index: 1;
        z-index: 1;
    }

    .sl-plans__grid .sl-plans__card:nth-child(2) {
        --card-index: 2;
        z-index: 2;
        /* top:37%; */
    }

    .sl-plans__grid .sl-plans__card:nth-child(3) {
        --card-index: 3;
        z-index: 3;
    }

    .sl-plans__card--starter:not(:has(.sl-plans__card-badge)) .sl-plans__card-bg {
        background: linear-gradient(to bottom, #ffc5932e 27%, transparent 82%), url(../images/membership-plans/pb1.svg) no-repeat top right / 60%;
    }

    .sl-plans__card--premium:not(:has(.sl-plans__card-badge)) .sl-plans__card-bg {
        background: linear-gradient(to left bottom, #29345026 7%, transparent 82%), url('../images/membership-plans/Topology-1.svg') no-repeat top right / 38%;
    }

    /* FAQ: tablet = 2x2 grid */
    .sl-cq__list {
        flex-wrap: wrap;
    }

    .sl-cq__item {
        width: 50%;
    }

    /* review section */
    .sl-review__inner {
        max-width: 95%;
    }

    .sl-faq__inner {
        grid-template-columns: 1fr 1fr;
    }

    .sl-footer__top {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        margin-bottom: max(28px, 4vw);
    }

    .sl-footer__nav {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: max(32px, 5vw);
        border-bottom: 2px solid #2dbdca3d;
    }

    /* Mobile order: Row1 = Services, Popular; Row2 = Products, Legal */
    .sl-footer__col--services {
        order: 1;
    }

    .sl-footer__col--popular {
        order: 2;
    }

    .sl-footer__col--products {
        order: 3;
    }

    .sl-footer__col--legal {
        order: 4;
    }

    /* Email section: centered block via flex (no grid) */
    .sl-footer__email-col {
        align-self: center;
        width: 100%;
        max-width: 480px;
        text-align: center;
        padding-top: max(24px, 4vw);
        padding-left: 0;
        padding-bottom: 0;
        /* border-top: 2px solid #2dbdca3d; */
        border-left: none;
    }


    .sl-footer__email-form {
        max-width: 100%;

    }

    .sl-footer__app-desc--web {
        display: none;
    }

    .sl-footer__app-desc--mobile {
        display: block;
    }

    .sl-footer__app-card {
        max-width: 100%;
    }

    .sl-footer__social {
        justify-content: center;
    }


    .sl-footer__bottom {
        flex-direction: column;
        text-align: center;
        gap: max(8px, 2vw);
    }

    .sl-footer__copyright,
    .sl-footer__trademark {
        display: block;
        width: 100%;
        text-align: center;
    }

    .sl-footer__divider {
        display: none;
    }

}
@media (max-width: 767px) {

    /* Banner: mobile = single column, full-width cards */
    .sl-card__text {
        text-align: left;
    }

    .sl-banner__inner {
        min-height: auto;
    }

    .sl-banner__body {
        order: 1;
    }

    .sl-banner__media {
        order: 2;
        min-height: max(270px, 18.229vw);
    }

    .sl-banner__content {
        text-align: center;
        display: flex;
        flex-direction: column;
        padding-top: max(30px, 1.563vw);
        padding-bottom: 0;
        line-height: 1.5;
    }

    .sl-banner__title {
        order: 0;
        line-height: 1.5;
    }

    .sl-banner__tagline {
        order: 1;
        margin-top: 16px;
    }

    .sl-banner__disclaimer {
        order: 2;
    }

    .sl-banner__cta {
        order: 3;
    }

    .sl-banner__features:has(> .sl-card) {
        order: 4;
        min-height: inherit;
    }

    .sl-banner__features:not(:has(*)) {
        min-height: 0;
    }

    /* Subscribe: mobile = stacking cards (overlap + sticky) + entrance animation */
    .sl-subscribe.sl-subscribe .sl-subscribe__swiper--stacked {
        overflow: visible;
    }

    .sl-subscribe__swiper--stacked .swiper-wrapper {
        flex-direction: column;
        padding-bottom: max(20px, 1.042vw);
    }

    .sl-subscribe__swiper--stacked .swiper-slide {
        min-width: 0;
        position: sticky;
        top: max(50px, 5vw);
        z-index: 1;
        margin: 0 0 max(-28px, -3vw) 0 !important;
        opacity: 0;
        animation: sl-subscribe-card-in 0.5s ease-out forwards;
    }

    .sl-subscribe__swiper--stacked .swiper-slide:nth-child(1) { --sl-subscribe-card-index: 1; z-index: 1; animation-delay: 0.08s; }
    .sl-subscribe__swiper--stacked .swiper-slide:nth-child(2) { --sl-subscribe-card-index: 2; z-index: 2; animation-delay: 0.16s; }
    .sl-subscribe__swiper--stacked .swiper-slide:nth-child(3) { --sl-subscribe-card-index: 3; z-index: 3; animation-delay: 0.24s; }
    .sl-subscribe__swiper--stacked .swiper-slide:nth-child(4) { --sl-subscribe-card-index: 4; z-index: 4; animation-delay: 0.32s; }
    .sl-subscribe__swiper--stacked .swiper-slide:nth-child(5) { --sl-subscribe-card-index: 5; animation-delay: 0.4s; }
    .sl-subscribe__swiper--stacked .swiper-slide:nth-child(6) { --sl-subscribe-card-index: 6; animation-delay: 0.48s; }
    .sl-subscribe__header {
        position: sticky;
        top: 0%;
    }
    

    @media (prefers-reduced-motion: reduce) {
        .sl-subscribe__swiper--stacked .swiper-slide {
            animation: none;
            opacity: 1;
        }
    }

    /* Plans: mobile = single column, full-width cards */

    .sl-plans__grid {
        max-width: 100%;
    }

    /* FAQ: mobile = accordion (grid-based smooth open/close, tighter spacing) */

    .sl-cq__list {
        flex-direction: column;
    }

    .sl-cq__item {
        padding: 0;
        overflow: hidden;
        width: 100%;
        max-width: 100%;
    }

    .sl-cq__trigger {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        cursor: pointer;
    }

    .sl-cq__icon {
        display: block;
        width: 0;
        height: 0;
        border-left: 5px solid transparent;
        border-right: 5px solid transparent;
        border-top: 6px solid var(--sl-text);
        flex-shrink: 0;
        transition: transform 0.35s ease;
    }

    .sl-cq__item.is-open .sl-cq__icon {
        transform: rotate(180deg);
    }

    /* Bootstrap-style accordion: same transition for open and close (height .35s ease) */
    .sl-cq__a {
        margin: 0;
        border-top: none;
        padding: 0;
        background: rgba(0, 0, 0, 0.04);
        transition: all 0.35s ease;
        animation: sl-cq__a-inner-fade-in 0.35s ease;
        height: 0;
        font-weight: 400;
        opacity: 0;

    }

    .sl-cq__item.is-open .sl-cq__a {
        height: auto;
        opacity: 1;
    }

    .sl-cq__a-inner {
        overflow: hidden;
        min-height: 0;
        background-color: #F3F4F7;
    }

    .sl-cq__item.is-open .sl-cq__a-inner {
        color: var(--sl-text-muted);
        padding: max(16px, 0.833vw);

    }

    .sl-cq__cta-line {
        width: 90%
    }

    /* rating section */

    .sl-review-card {
        flex-direction: column;
        min-height: 0;
        background: transparent;
        box-shadow: none;
    }

    .sl-review-card__media {
        flex: none;
        min-height: max(220px, 55vw);
        aspect-ratio: 16 / 10;
    }

    /* Featured: mobile – show mobile subtitle, adjust sliders */

    .sl-featured {
        padding: max(32px, 8vw) max(12px, 3vw);
    }

    .sl-featured__subtitle--top {
        display: none;
    }

    .sl-featured__subtitle--mobile {
        display: block;
    }

    .sl-featured__slider-wrap {
        padding: 0 max(40px, 10vw);
        margin-bottom: max(20px, 5vw);
    }

    .sl-featured__nav {
        width: 36px;
        height: 36px;
        min-width: 36px;
        min-height: 36px;
    }

    .sl-featured__logo-text {
        font-size: max(12px, 3.5vw);
    }

    /* Mobile: separator as thin light grey dashed line per design */
    .sl-featured__divider {
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
        border-top: 1px dashed #d0d0d0;
        display: block;
        margin-bottom: 20px;
    }

    /* FAQ: mobile = single column, title centered, button centered */

    .sl-faq__inner {
        grid-template-columns: 1fr;
        max-width: 100%;
    }

    .sl-faq__title {
        text-align: center;
        align-items: center;
    }

    .sl-faq__video-wrap {
        max-width: 100%;
    }

    .sl-faq__cta {
        display: flex;
        justify-content: center;
    }

    .sl-footer__nav {
        gap: max(28px, 6vw);
    }

    .sl-footer__email-col {
        max-width: 100%;
        padding-top: max(24px, 5vw);
    }


    .sl-footer__input,
    .sl-footer__submit {
        min-height: 28px;
    }

    .sl-footer__app-card {
        padding: 0 max(15px, 5vw) max(15px, 5vw) max(15px, 5vw);
    }




    .sl-footer__inner {
        max-width: 100%;
    }

    .sl-footer__watermark img {
        width: 100%;
    }
}
@media screen and (max-width: 576px) {
    .sl-review__inner {
        max-width: 100%;
    }

    .sl-featured__inner {
        max-width: 100% !important;
    }

    /* Featured: hide nav below 576px */

    .sl-featured__nav {
        display: none !important;
    }

    .sl-featured__slider-wrap {
        padding-inline: 0;
    }
}
@media screen and (max-width: 400px) {
    .sl-review-card__avatar {
        max-width: 32px;
        max-height: 32px;
    }

    .sl-review-card__author {
        gap: 5px;
    }

    .sl-review-card__name {
        font-size: 14px;
    }

    .sl-review-card__location {
        font-size: 12px;
    }

    .sl-review-card__text,.sl-testimonial-card__text {
        font-size: 16px;
    }

    .sl-review-card__nav-btn {
        width: 32px;
        height: 32px;
    }
    
    /* footer section */
    .sl-footer__app-btn {
        height: 30px;
    }

}

.sl-modal__btn-next.btn--org{
        color: var(--sl-modal-body-bg);
    background: var(--sl-modal-primary);
    cursor: pointer;
}

.sl-review-accordion__item--gray .accordion-collapse .accordion-body:first-child{
  margin:0 ;
}