/* ===== PAGE ===== */
.orindia-offre {
    padding: 52px 20px 80px;
    background: #ffffff;
    min-height: 100dvh;
}

/* Le footer offre est une ligne de crédits, pas un bloc — pas de marge */
.site-footer {
    margin-top: 0;
}

.offre-layout {
    width: min(100%, 1240px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}

/* ===== TITRE PLEINE LARGEUR ===== */
.offre-titre-principal h1 {
    max-width: 14ch;
}

.offre-titre-principal-sans-kicker h1 {
    max-width: none;
}

/* ===== SIDEKICK — mobile first ===== */
.offre-sidekick {
    order: initial;
}

.bravade-offre {
    width: 100%;
}

.offre-sidekick-title {
    margin: 0 0 14px;
    color: #0c1f17;
    font-size: clamp(1.35rem, 2.2vw, 1.9rem);
    font-weight: 700;
    line-height: 1.18;
    letter-spacing: -0.02em;
}

.bravade-offre p {
    color: rgba(16, 35, 28, 0.60);
    font-size: 1rem;
    line-height: 1.72;
    max-width: 42ch;
}

.offre-illustration {
    display: flex;
    justify-content: center;
    margin-top: 28px;
}

.offre-illustration img {
    display: block;
    width: min(100%, 300px);
    max-width: 100%;
    height: auto;
}

/* ===== PACK SHELL ===== */
.offre-pack-shell {
    display: flex;
    justify-content: center;
}

/* ===== PACK CARD ===== */
.pack-ordinia {
    width: min(100%, 392px);
    border-radius: 24px;
    overflow: hidden;
    background: #ffffff;
    box-shadow:
        0 1px 3px rgba(16, 35, 28, 0.06),
        0 20px 56px rgba(16, 35, 28, 0.16);
    position: static;
    flex-direction: column;
    justify-content: initial;
    padding: 0;
    border: none;
    height: auto;
    min-height: unset;
    max-height: unset;
    overflow-x: unset;
    scrollbar-width: unset;
}

.pack-ordinia::before {
    display: none;
}

/* ===== CARD HEADER — green zone ===== */
.pack-essentiel {
    padding: 28px 28px 26px;
    background: linear-gradient(135deg, #124d35 0%, #1a6b4a 60%, #22835c 100%);
    border-bottom: none;
    position: relative;
    overflow: hidden;
}

.pack-essentiel::before {
    content: "";
    position: absolute;
    top: -70px;
    right: -70px;
    width: 230px;
    height: 230px;
    border-radius: 50%;
    background: rgba(62, 213, 153, 0.10);
    pointer-events: none;
}

.pack-essentiel::after {
    content: "";
    position: absolute;
    bottom: -50px;
    left: 10px;
    width: 130px;
    height: 130px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.04);
    pointer-events: none;
}

.pack-badge {
    display: inline-flex;
    align-items: center;
    margin-bottom: 18px;
    padding: 5px 13px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.22);
    color: rgba(255, 255, 255, 0.90);
    font-size: 0.76rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    box-shadow: none;
}

.pack-essentiel h2 {
    font-size: clamp(1.5rem, 4vw, 2.1rem);
    font-weight: 800;
    color: #ffffff;
    line-height: 1.12;
    letter-spacing: -0.015em;
}

.pack-nom {
    display: block;
    margin: 0 0 10px;
    padding-left: 12px;
    border-left: 3px solid rgba(255, 255, 255, 0.55);
    position: relative;
    z-index: 1;
    color: rgba(255, 255, 255, 0.96);
    font-size: 0.86rem;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.prix-pack {
    margin-top: 16px;
    font-size: clamp(2.4rem, 8vw, 3.45rem);
    font-weight: 800;
    color: #ffffff;
    line-height: 1;
    letter-spacing: -0.025em;
}

.prix-devise {
    font-size: 0.52em;
    font-weight: 700;
    vertical-align: super;
    line-height: 1;
    opacity: 0.82;
}

.prix-freq {
    font-size: 0.36em;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.58);
    letter-spacing: 0.02em;
}

.pack-description {
    margin-top: 12px;
    max-width: 34ch;
    color: rgba(255, 255, 255, 0.70);
    font-size: 0.84rem;
    line-height: 1.6;
}

/* ===== DETAILS ===== */
.details-offre {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: 0;
}

.offre-davantage {
    padding: 20px 26px;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.offre-davantage + .offre-davantage {
    border-top: 1px solid #f0f0f0;
}

.offre-davantage-inclus {
    border: none;
}

.offre-davantage h3 {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 14px;
}

.offre-davantage-inclus h3 {
    color: var(--accent-1);
}

.offre-liste {
    display: grid;
    gap: 9px;
    margin-top: 0;
}

.offre-liste li {
    position: static;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding-left: 0;
    color: rgba(16, 35, 28, 0.82);
    font-size: 0.87rem;
    line-height: 1.46;
}

.offre-liste li::before {
    position: static;
    flex-shrink: 0;
    margin-top: 1px;
    width: 19px;
    height: 19px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1;
    box-shadow: none;
    top: unset;
    left: unset;
}

.offre-liste-inclus li::before {
    content: "\2713";
    background: #e4f4ec;
    color: var(--accent-1);
}

/* ===== NON INCLUS ===== */
.offre-davantage-exclus h3 {
    color: rgba(16, 35, 28, 0.44);
}

.offre-liste-exclus li {
    color: rgba(16, 35, 28, 0.54);
}

.offre-liste-exclus li::before {
    content: "\2212";
    background: #f2f2f2;
    color: rgba(16, 35, 28, 0.38);
}

/* ===== ITEM NOTE ===== */
.item-note {
    display: inline-block;
    margin-left: 5px;
    padding: 1px 7px;
    border-radius: 999px;
    background: rgba(26, 107, 74, 0.10);
    color: var(--accent-1);
    font-size: 0.74em;
    font-weight: 600;
    vertical-align: middle;
}

/* ===== ENGAGEMENT CONDITIONS ===== */
.engagement-conditions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 6px 10px;
    margin: 0;
    padding: 12px 24px;
    border-top: 1px solid #f0f0f0;
    background: #f8fbf9;
    color: rgba(16, 35, 28, 0.54);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    box-shadow: none;
}

.engagement-sep {
    color: var(--accent-1);
    opacity: 0.35;
    font-weight: 700;
}

/* ===== CTA (intégré dans la carte) ===== */
.offre-cta {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin: 0;
    padding: 16px 26px;
    border-radius: 0 0 24px 24px;
    background: linear-gradient(135deg, #124d35 0%, #1a6b4a 55%, #22835c 100%);
    border: none;
    color: #ffffff;
    font-size: 0.94rem;
    font-weight: 700;
    text-decoration: none;
    letter-spacing: 0.01em;
    box-shadow: none;
    text-shadow: none;
    transition: filter 200ms ease;
    position: relative;
    z-index: 1;
}

.offre-cta-pack {
    margin-top: 18px;
    border-radius: 999px;
    background: var(--bg-principal);
    color: var(--accent-1);
    box-shadow:
        0 10px 24px rgba(16, 35, 28, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.offre-cta::before {
    display: none;
}

.offre-cta:hover,
.offre-cta:focus-visible {
    filter: brightness(1.12);
    transform: none;
    color: #ffffff;
    background: linear-gradient(135deg, #124d35 0%, #1a6b4a 55%, #22835c 100%);
    border-color: transparent;
    box-shadow: none;
    outline: 3px solid rgba(62, 213, 153, 0.35);
    outline-offset: 0;
}

.offre-cta:active {
    transform: none;
    filter: brightness(0.96);
}

.offre-cta-pack:hover,
.offre-cta-pack:focus-visible {
    color: var(--accent-1);
    background: var(--bg-principal);
}

@media (max-width: 1079px) {
    .offre-titre-principal {
        display: none;
    }

    .offre-sidekick {
        order: -1;
    }

    .offre-illustration {
        display: none;
    }

    .bravade-offre {
        text-align: center;
    }

    .bravade-offre p {
        margin: 0 auto;
    }
}

/* ===== DESKTOP ===== */
@media (min-width: 1080px) {
    .orindia-offre {
        padding: 0 40px;
        display: flex;
        align-items: center;
    }

    .offre-layout {
        display: grid;
        grid-template-columns: minmax(360px, 420px) minmax(360px, 420px);
        justify-content: center;
        grid-template-rows: auto 1fr;
        align-items: start;
        gap: 40px 72px;
        padding-block: 64px;
        min-height: 100dvh;
    }

    /* h1 + kicker pleine largeur en haut */
    .offre-titre-principal {
        grid-column: 1 / -1;
        grid-row: 1;
        margin-bottom: 20px;
    }

    /* pack card — colonne gauche */
    .offre-pack-shell {
        grid-column: 1;
        grid-row: 2;
        justify-content: center;
        align-self: start;
    }

    /* p + illustration — colonne droite */
    .offre-sidekick {
        grid-column: 2;
        grid-row: 2;
        order: initial;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
        gap: 0;
        padding-top: 8px;
    }

    .pack-ordinia {
        width: min(100%, 372px);
        height: auto;
        min-height: unset;
        max-height: unset;
        overflow: visible;
        overflow-y: unset;
        padding-right: 0;
        scrollbar-width: unset;
        justify-content: initial;
    }

    .pack-nom {
        display: block;
        margin-bottom: 12px;
        padding-left: 14px;
        border-left-width: 3px;
        color: #ffffff;
        font-size: 0.9rem;
        letter-spacing: 0.08em;
    }

    .pack-ordinia::-webkit-scrollbar {
        display: none;
    }

    .bravade-offre {
        text-align: left;
    }

    .offre-sidekick-title {
        max-width: 18ch;
    }

    .bravade-offre p {
        max-width: 38ch;
    }

    .offre-illustration {
        justify-content: center;
        margin-top: 36px;
    }

    .offre-illustration img {
        width: clamp(260px, 26vw, 400px);
    }
}

/* ===== SMALL MOBILE ===== */
@media (max-width: 580px) {

    .orindia-offre {
        padding: 32px 18px 64px;
    }

    .offre-layout {
        gap: 32px;
    }

    .offre-titre-principal h1 {
        margin-top: 6px;
    }

    .pack-essentiel {
        padding: 26px 22px 24px;
    }

    .offre-cta-pack {
        margin-top: 16px;
        padding: 16px 20px;
    }

    .offre-davantage {
        padding: 20px 22px;
    }

    .offre-liste {
        gap: 12px;
    }

    .engagement-conditions {
        padding: 14px 22px;
        gap: 8px 12px;
    }

    .offre-cta {
        padding: 18px 22px;
        border-radius: 0 0 22px 22px;
    }

    .offre-illustration {
        margin-top: 36px;
    }
}
