/* ================================================
   Page — Mentions légales
   ================================================ */

/* ── Background global ── */
.legal-page {
    background: var(--light-warm);
    min-height: 100vh;
    padding-top: 40px;
}

/* En mobile le hero est plein écran (géré globalement dans hero-visual.css) :
   on supprime aussi le padding-top pour coller le hero au navbar */
@media (max-width: 768px) {
    .legal-page {
        padding-top: 0;
    }
}

/* ── Hero ── */
.legal-page .hero__container {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: var(--container-max-width);
    margin: 0 auto;
    padding: 80px var(--padding-horizontal-large);
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* ── Layout 2 colonnes ── */
.legal-layout {
    display: flex;
    gap: 40px;
    max-width: var(--container-max-width);
    margin: 40px auto;
    padding: 0 var(--padding-horizontal-large);
    align-items: flex-start;
}

.legal-layout__sidebar {
    width: 300px;
    flex-shrink: 0;
    position: sticky;
    top: 120px;
}

.legal-layout__main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 50px;
}

/* ── Conditions row (2 cards side by side) ── */
.terms-conditions-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}

.terms-conditions-row .content-card {
    height: 100%;
}

/* ── Responsive ── */
@media (max-width: 1100px) {
    .legal-layout {
        gap: 24px;
        padding: 0 20px;
    }

    .legal-layout__sidebar {
        width: 260px;
    }
}

@media (max-width: 900px) {
    .legal-page .hero__container {
        padding: 50px 20px;
    }

    .legal-layout {
        flex-direction: column;
        gap: 24px;
        margin: 24px auto;
    }

    .legal-layout__sidebar {
        width: 100%;
        position: static;
    }

    .legal-layout__main {
        gap: 30px;
    }

    .terms-conditions-row {
        grid-template-columns: 1fr;
    }
}
