/* ───────────────────────────────────────────────────────
   Kodō Lab — Feuille de style partagée pages légales
   Mentions légales, Politique de confidentialité, CGU, CGV
─────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          hsl(210, 20%, 98%);
  --surface:     hsl(0, 0%, 100%);
  --surface2:    hsl(210, 17%, 96%);
  --fg:          hsl(220, 13%, 11%);
  --muted:       hsl(215, 8%, 47%);
  --subtle:      hsl(215, 8%, 65%);
  --border:      hsl(214, 14%, 89%);
  --border-soft: hsl(214, 14%, 93%);
  --primary:     hsl(210, 78%, 28%);
  --primary-h:   hsl(211, 82%, 20%);
  --primary-dim: hsl(211, 100%, 96%);
  --teal:        #0CC9A8;
  --teal-dim:    rgba(12,201,168,.08);
  --success-bg:  hsl(142,60%,95%);
  --success-fg:  hsl(142,65%,28%);
  --radius:      6px;
  --radius-lg:   12px;
  --mono:        'IBM Plex Mono', ui-monospace, 'SF Mono', monospace;
  --sans:        'IBM Plex Sans', system-ui, -apple-system, sans-serif;
  --shadow-sm:   0 1px 3px hsl(220 13% 11% / .06), 0 1px 2px hsl(220 13% 11% / .04);
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--fg);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "cv11";
  line-height: 1.6;
}

/* ── NAV ─────────────────────────────────────── */
nav {
  position: sticky; top: 0; z-index: 10;
  height: 58px;
  background: hsl(0 0% 100% / .92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 24px;
}
.nav-logo {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; color: var(--fg);
}
.nav-logo-icon {
  width: 28px; height: 28px; border-radius: 6px;
  background: var(--primary);
  display: flex; align-items: center; justify-content: center;
}
.nav-logo-icon svg { width: 13px; height: 13px; stroke: #fff; fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.nav-logo-text { font-size: 15px; font-weight: 600; letter-spacing: -.3px; }
.nav-home {
  font-size: 13px; color: var(--muted); text-decoration: none;
  padding: 8px 14px; border-radius: var(--radius);
  border: 1px solid var(--border);
  transition: all .15s;
}
.nav-home:hover { color: var(--fg); border-color: hsl(213,13%,72%); }

/* ── HEADER ──────────────────────────────────── */
.page-header {
  max-width: 720px;
  margin: 48px auto 32px;
  padding: 0 24px;
}
.breadcrumb {
  font-size: 12px; color: var(--subtle);
  margin-bottom: 12px; letter-spacing: .02em;
}
.breadcrumb a { color: var(--muted); text-decoration: none; }
.breadcrumb a:hover { color: var(--primary); text-decoration: underline; }
.page-title {
  font-size: 32px; font-weight: 600;
  letter-spacing: -.7px; line-height: 1.2;
  margin-bottom: 8px;
}
.page-sub {
  font-size: 14px; color: var(--muted);
}
.page-updated {
  display: inline-block; margin-top: 14px;
  font-size: 12px; color: var(--muted);
  background: var(--surface2); border: 1px solid var(--border-soft);
  border-radius: 20px; padding: 4px 12px;
  font-family: var(--mono);
}

/* ── CONTENT ─────────────────────────────────── */
main {
  max-width: 720px;
  margin: 0 auto 80px;
  padding: 0 24px;
}

article h2 {
  font-size: 20px; font-weight: 600;
  letter-spacing: -.3px;
  margin: 40px 0 12px;
  padding-top: 16px;
  border-top: 1px solid var(--border-soft);
}
article h2:first-child { border-top: none; padding-top: 0; margin-top: 0; }
article h3 {
  font-size: 15px; font-weight: 600;
  margin: 24px 0 8px;
  letter-spacing: -.1px;
}
article p {
  font-size: 15px;
  color: hsl(220, 13%, 25%);
  margin-bottom: 14px;
}
article ul, article ol {
  margin: 8px 0 16px 24px;
}
article li {
  font-size: 15px;
  color: hsl(220, 13%, 25%);
  margin-bottom: 6px;
}
article a {
  color: var(--primary); text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}
article a:hover { color: var(--primary-h); }
article strong { font-weight: 600; color: var(--fg); }
article code {
  font-family: var(--mono);
  font-size: 13px;
  background: var(--surface2);
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid var(--border-soft);
}

/* Callout box */
.callout {
  background: var(--primary-dim);
  border: 1px solid hsl(210, 78%, 28%, .18);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  margin: 20px 0;
}
.callout-title {
  font-size: 13px; font-weight: 600;
  color: var(--primary);
  text-transform: uppercase; letter-spacing: .06em;
  margin-bottom: 6px;
}
.callout p { margin-bottom: 0; font-size: 14px; }

.callout.warn {
  background: hsl(43, 100%, 96%);
  border-color: hsl(30, 90%, 70%);
}
.callout.warn .callout-title { color: hsl(30, 90%, 35%); }

/* Table */
.table-wrap { overflow-x: auto; margin: 16px 0 24px; }
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
th, td {
  text-align: left;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-soft);
  vertical-align: top;
}
th {
  background: var(--surface2);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--muted);
}
tr:last-child td { border-bottom: none; }

/* Identity card */
.identity-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 22px;
  margin: 20px 0;
  box-shadow: var(--shadow-sm);
}
.identity-card dl { display: grid; grid-template-columns: max-content 1fr; gap: 8px 20px; }
.identity-card dt { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; padding-top: 2px; }
.identity-card dd { font-size: 14px; color: var(--fg); }

/* ── FOOTER ──────────────────────────────────── */
footer {
  border-top: 1px solid var(--border);
  background: var(--surface);
  padding: 32px 24px;
  margin-top: 60px;
}
.footer-inner {
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 16px 32px;
  justify-content: space-between;
  align-items: flex-start;
}
.footer-links {
  display: flex; flex-wrap: wrap;
  gap: 6px 20px;
  font-size: 13px;
}
.footer-links a {
  color: var(--muted);
  text-decoration: none;
  transition: color .15s;
}
.footer-links a:hover { color: var(--primary); }
.footer-contact {
  font-size: 13px;
  color: var(--muted);
}
.footer-contact a {
  color: var(--muted);
  text-decoration: none;
}
.footer-contact a:hover { color: var(--primary); }
.footer-copyright {
  max-width: 720px;
  margin: 20px auto 0;
  font-size: 12px;
  color: var(--subtle);
  font-family: var(--mono);
}

/* ── RESPONSIVE ──────────────────────────────── */
@media (max-width: 640px) {
  .page-header { margin: 32px auto 24px; }
  .page-title { font-size: 26px; }
  article h2 { font-size: 18px; margin-top: 32px; }
  .identity-card dl { grid-template-columns: 1fr; gap: 4px 0; }
  .identity-card dt { padding-top: 10px; }
  .identity-card dt:first-child { padding-top: 0; }
  .footer-inner { flex-direction: column; }
}

/* ── PRINT ──────────────────────────────────── */
@media print {
  nav, footer { display: none; }
  body { background: #fff; }
  main, .page-header { max-width: 100%; }
}
