/* #region PAGES LEGALES : mentions legales, politique de confidentialite, plan du site */
.legal-page { padding-top: 128px; background: #fff; }
.legal-hero { position: relative; padding: 112px 0 54px; overflow: hidden; text-align: center; }
.legal-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 20% 20%, rgba(117,184,234,.16), transparent 32%), radial-gradient(circle at 80% 0%, rgba(74,151,223,.10), transparent 30%); pointer-events: none; }
.legal-hero .container { position: relative; z-index: 1; }
.legal-kicker { display: inline-flex; align-items: center; justify-content: center; margin-bottom: 18px; padding: 8px 14px; border-radius: 999px; background: rgba(117,184,234,.1); border: 1px solid rgba(117,184,234,.22); color: #166e8d; font-size: .76rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.legal-title { position: relative; font-family: "Sora", sans-serif; font-size: clamp(2.1rem, 4vw, 3.8rem); font-weight: 800; line-height: 1.05; letter-spacing: 0; color: #11151b; margin: 0; text-wrap: balance; }
.legal-title::after { content: ""; display: block; width: 78px; height: 3px; margin: 18px auto 0; border-radius: 999px; background: linear-gradient(90deg, var(--blue), var(--blue-strong)); box-shadow: 0 8px 18px rgba(74,151,223,.18); }.legal-title span { color: var(--blue-strong); }
.legal-subtitle { max-width: 760px; margin: 22px auto 0; font-size: clamp(1rem, 1.35vw, 1.18rem); line-height: 1.75; color: #42515d; }.legal-content { padding: 42px 0 124px; }
.legal-content .container { max-width: 940px; }
.legal-card { position: relative; overflow: hidden; padding: 42px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,250,253,.96)); border: 1px solid rgba(214,225,232,.95); box-shadow: 0 16px 36px rgba(16,24,32,.07), inset 0 1px 0 rgba(255,255,255,.8); transition: transform .32s var(--ease-smooth), box-shadow .32s ease, border-color .25s ease; }
.legal-card::before { content: ""; position: absolute; inset-inline: 0; top: 0; height: 4px; background: linear-gradient(90deg, var(--blue), var(--blue-strong)); opacity: .88; }
.legal-card:hover { transform: translateY(-4px); border-color: rgba(117,184,234,.42); box-shadow: 0 22px 46px rgba(16,24,32,.1), inset 0 1px 0 rgba(255,255,255,.84); }
.legal-block { margin-bottom: 38px; }
.legal-block:last-child { margin-bottom: 0; }
.legal-block h2 { font-family: "Sora", sans-serif; font-size: clamp(1.2rem, 1.8vw, 1.55rem); font-weight: 800; color: #162033; margin-bottom: 14px; letter-spacing: 0; }
.legal-block h3 { font-family: "Sora", sans-serif; font-size: 1.05rem; font-weight: 700; color: #162033; margin: 24px 0 10px; }
.legal-block p, .legal-block li { font-size: 1rem; line-height: 1.82; color: #3d4853; }
.legal-block p + p { margin-top: 12px; }
.legal-block ul, .legal-block ol { margin-top: 12px; padding-left: 22px; }
.legal-block a { position: relative; color: var(--blue-strong); font-weight: 600; text-decoration: none; }
.legal-block a::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .22s ease; }
.legal-block a:hover::after { transform: scaleX(1); }
.legal-note { padding: 16px 18px; border-radius: 16px; background: rgba(117,184,234,.08); border: 1px solid rgba(117,184,234,.18); color: #33404b; box-shadow: inset 0 1px 0 rgba(255,255,255,.7); }
.sitemap-list { display: grid; gap: 14px; list-style: none; padding-left: 0 !important; margin-top: 18px; }
.sitemap-list li { line-height: 1.4; }
.sitemap-list a { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 16px 18px; border-radius: 16px; background: rgba(117,184,234,.08); border: 1px solid rgba(117,184,234,.18); color: #162033; font-weight: 700; transition: transform .25s ease, background-color .25s ease, border-color .25s ease; }
.sitemap-list a::after { content: "→"; color: var(--blue-strong); transition: transform .25s ease; }
.sitemap-list a:hover { transform: translateY(-2px); background: rgba(117,184,234,.14); border-color: rgba(117,184,234,.32); text-decoration: none; }
.sitemap-list a:hover::after { transform: translateX(4px); }
@media (max-width: 767px) {
  .legal-page { padding-top: 94px; }
  .legal-hero { padding: 62px 0 28px; }
  .legal-title { font-size: 2rem; }
  .legal-subtitle { font-size: .94rem; line-height: 1.65; }
  .legal-content { padding: 28px 0 78px; }
  .legal-card { padding: 22px 16px; border-radius: 20px; }
  .legal-block { margin-bottom: 30px; }
  .legal-block h2 { font-size: 1.12rem; }
  .legal-block h3 { font-size: .98rem; }
  .legal-block p, .legal-block li { font-size: .94rem; line-height: 1.7; }
  .sitemap-list a { padding: 14px; border-radius: 14px; }
}
/* #endregion */

/* Harmonisation pages légales + barre bleue alignée sous la première lettre */
.legal-page,
.privacy-page,
.sitemap-page {
  background: linear-gradient(180deg, #ffffff 0%, #f7fafc 44%, #ffffff 100%) !important;
}
.legal-hero,
.privacy-hero,
.sitemap-hero {
  background: transparent !important;
}
.legal-hero::before,
.privacy-hero::before,
.sitemap-hero::before {
  display: none !important;
}
.legal-title,
.privacy-title,
.sitemap-title {
  display: inline-block !important;
  text-align: center !important;
}
.legal-title::after,
.privacy-title::after,
.sitemap-title::after {
  margin-left: 0 !important;
  margin-right: auto !important;
}
