/* ============================================================
   LeDistrib.be — Feuille de style des pages légales
   Reprend l'identité de index.html (sage, jaune signal,
   Archivo Black, Inter, JetBrains Mono).
   ============================================================ */

:root{
  --yellow:#FFD60A;
  --yellow-deep:#F4C600;
  --ink:#111111;
  --ink-2:#2a2a2a;
  --muted:#6b6b6b;
  --line:#e8e8e8;
  --bg:#b5bcaa;
  --card:#ffffff;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  overflow-x:hidden;
}
.container{max-width:880px;margin:0 auto;padding:0 32px}
h1,h2,h3,h4{font-family:'Archivo Black','Inter',sans-serif;font-weight:900;line-height:1.05;letter-spacing:-0.01em}
.mono{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:0.04em;text-transform:uppercase}
a{color:var(--ink)}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(250,250,247,0.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;max-width:1280px;margin:0 auto}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink)}
.logo img{display:block;height:48px;width:auto}
.nav .logo img{filter:none}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{
  text-decoration:none;color:var(--ink);font-size:14px;font-weight:500;
  position:relative;padding:6px 0;transition:color .15s;
}
.nav-links a:hover{color:var(--ink-2)}
.nav-links a.nav-cta{
  background:var(--ink);color:#fff;padding:10px 18px;border-radius:999px;
  font-size:13px;font-weight:600;transition:transform .15s;
}
.nav-links a.nav-cta:hover{transform:translateY(-1px);color:#fff}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);margin:4px 0;transition:.2s}

@media (max-width:880px){
  .nav-links{
    position:fixed;top:64px;left:0;right:0;
    flex-direction:column;align-items:flex-start;
    background:var(--bg);padding:24px 32px;gap:18px;
    border-bottom:1px solid var(--line);
    transform:translateY(-150%);transition:transform .25s;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-toggle{display:block}
  .nav-links a.nav-cta{display:none}
}

/* ============ PAGE HEADER ============ */
.legal-hero{
  padding:140px 0 50px;
}
.legal-hero .eyebrow{
  display:inline-block;font-family:'JetBrains Mono',monospace;
  font-size:12px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--ink-2);margin-bottom:16px;
}
.legal-hero .eyebrow::before{content:"— "}
.legal-hero h1{
  font-size:clamp(40px,6vw,72px);line-height:0.95;margin-bottom:18px;
}
.legal-hero h1 .accent{
  position:relative;display:inline-block;z-index:0;
}
.legal-hero h1 .accent::after{
  content:"";position:absolute;left:-4px;right:-4px;bottom:6px;height:16px;
  background:var(--yellow);z-index:-1;transform:skewX(-6deg);
}
.legal-hero h1 .accent > span{position:relative;z-index:1}
.legal-hero .updated{
  font-family:'JetBrains Mono',monospace;font-size:12px;
  color:var(--muted);letter-spacing:0.04em;
}

/* ============ CONTENT CARD ============ */
.legal-body{padding:0 0 100px}
.legal-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:20px;
  padding:48px;
}
.legal-card section{padding:0;margin:0 0 40px}
.legal-card section:last-child{margin-bottom:0}
.legal-card h2{
  font-size:24px;line-height:1.1;margin-bottom:16px;
  padding-bottom:12px;border-bottom:2px solid var(--yellow);
  display:inline-block;
}
.legal-card h3{
  font-family:'Inter',sans-serif;font-weight:700;
  font-size:16px;margin:24px 0 8px;letter-spacing:0;
}
.legal-card p{font-size:15px;color:var(--ink-2);margin-bottom:14px}
.legal-card ul{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}
.legal-card ul li{
  font-size:15px;color:var(--ink-2);padding-left:20px;position:relative;
}
.legal-card ul li::before{
  content:"";position:absolute;left:0;top:9px;
  width:6px;height:6px;background:var(--yellow);border-radius:50%;
}
.legal-card a{color:var(--ink);font-weight:600;text-decoration:underline;text-decoration-color:var(--yellow);text-underline-offset:3px}
.legal-card a:hover{color:var(--yellow-deep)}

/* Definition rows (mentions légales) */
.def-grid{
  display:grid;grid-template-columns:200px 1fr;gap:4px 24px;
  font-size:15px;margin-bottom:8px;
}
.def-grid dt{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);
  padding:10px 0;border-top:1px solid var(--line);
}
.def-grid dd{
  color:var(--ink);font-weight:500;
  padding:10px 0;border-top:1px solid var(--line);
}
.def-grid dt:first-of-type,.def-grid dd:first-of-type{border-top:none}

/* "À compléter" highlight */
.todo{
  background:rgba(255,214,10,0.25);
  padding:1px 6px;border-radius:4px;
  font-family:'JetBrains Mono',monospace;font-size:13px;
  color:var(--ink-2);
}

.callout{
  background:#fffdf2;border-left:3px solid var(--yellow);
  padding:16px 20px;border-radius:0 10px 10px 0;
  font-size:14px;color:var(--ink-2);margin:24px 0;
}

/* ============ CGV spécifique ============ */
/* Sommaire des articles */
.toc{
  background:#fafaf7;border:1px solid var(--line);
  border-radius:14px;padding:24px 28px;margin-bottom:32px;
}
.toc-title{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px;display:block;
}
.toc ol{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:1fr 1fr;gap:6px 24px;
  counter-reset:toc;
}
.toc li{
  counter-increment:toc;
  font-size:14px;
}
.toc li a{
  color:var(--ink-2);text-decoration:none;
  display:inline-flex;align-items:baseline;gap:8px;
  padding:4px 0;
  transition:color .15s,padding-left .15s;
}
.toc li a::before{
  content:counter(toc,decimal-leading-zero);
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--ink);font-weight:600;
  flex-shrink:0;
}
.toc li a:hover{color:var(--ink);padding-left:4px;text-decoration:none}
@media (max-width:880px){
  .toc{padding:18px 20px}
  .toc ol{grid-template-columns:1fr}
}

/* Sous-articles numérotés (10.2 etc.) */
.legal-card .sub{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:0.06em;
  color:var(--ink);font-weight:600;
  margin-top:18px;margin-bottom:2px;display:block;
}
.legal-card .sub + p,.legal-card .sub + ul{margin-top:6px}

/* Identité éditeur en haut */
.legal-id{
  background:#fafaf7;border:1px solid var(--line);
  border-radius:14px;padding:22px 26px;
  font-size:14px;color:var(--ink-2);
  margin-bottom:32px;
}
.legal-id strong{display:block;font-family:'Archivo Black',sans-serif;font-size:16px;color:var(--ink);margin-bottom:8px;font-weight:900;letter-spacing:0;line-height:1.2}
.legal-id-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-size:13.5px}
.legal-id-grid dt{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);padding-top:3px;white-space:nowrap}
.legal-id-grid dd{color:var(--ink)}
.legal-id-grid a{font-weight:600}
@media (max-width:600px){
  .legal-id-grid{grid-template-columns:1fr;gap:2px 0}
  .legal-id-grid dt{padding-top:8px}
  .legal-id-grid dd{padding-bottom:6px;border-bottom:1px solid var(--line)}
  .legal-id-grid dd:last-of-type{border-bottom:none}
}

/* Lien retour haut de page sur les sections longues */
.legal-card section{scroll-margin-top:100px}

@media (max-width:880px){
  .legal-hero{padding:110px 0 40px}
  .legal-card{padding:28px}
  .def-grid{grid-template-columns:1fr;gap:0}
  .def-grid dt{padding-bottom:0;border-top:1px solid var(--line)}
  .def-grid dd{padding-top:2px;border-top:none}
  .def-grid dt:first-of-type{border-top:none}
}

/* ============ FOOTER ============ */
footer{
  background:#0a0a0a;color:#999;padding:48px 0 24px;font-size:14px;
}
footer .container{max-width:1280px}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:16px;
}
.footer-copy{color:#666;font-size:12px;letter-spacing:0.02em}
.footer-legal{display:flex;gap:24px}
.footer-legal a{color:#888;text-decoration:none;font-size:12px;transition:color .2s}
.footer-legal a:hover{color:var(--yellow)}
.footer-legal a.current{color:var(--yellow)}
@media (max-width:880px){
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}
}
