/* ============================================================================
 * Legal pages — styles partagés (mentions, CGV, privacy, cookies).
 * Charte v3 : Hobeaux Rococeaux Sherman + Montserrat, palette noir/or/crème.
 * ============================================================================ */

:root {
  --noir: #1a1a18;
  --noir-soft: #2a2a26;
  --or: #c8a84b;
  --or-light: #e0c478;
  --or-deep: #a88838;
  --creme: #f1eee7;
  --line-soft: rgba(26, 26, 24, 0.08);
  --display: 'Hobeaux Rococeaux Sherman', Georgia, serif;
  --body: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

@font-face {
  font-family: 'Hobeaux Rococeaux Sherman';
  src: url('/fonts/HobeauxRococeauxSherman.ttf') format('truetype');
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: 'Montserrat';
  src: url('/fonts/Montserrat-Regular.ttf') format('truetype');
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: 'Montserrat';
  src: url('/fonts/Montserrat-SemiBold.ttf') format('truetype');
  font-weight: 600;
  font-display: swap;
}
@font-face {
  font-family: 'Montserrat';
  src: url('/fonts/Montserrat-Bold.ttf') format('truetype');
  font-weight: 700;
  font-display: swap;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--body);
  background: var(--creme);
  color: var(--noir);
  font-weight: 400;
  line-height: 1.65;
  font-size: 15px;
}
::selection { background: var(--or); color: var(--noir); }
a { color: var(--or-deep); text-decoration: none; transition: color .2s; }
a:hover { color: var(--or); }

.legal-header {
  background: var(--noir);
  color: var(--creme);
  padding: 28px 32px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.legal-header-inner {
  max-width: 880px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.legal-header img {
  height: 64px;
  width: auto;
  filter: brightness(0) invert(1);
  transform: scale(2.2);
  transform-origin: center;
}
.legal-header a.back {
  color: rgba(241, 238, 231, 0.78);
  font-size: 13px;
  border: 1px solid rgba(241, 238, 231, 0.2);
  padding: 8px 16px;
  border-radius: 999px;
  transition: all .25s;
}
.legal-header a.back:hover {
  background: var(--or);
  color: var(--noir);
  border-color: var(--or);
}

.legal-page {
  max-width: 880px;
  margin: 0 auto;
  padding: 60px 32px 100px;
}

.legal-eyebrow {
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--or-deep);
  font-weight: 600;
  margin-bottom: 16px;
}
.legal-title {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(34px, 4.5vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--noir);
  margin-bottom: 12px;
}
.legal-subtitle {
  font-size: 13px;
  color: rgba(26, 26, 24, 0.6);
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line-soft);
}

.legal-note {
  background: rgba(200, 168, 75, 0.08);
  border: 1px solid rgba(200, 168, 75, 0.25);
  border-radius: 14px;
  padding: 18px 22px;
  margin-bottom: 36px;
  font-size: 14px;
  color: rgba(26, 26, 24, 0.8);
}
.legal-note strong { color: var(--noir); }

.legal-page h2 {
  font-family: var(--display);
  font-weight: 400;
  font-size: 22px;
  color: var(--or-deep);
  margin: 36px 0 14px;
  letter-spacing: -0.005em;
}
.legal-page h3 {
  font-size: 15px;
  font-weight: 600;
  color: var(--noir);
  margin: 22px 0 10px;
}
.legal-page p {
  margin-bottom: 14px;
  color: rgba(26, 26, 24, 0.85);
}
.legal-page strong { color: var(--noir); font-weight: 600; }
.legal-page ul, .legal-page ol {
  margin: 14px 0 14px 24px;
  color: rgba(26, 26, 24, 0.85);
}
.legal-page li { margin-bottom: 6px; }

.legal-footer {
  background: var(--noir);
  color: rgba(241, 238, 231, 0.6);
  padding: 32px;
  text-align: center;
  font-size: 12.5px;
}
.legal-footer-inner { max-width: 880px; margin: 0 auto; }
.legal-footer a {
  color: rgba(241, 238, 231, 0.78);
  border-bottom: 1px solid rgba(241, 238, 231, 0.18);
}
.legal-footer a:hover { color: var(--or); border-color: var(--or); }
.legal-footer-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 14px;
}
