/* ===== Pages de contenu : pages légales (natif Elementor) + hub Notre École ===== */

/* --- PAGES LÉGALES (mentions, confidentialité, conditions) --- */
.legal-page { padding-top: var(--space-4xl); padding-bottom: var(--space-4xl); }
.legal-page > .elementor-container { max-width: 880px; }
.legal-page h1 { margin-bottom: var(--space-sm); }
.legal-page h2 {
    margin-top: var(--space-2xl); margin-bottom: var(--space-md);
    color: var(--bleu); font-size: 24px;
}
.legal-page p, .legal-page li { color: var(--gris-fonce); line-height: 1.75; }
.legal-page p { margin-bottom: var(--space-md); }
.legal-page ul, .legal-page ol { margin: 0 0 var(--space-lg) var(--space-xl); }
.legal-page li { margin-bottom: var(--space-xs); }
.legal-page a { color: var(--orange); text-decoration: underline; }
.legal-page .legal-updated {
    font-size: 14px; color: var(--gris-fonce); opacity: .7;
    margin-bottom: var(--space-2xl); font-style: italic;
}
.legal-page table { width: 100%; border-collapse: collapse; margin: var(--space-md) 0 var(--space-xl); }
.legal-page th, .legal-page td {
    text-align: left; padding: var(--space-sm) var(--space-md);
    border-bottom: 1px solid rgba(93, 87, 77, .15);
}
.legal-page th { font-family: var(--font-display, inherit); color: var(--gris-fonce); }
.legal-page td:last-child { white-space: nowrap; font-weight: 600; }

/* --- HUB « Notre École » (cartes vers les 4 sous-pages) --- */
.hub-page { max-width: 1400px; margin: 0 auto; padding: var(--space-4xl) var(--space-xl); }
.hub-hero { max-width: 820px; margin: 0 auto var(--space-4xl); text-align: center; }
.hub-hero .overline { color: var(--orange); display: block; margin-bottom: var(--space-sm); }
.hub-hero h1 { margin-bottom: var(--space-lg); }
.hub-hero p { color: var(--gris-fonce); font-size: 18px; line-height: 1.75; }
.hub-intro { max-width: 840px; margin: 0 auto var(--space-4xl); text-align: center; }
.hub-intro p { color: var(--gris-fonce); font-size: 17px; line-height: 1.8; margin-bottom: var(--space-md); }
.hub-intro p:last-child { margin-bottom: 0; }
.hub-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-2xl); }
.hub-card {
    display: flex; flex-direction: column; background: var(--blanc);
    border-radius: var(--radius-lg); overflow: hidden;
    box-shadow: var(--shadow-medium, 0 8px 30px rgba(0, 0, 0, .08));
    text-decoration: none; color: inherit;
    transition: transform .3s ease, box-shadow .3s ease;
}
.hub-card, .hub-card:hover, .hub-card h3, .hub-card p, .hub-card .hub-link { text-decoration: none !important; }
.hub-card h3 { color: var(--gris-fonce); }
.hub-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lifted, 0 20px 50px rgba(0, 0, 0, .14)); }
.hub-card-img { aspect-ratio: 16 / 10; overflow: hidden; }
.hub-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.hub-card:hover .hub-card-img img { transform: scale(1.05); }
.hub-card-body { padding: var(--space-xl); display: flex; flex-direction: column; gap: var(--space-sm); flex: 1; }
.hub-card-body h3 { margin: 0; }
.hub-card-body p { color: var(--gris-fonce); margin: 0; flex: 1; }
.hub-link { color: var(--orange); font-weight: 700; margin-top: var(--space-sm); }
.hub-cta { max-width: 520px; margin: var(--space-4xl) auto 0; }

@media (max-width: 768px) {
    .hub-grid { grid-template-columns: 1fr; }
    .legal-page { padding-top: var(--space-2xl); padding-bottom: var(--space-2xl); }
}
