/* ============================================================
   GEOFIXE — Pages de contenu (légal, articles, prose) — V2 clair
   ============================================================ */

/* En-tête de page de contenu */
.page-hero {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding-block: clamp(2rem, 6vw, 3.5rem);
}
.page-hero .eyebrow { margin-bottom: .8rem; }
.page-hero h1 { font-size: clamp(1.8rem, 5vw, 2.6rem); }
.page-hero .page-meta { color: var(--muted); font-size: .9rem; margin-top: .6rem; }

/* Navigation inter-pages (légal) */
.subnav {
    display: flex; gap: .5rem; flex-wrap: wrap;
    margin-top: 1.5rem;
}
.subnav a {
    font-size: .9rem; font-weight: 600; color: var(--ink-soft);
    padding: .45rem .9rem; border-radius: var(--r-full);
    background: var(--surface); border: var(--card-border);
    transition: all var(--t-fast);
}
.subnav a:hover { border-color: var(--brand); color: var(--brand-600); }
.subnav a.active { background: var(--brand); border-color: var(--brand); color: #fff; }

/* Conteneur prose */
.prose {
    max-width: 760px;
    margin-inline: auto;
    padding-block: clamp(2.5rem, 6vw, 4rem);
}
.prose > * + * { margin-top: 1.1rem; }
.prose h2 {
    font-size: clamp(1.3rem, 3vw, 1.6rem);
    margin-top: 2.5rem; padding-bottom: .6rem;
    border-bottom: 1px solid var(--border);
}
.prose h3 { font-size: 1.15rem; margin-top: 1.8rem; }
.prose p, .prose li { color: var(--ink-soft); line-height: 1.8; }
.prose ul, .prose ol { padding-left: 1.3rem; }
.prose ul { list-style: none; padding-left: 0; }
.prose ul li { position: relative; padding-left: 1.4rem; }
.prose ul li::before { content: "—"; position: absolute; left: 0; color: var(--brand); }
.prose ol { list-style: decimal; padding-left: 1.5rem; }
.prose ol li { padding-left: .25rem; }
.prose a { color: var(--brand-600); font-weight: 500; text-decoration: underline; text-underline-offset: 2px; }
.prose a:hover { color: var(--brand-700); }
.prose strong { color: var(--ink); font-weight: 700; }
.prose img { border-radius: var(--r-lg); margin-block: 1.5rem; box-shadow: var(--shadow-sm); }
.prose table { width: 100%; border-collapse: collapse; margin-block: 1.5rem; font-size: .95rem; }
.prose th, .prose td { padding: .7rem .9rem; border: var(--card-border); text-align: left; }
.prose th { background: var(--brand-50); color: var(--ink); font-weight: 700; }
.prose blockquote {
    border-left: 3px solid var(--brand); background: var(--brand-50);
    padding: 1rem 1.25rem; border-radius: 0 var(--r-md) var(--r-md) 0; color: var(--ink-soft);
}

/* ===== Compat classes "legal-*" de l'ancien site (texte conservé) ===== */
.legal-content { max-width: 760px; margin-inline: auto; }
.legal-section { margin-bottom: 2.25rem; }
.legal-section h2 {
    font-size: 1.2rem; margin-bottom: .8rem; padding-bottom: .55rem;
    border-bottom: 1px solid var(--border); color: var(--ink);
}
.legal-section h3 { font-size: 1.05rem; margin: 1.2rem 0 .5rem; }
.legal-section p, .legal-section li { color: var(--ink-soft); line-height: 1.8; font-size: .98rem; }
.legal-section ul { list-style: none; padding: 0; margin-top: .5rem; }
.legal-section ul li { padding: .15rem 0 .15rem 1.2rem; position: relative; }
.legal-section ul li::before { content: "—"; position: absolute; left: 0; color: var(--brand); }
.legal-section strong { color: var(--ink); font-weight: 700; }
.legal-section a { color: var(--brand-600); text-decoration: underline; font-weight: 500; }
.legal-section a:hover { color: var(--brand-700); }
.legal-section table { width: 100%; border-collapse: collapse; margin-block: 1rem; font-size: .92rem; }
.legal-section th, .legal-section td { padding: .6rem .8rem; border: var(--card-border); text-align: left; }
.legal-section th { background: var(--brand-50); color: var(--ink); }
