/* .value-prop-pricing-header */

.value-prop-pricing-header {
    padding: 96px 0 48px;
    border-bottom: 0.5px solid rgba(49, 53, 63, 0.24);
}

.value-prop-pricing-header:where([data-side="sellside"]) {
    padding: 118px 0 106px;
}

.value-prop-pricing-header__text {
    text-align: center;
    max-width: 644px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.value-prop-pricing-header__text-top {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.value-prop-pricing-header__text-top-heading {

}

.value-prop-pricing-header__text-top-subheading {
    color: var(--brand-primary);
    text-transform: uppercase;
}

.value-prop-pricing-header__text-bottom {

}

/* .value-prop-pricing */

.value-prop-pricing {
    display: flex;
    padding: 0 120px;
    flex-direction: column;
    align-items: center;
    align-self: stretch;
    border-top: 1px solid rgba(49, 53, 63, 0.24);
}

.value-prop-pricing__wrap {
    border: 0;
}

.value-prop-pricing__panels {
    display: flex;
    align-items: stretch;
    gap: 48px;
    align-self: stretch;
}

:where(.value-prop-pricing[data-sections-count="2"]) .value-prop-pricing__panels {
    gap: 96px;
}

.value-prop-pricing__panel {
    display: flex;
    padding: 120px 0;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: 32px;
    flex: 1 0 0;
    text-align: center;
}

.value-prop-pricing__separator {
    width: 1px;
    background: rgba(49, 53, 63, 0.24);
}

.value-prop-pricing__panel-top {
    height: 104px;
}

.value-prop-pricing__panel-top img {
    width: 104px;
    height: 104px;
    display: block;
    margin: 0 auto;
}

.value-prop-pricing__panel-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    align-self: stretch;
}

/* .value-prop-success-fee */

.value-prop-success-fee {
    --child-max-width: 720px;
    display: flex;
}

/* .value-prop-success-fee-overview */

.value-prop-success-fee-overview {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    flex: 0 0 50%;
}

.value-prop-success-fee-overview__top {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    flex: 1 0 0;
    align-self: stretch;
    background: rgba(149, 179, 248, 0.10);
    position: relative;
    overflow: hidden; /* cut off background image */
}

.value-prop-success-fee-overview__top-background {
    width: 301px;
    height: 440px;
    position: absolute;
    right: -34px;
    top: -3px;
    pointer-events: none;
    background: url(../images/value-prop-buyside-background.png) 0 0 / cover no-repeat;
}

.value-prop-success-fee-overview__top-wrap {
    max-width: var(--child-max-width);
    width: 100%;
    padding: 64px 64px 96px 120px;
}

.value-prop-success-fee-overview__top-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    max-width: 333px;
}

.value-prop-success-fee-overview__top-text em {
    color: var(--brand-primary);
    font-style: normal;
}

.value-prop-success-fee-overview__bottom {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 12px;
    color: white;
    background: #08349B;
}

.value-prop-success-fee-overview__bottom-wrap {
    max-width: var(--child-max-width);
    width: 100%;
    padding: 32px 64px 32px 120px;
}

.value-prop-success-fee-overview__bottom-text {
    max-width: var(--child-max-width);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    flex: 1 0 0;
}

.value-prop-success-fee-overview__bottom-text-header {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    opacity: 0.6;
}

.value-prop-success-fee-overview__bottom-text-header-heading {
    text-transform: uppercase;
}

.value-prop-success-fee-overview__bottom-text-header-icon {
    width: 24px;
    height: 24px;
    fill: white;
}

/* .value-prop-success-fee-details */

.value-prop-success-fee-details {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    gap: 32px;
    flex: 0 0 50%;
    background: #326CF4;
    color: white;
}

.value-prop-success-fee-details__wrap {
    max-width: var(--child-max-width);
    width: 100%;
    padding: 80px 120px;
}

.value-prop-success-fee-details__list {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 20px;
    align-self: stretch;
    list-style: none;
    padding: 0;
    margin: 0;
}

.value-prop-success-fee-details__list li::before {
    content: none;
}

.value-prop-success-fee-details__list-item {
    display: flex;
    justify-content: space-between;
    letter-spacing: -0.4px;
}

.value-prop-success-fee-details__list-separator {
    width: 100%;
    height: 1px;
    margin-top: -1px;
    background: rgba(255, 255, 255, 0.24);
}

/* .value-prop-rewards */

.value-prop-rewards {
    border-bottom: 0.5px solid rgba(49, 53, 63, 0.24);
}

/* .value-prop-reward */

.value-prop-reward {
    display: flex;
}

.value-prop-reward:where(:nth-child(2n)) {
    flex-direction: row-reverse;
}

.value-prop-reward:nth-child(2n) .value-prop-reward__text-container {
    margin-left: auto;
}

.value-prop-reward__image {
    position: relative;
    min-height: 500px;
    background: linear-gradient(90deg, #08349B 0%, #031235 100%), #08349B;
    flex: 1 1 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden; /* cut off background ribbon images */
}

.value-prop-reward__image-icon {
    position: absolute;
    pointer-events: none;
}

.value-prop-reward__image-icon::before {
    background-size: cover;
    background-repeat: no-repeat;
    content: '';
    display: block;
}

.value-prop-reward:nth-child(3n+1) .value-prop-reward__image-icon {
    bottom: 0;
    left: 0;
    width: 506px;
}

.value-prop-reward:nth-child(3n+1) .value-prop-reward__image-icon::before {
    background-image: url(../images/value-prop-sellside-river-1.png);
    padding-top: calc(100% * (456 / 506));
}

.value-prop-reward:nth-child(3n+2) .value-prop-reward__image-icon {
    bottom: 0;
    right: 0;
    width: 520px;
}

.value-prop-reward:nth-child(3n+2) .value-prop-reward__image-icon::before {
    background-image: url(../images/value-prop-sellside-river-2.png);
    padding-top: calc(100% * (441 / 520));
}

.value-prop-reward:nth-child(3n+3) .value-prop-reward__image-icon {
    bottom: 0;
    left: 0;
    width: 643px;
}

.value-prop-reward:nth-child(3n+3) .value-prop-reward__image-icon::before {
    background-image: url(../images/value-prop-sellside-river-3.png);
    padding-top: calc(100% * (312 / 643));
}

.value-prop-reward__image-content {
    width: calc(var(--img-width) * 1px);
    max-width: calc(100% - 64px);
    position: relative;
}

.value-prop-reward__image-content div {
    padding-top: calc(var(--img-height) / var(--img-width) * 100%);
    background-size: cover;
    background-repeat: no-repeat;
}

.value-prop-reward__text {
    flex: 1 1 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.value-prop-reward__text-container {
    padding: 48px 64px;
    display: flex;
    gap: 24px;
    flex-direction: column;
    max-width: 720px;
}

.value-prop-reward__text p:not(:last-child) {
    margin-bottom: 8px;
}

.value-prop-reward__text strong {
    font-variation-settings: "slnt" 0, "wght" 600;
}

.value-prop-reward__text ul {
    list-style: none;
    margin: 24px 0 0;
    padding: 0 0 0 22px;
}

.value-prop-reward__text li {
    position: relative;
    margin-bottom: 12px;
}

.value-prop-reward__text li::before {
    content: '';
    background: url(../images/value-prop-list-marker.png) 0 0 / cover no-repeat;
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    top: 0;
    left: -22px;
}

/* media query: tablet */

@media screen and (max-width: 1279px) {
    .value-prop-pricing-header {
        padding: 124px 0 80px;
    }

    .value-prop-pricing-header__text {
        max-width: 496px;
        padding: 0 32px;
    }

    .value-prop-pricing {
        padding: 0 32px;
    }

    .value-prop-pricing__panels {
        gap: 24px;
    }

    .value-prop-pricing__panel {
        padding: 64px 0;
    }

    .value-prop-success-fee-overview__top-wrap {
        padding: 40px 32px 96px 32px;
    }

    .value-prop-success-fee-overview__top-background {
        display: none;
    }

    .value-prop-success-fee-overview__bottom-wrap {
        padding: 32px;
    }

    .value-prop-success-fee-details__wrap {
        padding: 64px 32px;
    }

    .value-prop-success-fee-details__list-item {
        letter-spacing: 0;
    }

    .value-prop-reward__image {
        min-height: 308px;
    }

    .value-prop-reward__image-content {
        width: calc(var(--img-width) * 0.61 * 1px);
        max-width: calc(100% - 48px);
    }

    .value-prop-reward__text p:not(:last-child) {
        margin-bottom: 0;
    }

    .value-prop-reward__text li {
        margin-bottom: 14px;
    }

    .value-prop-reward__text-container {
        padding: 48px 32px;
        max-width: none;
    }
}

/* media query: mobile */

@media screen and (max-width: 767px) {
    .value-prop-pricing {
        padding: 0;
    }

    .value-prop-pricing__panels {
        flex-direction: column;
        padding: 80px 0;
        gap: 40px;
    }

    .value-prop-pricing__panel {
        padding: 0 20px;
        flex-direction: row;
        gap: 12px;
        text-align: left;
    }

    .value-prop-pricing__panel-top {
        flex: 0 0 70px;
        display: flex;
        align-items: center;
        justify-content: center;
        height: 70px;
    }

    .value-prop-pricing__panel-top img {
        width: 70px;
        height: 70px;
    }

    .value-prop-pricing__separator {
        width: 100%;
        height: 1px;
    }

    .value-prop-pricing__panel-bottom {
        align-items: flex-start;
    }

    .value-prop-success-fee {
        flex-direction: column;
    }

    .value-prop-success-fee-overview__top {
        flex: 1 0 auto;
    }

    .value-prop-success-fee-overview__top-wrap {
        padding: 64px 20px;
    }

    .value-prop-success-fee-overview__top-text {
        padding: 0 0 56px;
        max-width: 165px;
        gap: 10px;
    }

    .value-prop-success-fee-overview__bottom-wrap {
        padding: 20px;
    }

    .value-prop-success-fee-overview__top-background {
        display: block;
        width: 246px;
        height: 446px;
        right: -78px;
        top: -3px;
        background-image: url(../images/value-prop-buyside-background-mobile.png);
    }

    .value-prop-success-fee-overview__bottom-text-header-icon {
        width: 20px;
        height: 20px;
    }

    .value-prop-success-fee-details__wrap {
        padding: 64px 20px;
    }

    .value-prop-reward {
        flex-direction: column;
    }

    .value-prop-reward__image {
        height: 320px;
        padding: 0;
        min-height: 0;
        flex: 1 1 auto;
    }

    .value-prop-reward__image-icon {
        width: 779px;
    }

    .value-prop-reward:nth-child(3n+1) .value-prop-reward__image-icon {
        width: auto;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
    }

    .value-prop-reward:nth-child(3n+1) .value-prop-reward__image-icon::before {
        padding: 0;
        background: url(../images/value-prop-sellside-river-mobile-1.png) 50% 100% / cover no-repeat;
        width: 100%;
        height: 100%;
    }

    .value-prop-reward:nth-child(3n+2) .value-prop-reward__image-icon {
        width: 160px;
    }

    .value-prop-reward:nth-child(3n+2) .value-prop-reward__image-icon::before {
        padding-top: calc(100% * (367 / 160));
        background-image: url(../images/value-prop-sellside-river-mobile-2.png);
    }

    .value-prop-reward:nth-child(3n+3) .value-prop-reward__image-icon {
        width: 360px;
        left: auto;
        right: 0;
    }

    .value-prop-reward:nth-child(3n+3) .value-prop-reward__image-icon::before {
        padding-top: calc(100% * (128 / 360));
        background-image: url(../images/value-prop-sellside-river-mobile-3.png);
    }

    .value-prop-reward__text {
        flex: 1 1 auto;
    }

    .value-prop-reward__text-container {
        padding: 48px 20px;
        gap: 16px;
    }
}
