@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap);

:root {
    --color-bg: #fff;
    --color-surface: #4e0052;
    --color-highlight: #ff0db6;
    --text-primary: #ffffff;
    --border-color: rgba(255, 255, 255, 0.35);
    --radius-pill: 40px;
    --hero-desktop-image: url(/lp-statics/images/paribu-banner-desktop.webp);
    --hero-mobile-image: url(/lp-statics/images/paribu-banner-mobile.webp)
}

* {
    box-sizing: border-box
}

.hero {
    width: 100%
}

body {
    margin: 0;
    font-family: 'Inter', system-ui, sans-serif;
    color: #212121;
    background-color: var(--color-bg)
}

main {
    min-height: 100vh;
}

.hero {
    width: 100%
}

.hero__inner {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 650px;
    background-color: var(--color-surface);
    overflow: hidden
}

.hero__sticky {
    display: none
}

.hero__media {
    width: 100%;
    height: clamp(320px, 70vw, 420px);
    position: relative;
    overflow: hidden;
    border-bottom-left-radius: 24px;
    border-bottom-right-radius: 24px
}

.hero__media picture,
.hero__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover
}

.hero__content {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 16px;
    color: #fff;
    max-width: 520px;
    margin-inline: auto;
    width: 100%;
    align-items: flex-start;
}

.hero__content > * {
    width: 100%;
}

.hero__eyebrow {
    margin: 0;
    font-size: 26px;
    line-height: 32px;
    font-weight: 700;
    color: var(--text-primary)
}

.hero h1 {
    margin: 0;
    font-size: 18px;
    line-height: 28px;
    font-weight: 700;
    color: var(--color-highlight)
}

.hero__lead {
    margin: 0;
    font-size: 14px;
    line-height: 22px
}

.hero__actions {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
    margin-top: 8px
}

.hero__sticky {
    display: none
}

.cta {
    border-radius: var(--radius-pill);
    padding: 12px 24px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none
}

.cta--primary {
    display: none;
    border: none;
    background: var(--text-primary);
    color: #4e0052
}

.cta--primary:hover,
.cta--primary:focus-visible {
    background-color: #fff8ff
}

.cta--ghost {
    border: 1px solid var(--border-color);
    background: #fff0;
    color: var(--text-primary);
    width: 100%
}

.cta--ghost:hover,
.cta--ghost:focus-visible {
    background: #fff;
    color: #4e0052
}

.perks__content .cta--ghost:hover,
.perks__content .cta--ghost:focus-visible {
    background-color: #fff8ff
}

@media (min-width:960px) {
    body {
        background-color: var(--color-bg)
    }

    .hero__inner {
        min-height: 650px;
        justify-content: center;
        background-image: var(--hero-desktop-image);
        background-size: cover;
        background-position: center
    }

    .hero__inner::before {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(118deg, rgb(0 0 0 / .45) 0%, #fff0 50%);
        pointer-events: none
    }

    .hero__media {
        display: none
    }

    .hero__content {
        max-width: 1200px;
        margin-left: auto;
        margin-right: auto;
        gap: 16px;
        padding: 0 76px;
        box-sizing: border-box;
        align-items: flex-start;
    }

    .hero__content > * {
        max-width: 560px;
    }

    .hero__eyebrow {
        font-size: 34px;
        line-height: 40px
    }

    .hero h1 {
        font-size: 26px;
        line-height: 32px
    }

    .hero__lead {
        font-size: 14px
    }

    .hero__actions {
        flex-direction: row;
        gap: 24px;
        width: auto
    }

    .cta--primary {
        display: inline-flex
    }

    .cta--ghost {
        width: auto
    }
}

@media (max-width:959px) {
    .hero .cta--ghost {
        border-color: #fff
    }

    .hero__inner {
        border-bottom-left-radius: 24px;
        border-bottom-right-radius: 24px
    }

    .hero__sticky {
        display: block;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 100;
        pointer-events: none
    }

    .hero__sticky-overlay {
        background: linear-gradient(180deg, #fff0 0%, rgb(255 255 255 / .8) 60%, rgb(255 255 255) 100%);
        padding: 16px calc(16px + env(safe-area-inset-bottom, 0))
    }

    .hero__sticky-link {
        width: 100%;
        display: inline-flex;
        pointer-events: auto;
        background: #4e0052;
        color: #fff
    }
}

.info {
    width: 100%;
    padding: 32px 16px 16px 16px
}

.info,
.steps,
.perks,
.terms,
.disclaimer {
    max-width: 1200px;
    margin-inline: auto;
    box-sizing: border-box;
}



.info__inner {
    display: flex;
    flex-direction: column;
    gap: 24px;
    background: #fff;
    width: 100%
}

.info__media {
    border-radius: 32px;
    overflow: hidden
}

.info__media img {
    width: 100%;
    display: block;
    border-radius: inherit
}

.info__content {
    display: flex;
    flex-direction: column;
    gap: 16px;
    color: #212121
}

.info__title {
    margin: 0;
    font-size: 22px;
    line-height: 30px;
    font-weight: 600;
    color: #4e0052
}

.info__text {
    margin: 0;
    font-size: 14px;
    line-height: 22px
}

.steps {
    width: 100%;
    background: #fff
}

.steps__inner {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 32px 16px 32px 16px
}

.steps__media {
    width: 100%
}

.steps__media img {
    width: 100%;
    display: block;
    border-radius: 32px
}

.steps__content {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 0;
    color: #212121
}

.steps__title {
    margin: 0;
    font-size: 22px;
    line-height: 30px;
    font-weight: 600;
    color: #4e0052
}

.steps__lead {
    margin: 0;
    font-size: 14px;
    line-height: 22px
}

.steps__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px
}

.steps__item {
    display: flex;
    gap: 8px;
    align-items: center;
    font-size: 14px;
    line-height: 22px
}

.steps__item img {
    flex-shrink: 0
}

.steps__index {
    border: 1px solid #ff0fb6;
    width: 24px;
    height: 24px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 9999px;
    margin: 0;
}

.perks {
    width: 100%;
    background: #fff
}

.perks__inner {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 32px 16px 16px 16px
}

.perks__media img {
    width: 100%;
    border-radius: 32px;
    display: block
}

.perks__content {
    display: flex;
    flex-direction: column;
    gap: 16px;
    color: #212121
}

.perks__title {
    margin: 0;
    font-size: 22px;
    line-height: 30px;
    font-weight: 600;
    color: #4e0052
}

.perks__lead {
    margin: 0;
    font-size: 14px;
    line-height: 22px
}

.perks__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px
}

.perks__item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    line-height: 22px
}

.perks__item img {
    flex-shrink: 0
}

.perks__footnote {
    color: #212121;
    text-decoration: none
}

.cta--primary-outline {
    border: 1px solid #4e0052;
    color: #4e0052;
    width: 100%;
    text-align: center
}

.terms {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 32px 16px 32px
}

.terms__card {
    width: 100%;
    max-width: 848px;
    border: 1px solid #e0e0e0;
    border-radius: 32px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    background: #fff
}

.terms__title {
    margin: 0;
    font-size: 22px;
    line-height: 30px;
    font-weight: 600;
    color: #4e0052;
    text-align: center
}

.terms__body[hidden] {
    display: none
}

.terms__list {
    margin: 0;
    padding-left: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    font-size: 14px;
    line-height: 22px;
    color: #212121
}

.terms__toggle {
    border: none;
    background: #fff0;
    color: #4e0052;
    font-size: 14px;
    font-weight: 500;
    align-self: center;
    cursor: pointer
}

.elementor-kit-6 .terms__toggle {
    background: transparent;
    color: #4e0052;
    border: none;
}

.elementor-kit-6 .steps__title,
.elementor-kit-6 .perks__title,
.elementor-kit-6 .terms__title,
.elementor-kit-6 .info__title {
    font-size: 22px;
    line-height: 30px;
    font-weight: 600;
    color: #4e0052 !important;
}

.disclaimer {
    width: 100%;
    padding: 32px 16px 32px
}

.disclaimer__content {
    display: flex;
    gap: 16px;
    max-width: 1224px;
    margin: 0 auto;
    font-size: 14px;
    line-height: 22px;
    color: #9e9e9e;
    align-items: baseline
}

.disclaimer__index {
    flex-shrink: 0;
    color: #9e9e9e
}

@media (min-width:960px) {
    .info__inner {
        flex-direction: row;
        gap: 64px;
        padding: 32px 76px 16px 76px;
        align-items: center
    }

    .info__media,
    .info__content {
        flex: 1
    }

    .steps__inner {
        flex-direction: row;
        gap: 64px;
        padding: 32px 76px;
        align-items: center
    }

    .steps__content {
        flex: 1;
        padding: 0
    }

    .steps__media {
        flex: 1;
        order: 2
    }

    .steps__media img {
        height: 420px;
        object-fit: cover
    }

    .perks__inner {
        flex-direction: row;
        padding: 64px 76px 64px 76px;
        align-items: center;
        gap: 64px
    }

    .perks__media {
        flex: 1
    }

    .perks__content {
        flex: 1
    }

    .cta--primary-outline {
        width: fit-content;
        margin-top: 48px
    }

    .terms__card {
        padding: 32px
    }
}
