/* Styles partagés pages légales — MyLeveling */
:root {
  --font-display: "Inter Tight", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;
  --bg: #07070A;
  --card: #111116;
  --border: rgba(255,255,255,0.07);
  --green: #11D04A;
  --text: #E8E8E8;
  --text-sec: #A0A0B0;
  --text-ter: #5A5A70;
}
*, *::before, *::after { box-sizing: border-box; }
html { background: var(--bg); overscroll-behavior: none; }
html, body {
  margin: 0; padding: 0;
  background: var(--bg);
  font-family: var(--font-display);
  -webkit-font-smoothing: antialiased;
  color: var(--text);
  line-height: 1.65;
}
body { overflow-x: hidden; }

/* Grain — texture pré-rendue (cf. index.html) pour éviter le repaint
   plein écran au scroll mobile causé par filtre SVG + mix-blend-mode */
body::after {
  content: '';
  position: fixed; inset: 0;
  pointer-events: none; z-index: 100;
  opacity: 0.35; mix-blend-mode: overlay;
  background-image: url("noise.png");
  background-repeat: repeat;
  background-size: 320px 320px;
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* Header mini */
.site-header {
  padding: 28px clamp(20px, 5vw, 48px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 12px;
}
.site-header a {
  display: flex; align-items: center; gap: 8px;
  text-decoration: none; color: var(--text);
  font-size: 15px; font-weight: 600; letter-spacing: -0.3px;
}
.site-header img { height: 20px; image-rendering: pixelated; }
.site-header .sep {
  font-size: 13px; color: var(--text-ter); margin-left: 4px;
}

/* Main content */
.legal-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: clamp(48px, 8vw, 80px) clamp(20px, 5vw, 48px) 100px;
}

.legal-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--green);
  font-weight: 600; margin-bottom: 12px;
}

.legal-wrap h1 {
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 700; letter-spacing: -0.03em;
  line-height: 1.1; margin: 0 0 8px;
}

.legal-date {
  font-size: 13px; color: var(--text-ter);
  font-family: var(--font-mono); margin-bottom: 48px;
}

.legal-wrap h2 {
  font-size: 1.05rem; font-weight: 700;
  letter-spacing: -0.01em;
  margin: 40px 0 10px;
  color: var(--text);
}

.legal-wrap p, .legal-wrap li {
  font-size: 14.5px; color: var(--text-sec);
  margin: 0 0 12px;
}

.legal-wrap ul {
  padding-left: 20px; margin: 0 0 12px;
}

.legal-wrap li { margin-bottom: 6px; }

.legal-wrap a {
  color: var(--green); text-decoration: none;
  border-bottom: 1px solid rgba(17,208,74,0.25);
  transition: border-color 0.2s;
}
.legal-wrap a:hover { border-color: var(--green); }

.placeholder {
  background: rgba(17,208,74,0.08);
  border: 1px solid rgba(17,208,74,0.2);
  border-radius: 4px; padding: 1px 6px;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--green); font-weight: 600;
}

/* Footer */
.legal-footer {
  border-top: 1px solid var(--border);
  padding: 28px clamp(20px, 5vw, 48px);
  /* safe-area iOS : viewport-fit=cover dessine derrière la barre Safari */
  padding-bottom: calc(28px + env(safe-area-inset-bottom, 0px));
  display: flex; gap: 24px; flex-wrap: wrap;
  align-items: center;
}
.legal-footer span {
  font-size: 12px; color: var(--text-ter);
  font-family: var(--font-mono);
}
.legal-footer a {
  font-size: 12px; color: var(--text-ter);
  text-decoration: none; transition: color 0.2s;
}
.legal-footer a:hover { color: var(--text); }
