.ps-promo-offer {
    --po-dark: #001f1a;
    --po-dark-2: #001713;
    --po-green: #025043;
    --po-green-2: #0b6b5a;
    --po-gold: #f6c12e;
    --po-gold-soft: #ffe39a;
    --po-white: #ffffff;
    --po-card: #f8fbf9;
    --po-text: #001f1a;
    --po-muted: rgba(255, 255, 255, 0.74);
    --po-muted-dark: rgba(0, 31, 26, 0.66);
    --po-line: rgba(255, 255, 255, 0.13);
    --po-card-line: rgba(2, 80, 67, 0.11);
    --po-text-main: var(--white);
    --po-text-subtle: rgba(255, 255, 255, 0.74);
    --po-text-note: rgba(255, 255, 255, 0.62);
    --po-text-card: var(--color-blue-dark);
    --po-text-card-muted: var(--gray-600);
    --po-kicker-text: var(--color-primary);
    --po-badge-text: var(--color-blue-dark);
    --po-status-count-text: var(--color-blue-dark);

    --po-eyebrow-size: var(--text-xxs-size);
    --po-eyebrow-weight: var(--weight-eyebrow);
    --po-title-size: 26px;
    --po-title-line: 32px;
    --po-title-weight: var(--font-medium);
    --po-body-size: var(--text-base-size);
    --po-body-line: var(--text-base-line);
    --po-button-size: var(--text-xs-size);
    --po-button-weight: var(--weight-button);
    --po-card-title-size: 22px;
    --po-card-title-weight: var(--font-medium);
    --po-benefit-size: var(--text-xs-size);
    --po-benefit-note-size: var(--text-xxs-size);
    --po-benefit-note-weight: var(--font-medium);
    --po-benefit-index-size: var(--text-xxs-size);
    --po-benefit-index-weight: var(--font-medium);
    --po-status-size: var(--text-xxs-size);
    --po-status-weight: var(--font-medium);
    --po-status-count-size: 12px;
    --po-status-count-weight: var(--font-black);
    --po-note-size: var(--text-xxs-size);
    --po-note-weight: var(--font-semibold);
    --po-module-radius: 32px;

    position: relative;
    font-family: var(--font-family-main, "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    letter-spacing: normal;
    padding: clamp(60px, 6vw, 92px) 0;
    background:
        radial-gradient(900px 480px at 14% 2%, rgba(246, 193, 46, 0.11), transparent 64%),
        radial-gradient(780px 460px at 82% 18%, rgba(8, 106, 88, 0.36), transparent 66%),
        radial-gradient(760px 520px at 52% 108%, rgba(0, 104, 86, 0.24), transparent 66%),
        linear-gradient(135deg, #00241f 0%, #004234 46%, #001a16 100%);
    overflow: hidden;
    isolation: isolate;
}

.ps-promo-offer *,
.ps-promo-offer *::before,
.ps-promo-offer *::after {
    box-sizing: border-box;
}

.ps-promo-offer::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.038) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.038) 1px, transparent 1px);
    background-size: 88px 88px;
    opacity: 0.16;
    mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 78%, transparent 100%);
    pointer-events: none;
}

.ps-promo-offer::after {
    content: "";
    position: absolute;
    right: -190px;
    top: 12%;
    z-index: 0;
    width: 520px;
    height: 520px;
    border-radius: 999px;
    border: 1px solid rgba(246, 193, 46, 0.13);
    background: radial-gradient(circle at 50% 50%, rgba(246, 193, 46, 0.08), transparent 62%);
    opacity: 0.48;
    pointer-events: none;
}

.ps-promo-offer .layout-container {
    position: relative;
    z-index: 1;
    width: min(100% - 48px, 1280px);
    max-width: 1280px;
    margin: 0 auto;
}

.ps-promo-offer__module {
    position: relative;
    display: grid;
    grid-template-columns: minmax(350px, 0.9fr) minmax(500px, 1.1fr);
    align-items: center;
    gap: clamp(34px, 4vw, 56px);
    width: 100%;
    max-width: 1140px;
    margin: 0 auto;
    padding: clamp(36px, 4vw, 54px);
    border: 1px solid var(--po-line);
    border-radius: var(--po-module-radius);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.034)),
        radial-gradient(560px 340px at 18% 14%, rgba(246, 193, 46, 0.055), transparent 70%),
        radial-gradient(560px 340px at 84% 78%, rgba(255, 255, 255, 0.055), transparent 72%);
    box-shadow:
        0 34px 86px rgba(0, 15, 12, 0.38),
        inset 0 1px 0 rgba(255, 255, 255, 0.14);
    overflow: hidden;
    isolation: isolate;
    backdrop-filter: blur(16px);
}

.ps-promo-offer__module::before {
    content: "";
    position: absolute;
    inset: 14px;
    z-index: 0;
    border: 1px solid rgba(255, 255, 255, 0.055);
    border-radius: calc(var(--po-module-radius) - 10px);
    pointer-events: none;
}

.ps-promo-offer__module::after {
    content: "";
    position: absolute;
    right: clamp(18px, 3vw, 42px);
    bottom: clamp(22px, 3vw, 46px);
    z-index: 1;
    width: clamp(250px, 24vw, 360px);
    height: clamp(250px, 24vw, 360px);
    border-radius: 999px;
    background:
        radial-gradient(circle at 52% 42%, rgba(246, 193, 46, 0.18), transparent 42%),
        radial-gradient(circle at 50% 54%, rgba(255, 255, 255, 0.12), transparent 58%),
        radial-gradient(circle at 50% 64%, rgba(2, 80, 67, 0.24), transparent 72%);
    filter: blur(5px);
    opacity: 0.9;
    pointer-events: none;
}

.ps-promo-offer__content,
.ps-promo-offer__visual {
    position: relative;
    z-index: 3;
}

.ps-promo-offer__content {
    max-width: 460px;
}

.ps-promo-offer__meta {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}

.ps-promo-offer__eyebrow {
    margin: 0;
    color: var(--po-kicker-text);
    font-size: var(--po-eyebrow-size);
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: normal;
    font-weight: var(--po-eyebrow-weight);
    white-space: nowrap;
}

.ps-promo-offer__badge {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 5px 10px;
    border-radius: 999px;
    color: var(--po-badge-text);
    background: linear-gradient(180deg, var(--po-gold-soft), var(--po-gold));
    border: 1px solid rgba(255, 227, 154, 0.76);
    font-size: var(--po-eyebrow-size);
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: normal;
    font-weight: var(--po-eyebrow-weight);
    white-space: nowrap;
}

.ps-promo-offer__title {
    margin: 0;
    max-width: 460px;
    color: var(--po-text-main);
    font-size: var(--po-title-size);
    line-height: var(--po-title-line);
    font-weight: var(--po-title-weight);
    letter-spacing: normal;
    text-wrap: balance;
}

.ps-promo-offer__title strong,
.ps-promo-offer__title mark {
    color: var(--po-gold);
    background: transparent;
}

.ps-promo-offer__desc {
    max-width: 420px;
    margin-top: 18px;
    color: var(--po-text-subtle);
    font-size: var(--po-body-size);
    line-height: 1.6;
}

.ps-promo-offer__desc p {
    margin: 0 0 0.86em;
}

.ps-promo-offer__desc p:last-child {
    margin-bottom: 0;
}

.ps-promo-offer__actions {
    margin-top: 22px;
}

.ps-promo-offer__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 50px;
    padding: 0 24px;
    border-radius: 999px;
    font-size: var(--po-button-size);
    line-height: 1;
    letter-spacing: normal;
    font-weight: var(--po-button-weight);
    text-transform: uppercase;
    text-decoration: none;
    transition:
        transform 180ms ease,
        box-shadow 180ms ease,
        background 180ms ease;
}

.ps-promo-offer__cta--primary {
    color: var(--color-blue-dark);
    background: linear-gradient(180deg, #ffe49f, var(--po-gold));
    border: 1px solid rgba(255, 226, 150, 0.82);
    box-shadow:
        0 12px 26px rgba(246, 193, 46, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

.ps-promo-offer__cta--secondary {
    color: var(--po-white);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.18);
}

.ps-promo-offer__cta:hover {
    transform: translateY(-1px);
}

.ps-promo-offer__cta--primary:hover {
    transform: translateY(-2px);
    box-shadow:
        0 14px 28px rgba(246, 193, 46, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.ps-promo-offer__cta:focus-visible {
    outline: 2px solid var(--po-gold);
    outline-offset: 4px;
}

.ps-promo-offer__cta-icon {
    font-size: 18px;
    transition: transform 180ms ease;
}

.ps-promo-offer__cta:hover .ps-promo-offer__cta-icon {
    transform: translateX(2px);
}

.ps-promo-offer__note {
    position: relative;
    margin: 14px 0 0;
    padding-left: 20px;
    color: var(--po-text-note);
    font-size: var(--po-note-size);
    line-height: 1.45;
    font-weight: var(--po-note-weight);
}

.ps-promo-offer__note::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.52em;
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: var(--po-gold);
    box-shadow: 0 0 0 5px rgba(246, 193, 46, 0.12);
}

.ps-promo-offer__visual {
    position: static;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    min-height: 410px;
}

.ps-promo-offer__card {
    position: relative;
    z-index: 4;
    width: min(100%, 480px);
    margin: 0;
    padding: 30px;
    border-radius: 28px;
    color: var(--po-text);
    background:
        radial-gradient(420px 260px at 100% 0%, rgba(246, 193, 46, 0.07), transparent 62%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.985), rgba(241, 248, 245, 0.955));
    border: 1px solid rgba(255, 255, 255, 0.72);
    box-shadow:
        0 28px 64px rgba(0, 20, 16, 0.3),
        inset 0 1px 0 rgba(255, 255, 255, 0.98);
    overflow: hidden;
}

.ps-promo-offer__card::before {
    content: "";
    position: absolute;
    left: 34px;
    right: 34px;
    top: 0;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--po-gold), rgba(246, 193, 46, 0));
}
.ps-promo-offer__card-head,
.ps-promo-offer__benefits,
.ps-promo-offer__status {
    position: relative;
    z-index: 2;
}

.ps-promo-offer__card-head {
    max-width: 430px;
}

.ps-promo-offer__card-kicker {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 5px 9px;
    border-radius: 999px;
    color: var(--po-kicker-text);
    background: rgba(246, 193, 46, 0.14);
    border: 1px solid rgba(246, 193, 46, 0.36);
    font-size: var(--po-eyebrow-size);
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: normal;
    font-weight: var(--po-eyebrow-weight);
    white-space: nowrap;
}

.ps-promo-offer__card-title {
    max-width: 400px;
    margin: 12px 0 0;
    color: var(--po-text);
    font-size: var(--po-card-title-size);
    line-height: 1.12;
    font-weight: var(--po-card-title-weight);
    letter-spacing: normal;
    text-wrap: balance;
}

.ps-promo-offer__benefits {
    display: grid;
    gap: 8px;
    max-width: 430px;
    margin: 22px 0 0;
    padding: 0;
    list-style: none;
}

.ps-promo-offer__benefit {
    display: grid;
    grid-template-columns: 30px 1fr;
    align-items: center;
    gap: 10px;
    min-width: 0;
    padding: 9px 11px;
    border-radius: 14px;
    border: 1px solid var(--po-card-line);
    background: rgba(255, 255, 255, 0.88);
    box-shadow:
        0 10px 22px rgba(2, 80, 67, 0.045),
        inset 0 1px 0 rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(10px);
}

.ps-promo-offer__benefit.is-highlight {
    border-color: rgba(246, 193, 46, 0.32);
    background:
        linear-gradient(135deg, rgba(246, 193, 46, 0.16), rgba(255, 255, 255, 0.9));
}

.ps-promo-offer__benefit-index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    color: var(--po-gold);
    background: linear-gradient(180deg, var(--po-green-2), var(--po-green));
    border: 1px solid rgba(255, 255, 255, 0.18);
    font-size: var(--po-benefit-index-size);
    line-height: 1;
    font-weight: var(--po-benefit-index-weight);
    letter-spacing: normal;
    font-variant-numeric: tabular-nums;
    box-shadow: 0 8px 16px rgba(2, 80, 67, 0.16);
}

.ps-promo-offer__benefit-main {
    min-width: 0;
}

.ps-promo-offer__benefit-text {
    display: block;
    color: var(--po-text);
    font-size: var(--po-benefit-size);
    line-height: 1.38;
    font-weight: var(--font-medium);
    letter-spacing: normal;
    text-wrap: balance;
}

.ps-promo-offer__benefit-note {
    display: block;
    margin-top: 4px;
    color: var(--po-text-card-muted);
    font-size: var(--po-benefit-note-size);
    line-height: 1.35;
    font-weight: var(--po-benefit-note-weight);
    letter-spacing: normal;
}

.ps-promo-offer__status {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    max-width: 430px;
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 16px;
    border: 1px solid rgba(2, 80, 67, 0.11);
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(10px);
}

.ps-promo-offer__status-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 26px;
    height: 26px;
    border-radius: 999px;
    color: var(--po-status-count-text);
    background: var(--po-gold);
    font-size: var(--po-status-count-size);
    line-height: 1;
    font-weight: var(--po-status-count-weight);
    letter-spacing: normal;
}

.ps-promo-offer__status-text {
    color: var(--po-text-card-muted);
    font-size: var(--po-status-size);
    line-height: 1.35;
    font-weight: var(--po-status-weight);
    letter-spacing: normal;
    text-wrap: balance;
}

.ps-promo-offer__person {
    position: absolute;
    right: clamp(-24px, -1.4vw, -10px);
    bottom: -10px;
    z-index: 5;
    display: block;
    width: clamp(232px, 17.8vw, 292px);
    margin: 0;
    pointer-events: none;
    filter:
        drop-shadow(0 24px 30px rgba(0, 20, 16, 0.28))
        drop-shadow(0 1px 0 rgba(255, 255, 255, 0.14));
}

.ps-promo-offer__person::before {
    content: "";
    position: absolute;
    left: 8%;
    right: 2%;
    bottom: 2%;
    z-index: -1;
    height: 74%;
    border-radius: 999px 999px 34px 34px;
    background:
        radial-gradient(circle at 50% 30%, rgba(246, 193, 46, 0.18), transparent 44%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    filter: blur(12px);
}

.ps-promo-offer__person::after {
    content: "";
    position: absolute;
    left: 14%;
    right: 8%;
    bottom: 2px;
    z-index: -2;
    height: 24px;
    border-radius: 999px;
    background: rgba(0, 20, 16, 0.3);
    filter: blur(12px);
}

.ps-promo-offer__person-img {
    display: block;
    width: 100%;
    height: auto;
    transform: translateY(12px);
}

.ps-promo-offer--no-person .ps-promo-offer__person {
    display: none;
}

.ps-promo-offer--no-person .ps-promo-offer__card {
    width: min(100%, 590px);
}

.ps-promo-offer:not(.ps-promo-offer--no-person) .ps-promo-offer__card-head,
.ps-promo-offer:not(.ps-promo-offer--no-person) .ps-promo-offer__card-title,
.ps-promo-offer:not(.ps-promo-offer--no-person) .ps-promo-offer__benefits,
.ps-promo-offer:not(.ps-promo-offer--no-person) .ps-promo-offer__status {
    max-width: 330px;
}

.ps-promo-offer--no-content .ps-promo-offer__module,
.ps-promo-offer--no-items .ps-promo-offer__module {
    grid-template-columns: 1fr;
    max-width: 860px;
}

.ps-promo-offer--reverse .ps-promo-offer__content {
    order: 2;
}

.ps-promo-offer--reverse .ps-promo-offer__visual {
    order: 1;
}

.ps-promo-offer-admin-placeholder {
    padding: 14px 16px;
    border: 1px dashed rgba(2, 80, 67, 0.24);
    border-radius: 14px;
}

@media (max-width: 1280px) {
    .ps-promo-offer {
        --po-title-size: clamp(32px, 2.65vw, 40px);
    }

    .ps-promo-offer .layout-container {
        width: min(100% - 40px, 1180px);
    }

    .ps-promo-offer__module {
        grid-template-columns: minmax(330px, 0.9fr) minmax(480px, 1.1fr);
        gap: clamp(30px, 3.6vw, 44px);
        padding: clamp(32px, 3.4vw, 42px);
    }

    .ps-promo-offer__card {
        width: min(100%, 480px);
        padding: 30px;
    }

    .ps-promo-offer__card::before {
        left: 32px;
        right: 32px;
    }

    .ps-promo-offer__person {
        right: clamp(-20px, -1vw, -8px);
        width: clamp(240px, 18.5vw, 292px);
    }
}

@media (max-width: 1080px) {
    .ps-promo-offer {
        --po-title-size: clamp(32px, 4vw, 40px);
    }

    .ps-promo-offer__module {
        grid-template-columns: 1fr;
        max-width: 820px;
    }

    .ps-promo-offer__content {
        max-width: 520px;
    }

    .ps-promo-offer__title {
        max-width: 520px;
    }

    .ps-promo-offer__desc {
        max-width: 500px;
    }

    .ps-promo-offer__visual {
        position: relative;
        min-height: 400px;
    }

    .ps-promo-offer__card {
        width: min(100%, 520px);
    }

    .ps-promo-offer__person {
        right: -12px;
        width: clamp(235px, 31vw, 295px);
    }

    .ps-promo-offer__module::after {
        right: 46px;
        bottom: 46px;
        width: 220px;
        height: 220px;
    }
}

@media (max-width: 720px) {
    .ps-promo-offer {
        --po-title-size: clamp(28px, 7.2vw, 38px);
        --po-title-line: 1.08;
        --po-card-title-size: clamp(22px, 5.8vw, 26px);
        padding: 50px 0;
    }

    .ps-promo-offer .layout-container {
        width: min(100% - 28px, 640px);
    }

    .ps-promo-offer__module {
        gap: 30px;
        padding: 26px 18px;
        border-radius: 26px;
    }

    .ps-promo-offer__module::before {
        inset: 10px;
        border-radius: 20px;
    }

    .ps-promo-offer__module::after {
        display: none;
    }

    .ps-promo-offer__desc {
        margin-top: 20px;
        font-size: var(--text-sm-size);
        line-height: var(--text-base-line);
    }

    .ps-promo-offer__cta {
        width: 100%;
    }

    .ps-promo-offer__visual {
        min-height: auto;
    }

    .ps-promo-offer__card {
        width: 100%;
        padding: 24px 18px;
        border-radius: 24px;
    }

    .ps-promo-offer__card::before {
        left: 18px;
        right: 18px;
    }
    .ps-promo-offer__card-head,
    .ps-promo-offer__card-title,
    .ps-promo-offer__benefits,
    .ps-promo-offer__status {
        max-width: none;
    }

    .ps-promo-offer__benefit {
        grid-template-columns: 28px 1fr;
        gap: 10px;
        padding: 10px;
    }

    .ps-promo-offer__person {
        display: none;
    }
}

@media (max-width: 420px) {
    .ps-promo-offer {
        --po-eyebrow-size: var(--text-xxs-size);
    }

    .ps-promo-offer .layout-container {
        width: min(100% - 20px, 400px);
    }

    .ps-promo-offer__module {
        padding: 22px 14px;
        border-radius: 24px;
    }

    .ps-promo-offer__meta {
        gap: 8px;
    }

    .ps-promo-offer__badge {
        min-height: 24px;
        padding: 5px 9px;
    }

    .ps-promo-offer__card {
        padding: 22px 16px;
        border-radius: 22px;
    }

    .ps-promo-offer__card::before {
        left: 16px;
        right: 16px;
    }

    .ps-promo-offer__benefit {
        border-radius: 15px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .ps-promo-offer__cta,
    .ps-promo-offer__cta-icon {
        transition: none;
    }

    .ps-promo-offer__cta:hover,
    .ps-promo-offer__cta:hover .ps-promo-offer__cta-icon {
        transform: none;
    }
}
/* =========================================================
   Promo Offer — Light Premium Theme / Final polish
   Works when section has: .ps-promo-offer--theme-light
   ========================================================= */

.ps-promo-offer--theme-light {
    --po-dark: #001f1a;
    --po-dark-2: #f7fbf8;
    --po-green: #025043;
    --po-green-2: #0b6b5a;
    --po-gold: #f6c12e;
    --po-gold-soft: #ffe39a;
    --po-white: #ffffff;
    --po-card: #ffffff;
    --po-text: #001f1a;
    --po-muted: rgba(0, 31, 26, 0.66);
    --po-muted-dark: rgba(0, 31, 26, 0.66);
    --po-line: rgba(2, 80, 67, 0.13);
    --po-card-line: rgba(2, 80, 67, 0.10);
    --po-text-main: var(--color-blue-dark);
    --po-text-subtle: var(--gray-600);
    --po-text-note: var(--gray-600);
    --po-text-card: var(--color-blue-dark);
    --po-text-card-muted: var(--gray-600);
    --po-kicker-text: var(--color-secondary);
    --po-badge-text: var(--color-blue-dark);
    --po-status-count-text: var(--color-blue-dark);
    background: var(--gray-50);
}

.ps-promo-offer--theme-light::before {
    background-image:
        linear-gradient(rgba(2, 80, 67, 0.032) 1px, transparent 1px),
        linear-gradient(90deg, rgba(2, 80, 67, 0.032) 1px, transparent 1px);
    background-size: 92px 92px;
    opacity: 0.58;
    mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 78%, transparent 100%);
}

.ps-promo-offer--theme-light::after {
    border-color: rgba(2, 80, 67, 0.085);
    background:
        radial-gradient(circle at 50% 50%, rgba(2, 80, 67, 0.055), transparent 50%),
        radial-gradient(circle at 50% 50%, rgba(246, 193, 46, 0.09), transparent 66%);
    opacity: 0.62;
}

.ps-promo-offer--theme-light .ps-promo-offer__module {
    border-color: rgba(2, 80, 67, 0.18);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(247, 251, 248, 0.82)),
        radial-gradient(620px 360px at 14% 10%, rgba(246, 193, 46, 0.095), transparent 70%),
        radial-gradient(560px 340px at 88% 82%, rgba(2, 80, 67, 0.075), transparent 72%);
    box-shadow:
        0 28px 72px rgba(0, 50, 41, 0.11),
        0 10px 28px rgba(0, 50, 41, 0.055),
        inset 0 1px 0 rgba(255, 255, 255, 0.96);
}

.ps-promo-offer--theme-light .ps-promo-offer__module::before {
    border-color: rgba(2, 80, 67, 0.07);
}

.ps-promo-offer--theme-light .ps-promo-offer__module::after {
    right: clamp(26px, 3.4vw, 52px);
    bottom: clamp(24px, 3vw, 46px);
    background:
        radial-gradient(circle at 52% 42%, rgba(246, 193, 46, 0.18), transparent 42%),
        radial-gradient(circle at 50% 54%, rgba(255, 255, 255, 0.54), transparent 58%),
        radial-gradient(circle at 50% 64%, rgba(2, 80, 67, 0.12), transparent 72%);
    filter: blur(5px);
    opacity: 0.82;
}

.ps-promo-offer--theme-light .ps-promo-offer__eyebrow {
    color: var(--po-green);
}

.ps-promo-offer--theme-light .ps-promo-offer__badge {
    box-shadow: 0 10px 22px rgba(246, 193, 46, 0.15);
}

.ps-promo-offer--theme-light .ps-promo-offer__title {
    color: var(--po-text);
    max-width: 440px;
}

.ps-promo-offer--theme-light .ps-promo-offer__title strong,
.ps-promo-offer--theme-light .ps-promo-offer__title mark {
    color: var(--po-green);
}

.ps-promo-offer--theme-light .ps-promo-offer__desc {
    max-width: 410px;
    color: var(--po-text-subtle);
}

.ps-promo-offer--theme-light .ps-promo-offer__cta--primary {
    box-shadow:
        0 12px 24px rgba(246, 193, 46, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.44);
}

.ps-promo-offer--theme-light .ps-promo-offer__cta--secondary {
    color: var(--po-green);
    background: #ffffff;
    border-color: rgba(2, 80, 67, 0.18);
    box-shadow: 0 14px 28px rgba(2, 80, 67, 0.08);
}

.ps-promo-offer--theme-light .ps-promo-offer__note {
    color: var(--po-text-note);
}

.ps-promo-offer--theme-light .ps-promo-offer__note::before {
    box-shadow: 0 0 0 5px rgba(246, 193, 46, 0.18);
}

.ps-promo-offer--theme-light .ps-promo-offer__card {
    background:
        radial-gradient(430px 260px at 100% 0%, rgba(246, 193, 46, 0.08), transparent 62%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.995), rgba(246, 250, 247, 0.965));
    border-color: rgba(2, 80, 67, 0.13);
    box-shadow:
        0 22px 52px rgba(0, 50, 41, 0.13),
        0 10px 24px rgba(0, 50, 41, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.98);
}

.ps-promo-offer--theme-light .ps-promo-offer__card::before {
    background: linear-gradient(90deg, var(--po-gold), rgba(246, 193, 46, 0));
}

.ps-promo-offer--theme-light .ps-promo-offer__card-kicker {
    background: rgba(246, 193, 46, 0.13);
    border-color: rgba(246, 193, 46, 0.34);
}

.ps-promo-offer--theme-light .ps-promo-offer__benefit {
    background: rgba(255, 255, 255, 0.91);
    border-color: rgba(2, 80, 67, 0.09);
    box-shadow:
        0 9px 20px rgba(2, 80, 67, 0.05),
        inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.ps-promo-offer--theme-light .ps-promo-offer__benefit.is-highlight {
    border-color: rgba(246, 193, 46, 0.36);
    background:
        linear-gradient(135deg, rgba(246, 193, 46, 0.17), rgba(255, 255, 255, 0.92));
}

.ps-promo-offer--theme-light .ps-promo-offer__benefit-index {
    box-shadow: 0 8px 16px rgba(2, 80, 67, 0.14);
}

.ps-promo-offer--theme-light .ps-promo-offer__status {
    background: rgba(255, 255, 255, 0.84);
    border-color: rgba(2, 80, 67, 0.10);
}

.ps-promo-offer--theme-light .ps-promo-offer__person {
    bottom: -14px;
    width: clamp(232px, 17.8vw, 292px);
    filter:
        drop-shadow(0 24px 28px rgba(0, 50, 41, 0.16))
        drop-shadow(0 1px 0 rgba(255, 255, 255, 0.34));
}

.ps-promo-offer--theme-light .ps-promo-offer__person::before {
    background:
        radial-gradient(circle at 50% 30%, rgba(246, 193, 46, 0.16), transparent 44%),
        linear-gradient(180deg, rgba(2, 80, 67, 0.09), rgba(255, 255, 255, 0));
}

.ps-promo-offer--theme-light .ps-promo-offer__person::after {
    background: rgba(0, 50, 41, 0.16);
}

@media (max-width: 1280px) {
    .ps-promo-offer--theme-light .ps-promo-offer__person {
        width: clamp(244px, 19.6vw, 292px);
    }
}

@media (max-width: 1080px) {
    .ps-promo-offer--theme-light .ps-promo-offer__module::after {
        opacity: 0.68;
    }
}

@media (max-width: 720px) {
    .ps-promo-offer--theme-light .ps-promo-offer__card {
        box-shadow:
            0 18px 42px rgba(0, 50, 41, 0.12),
            inset 0 1px 0 rgba(255, 255, 255, 0.98);
    }
}

/* =========================================================
   Promo Offer — Light Theme + Emerald Benefits Card
   Works when section has: .ps-promo-offer--theme-light-emerald
   ========================================================= */

.ps-promo-offer--theme-light-emerald {
    --po-dark: #001f1a;
    --po-dark-2: #f7fbf8;
    --po-green: #025043;
    --po-green-2: #0b6b5a;
    --po-gold: #f6c12e;
    --po-gold-soft: #ffe39a;
    --po-white: #ffffff;
    --po-card: #ffffff;
    --po-text: #001f1a;
    --po-muted: rgba(0, 31, 26, 0.66);
    --po-muted-dark: rgba(0, 31, 26, 0.66);
    --po-line: rgba(2, 80, 67, 0.13);
    --po-card-line: rgba(255, 255, 255, 0.12);
    --po-text-main: var(--color-blue-dark);
    --po-text-subtle: var(--gray-600);
    --po-text-note: var(--gray-600);
    --po-text-card: var(--white);
    --po-text-card-muted: rgba(255, 255, 255, 0.74);
    --po-kicker-text: var(--color-secondary);
    --po-badge-text: var(--color-blue-dark);
    --po-status-count-text: var(--color-blue-dark);

    background: var(--gray-50);
}

.ps-promo-offer--theme-light-emerald::before {
    background-image:
        linear-gradient(rgba(2, 80, 67, 0.032) 1px, transparent 1px),
        linear-gradient(90deg, rgba(2, 80, 67, 0.032) 1px, transparent 1px);
    background-size: 92px 92px;
    opacity: 0.58;
    mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 78%, transparent 100%);
}

.ps-promo-offer--theme-light-emerald::after {
    border-color: rgba(2, 80, 67, 0.085);
    background:
        radial-gradient(circle at 50% 50%, rgba(2, 80, 67, 0.055), transparent 50%),
        radial-gradient(circle at 50% 50%, rgba(246, 193, 46, 0.09), transparent 66%);
    opacity: 0.62;
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__module {
    border-color: rgba(2, 80, 67, 0.18);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(247, 251, 248, 0.82)),
        radial-gradient(620px 360px at 14% 10%, rgba(246, 193, 46, 0.095), transparent 70%),
        radial-gradient(560px 340px at 88% 82%, rgba(2, 80, 67, 0.075), transparent 72%);
    box-shadow:
        0 28px 72px rgba(0, 50, 41, 0.11),
        0 10px 28px rgba(0, 50, 41, 0.055),
        inset 0 1px 0 rgba(255, 255, 255, 0.96);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__module::before {
    border-color: rgba(2, 80, 67, 0.07);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__module::after {
    right: clamp(26px, 3.4vw, 52px);
    bottom: clamp(24px, 3vw, 46px);
    background:
        radial-gradient(circle at 52% 42%, rgba(246, 193, 46, 0.18), transparent 42%),
        radial-gradient(circle at 50% 54%, rgba(255, 255, 255, 0.54), transparent 58%),
        radial-gradient(circle at 50% 64%, rgba(2, 80, 67, 0.12), transparent 72%);
    filter: blur(5px);
    opacity: 0.82;
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__eyebrow {
    color: var(--po-green);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__badge {
    box-shadow: 0 10px 22px rgba(246, 193, 46, 0.15);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__title {
    color: var(--po-text);
    max-width: 440px;
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__title strong,
.ps-promo-offer--theme-light-emerald .ps-promo-offer__title mark {
    color: var(--po-green);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__desc {
    max-width: 410px;
    color: var(--po-text-subtle);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__cta--primary {
    box-shadow:
        0 12px 24px rgba(246, 193, 46, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.44);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__cta--secondary {
    color: var(--po-green);
    background: #ffffff;
    border-color: rgba(2, 80, 67, 0.18);
    box-shadow: 0 14px 28px rgba(2, 80, 67, 0.08);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__note {
    color: var(--po-text-note);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__note::before {
    box-shadow: 0 0 0 5px rgba(246, 193, 46, 0.18);
}

/* Emerald benefits card */

.ps-promo-offer--theme-light-emerald .ps-promo-offer__card {
    color: var(--po-text-card);
    background:
        radial-gradient(400px 240px at 96% 0%, rgba(246, 193, 46, 0.14), transparent 62%),
        radial-gradient(360px 260px at 12% 100%, rgba(255, 255, 255, 0.08), transparent 66%),
        linear-gradient(145deg, rgba(2, 72, 60, 0.98), rgba(0, 43, 36, 0.98));
    border-color: rgba(255, 255, 255, 0.14);
    box-shadow:
        0 24px 56px rgba(0, 50, 41, 0.24),
        0 12px 28px rgba(0, 50, 41, 0.11),
        inset 0 1px 0 rgba(255, 255, 255, 0.13);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__card::before {
    background: linear-gradient(90deg, var(--po-gold), rgba(246, 193, 46, 0));
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__card-kicker {
    color: var(--po-gold);
    background: rgba(246, 193, 46, 0.11);
    border-color: rgba(246, 193, 46, 0.34);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__card-title {
    color: var(--po-text-card);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__benefit {
    background: rgba(255, 255, 255, 0.075);
    border-color: rgba(255, 255, 255, 0.105);
    box-shadow:
        0 10px 22px rgba(0, 20, 16, 0.10),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(10px);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__benefit.is-highlight {
    border-color: rgba(246, 193, 46, 0.34);
    background:
        linear-gradient(135deg, rgba(246, 193, 46, 0.13), rgba(255, 255, 255, 0.075));
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__benefit-index {
    color: var(--po-status-count-text);
    background: linear-gradient(180deg, #ffe49f, var(--po-gold));
    border-color: rgba(255, 226, 150, 0.44);
    box-shadow: 0 8px 16px rgba(246, 193, 46, 0.14);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__benefit-text {
    color: var(--po-text-card);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__benefit-note {
    color: var(--po-text-card-muted);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__status {
    color: var(--po-text-card);
    background: rgba(255, 255, 255, 0.075);
    border-color: rgba(246, 193, 46, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__status-count {
    background: var(--po-gold);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__status-text {
    color: var(--po-text-card-muted);
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__person {
    bottom: -14px;
    width: clamp(232px, 17.8vw, 292px);
    filter:
        drop-shadow(0 24px 28px rgba(0, 50, 41, 0.18))
        drop-shadow(0 1px 0 rgba(255, 255, 255, 0.30));
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__person::before {
    background:
        radial-gradient(circle at 50% 30%, rgba(246, 193, 46, 0.18), transparent 44%),
        linear-gradient(180deg, rgba(2, 80, 67, 0.10), rgba(255, 255, 255, 0));
}

.ps-promo-offer--theme-light-emerald .ps-promo-offer__person::after {
    background: rgba(0, 50, 41, 0.18);
}

@media (max-width: 1280px) {
    .ps-promo-offer--theme-light-emerald .ps-promo-offer__person {
        width: clamp(244px, 19.6vw, 292px);
    }
}

@media (max-width: 1080px) {
    .ps-promo-offer--theme-light-emerald .ps-promo-offer__module::after {
        opacity: 0.68;
    }
}

@media (max-width: 720px) {
    .ps-promo-offer--theme-light-emerald .ps-promo-offer__card {
        box-shadow:
            0 18px 42px rgba(0, 50, 41, 0.20),
            inset 0 1px 0 rgba(255, 255, 255, 0.13);
    }
}
