/* =============================================================
   proteger-mes-donnees.fr : Base & composants
   Dépend de tokens.css. Aucune dépendance externe.
   ============================================================= */

/* ---- Reset léger ------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
html { scroll-padding-top: calc(var(--header-h) + 1rem); }

body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg, video { display: block; max-width: 100%; }
img { height: auto; }

/* ---- Typographie ------------------------------------------- */
h1, h2, h3, h4 {
  line-height: var(--lh-tight);
  font-weight: var(--ff-bold);
  letter-spacing: -0.018em;
  color: var(--text);
  text-wrap: balance;
}
h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl); line-height: var(--lh-snug); }
h4 { font-size: var(--fs-lg); line-height: var(--lh-snug); }
p  { text-wrap: pretty; }

a { color: var(--link); text-decoration-color: color-mix(in srgb, var(--link) 35%, transparent); text-underline-offset: 0.18em; transition: color var(--transition); }
a:hover { color: var(--link-hover); text-decoration-color: currentColor; }

:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
  border-radius: 4px;
}

code, kbd { font-family: var(--font-mono); font-size: 0.92em; }

/* ---- Layout primitives ------------------------------------- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--sp-5); }
.container-narrow { max-width: var(--container-narrow); }
.measure { max-width: var(--measure); }
.section { padding-block: var(--sp-8); }
.stack > * + * { margin-top: var(--sp-4); }
.eyebrow {
  font-size: var(--fs-xs);
  font-weight: var(--ff-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-primary-700);
  white-space: nowrap;
}
.skip-link {
  position: absolute; left: var(--sp-4); top: -100px;
  background: var(--c-primary-700); color: #fff; padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md); z-index: 100; transition: top var(--transition);
}
.skip-link:focus { top: var(--sp-4); }

/* =============================================================
   Boutons
   ============================================================= */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font: inherit; font-weight: var(--ff-semibold); font-size: var(--fs-base);
  line-height: 1; cursor: pointer; border: 1px solid transparent;
  border-radius: var(--r-md); padding: 0.78em 1.25em;
  text-decoration: none; transition: background var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition), transform var(--transition);
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--c-primary-600); color: #fff; box-shadow: var(--shadow-sm); }
.btn-primary:hover { background: var(--c-primary-700); color: #fff; box-shadow: var(--shadow-md); }
.btn-secondary { background: var(--surface); color: var(--c-primary-700); border-color: var(--border-strong); }
.btn-secondary:hover { background: var(--c-primary-50); border-color: var(--c-primary-300); color: var(--c-primary-800); }
.btn-ghost { background: transparent; color: var(--c-primary-700); padding-inline: 0.4em; }
.btn-ghost:hover { color: var(--c-primary-800); }
.btn-lg { font-size: var(--fs-md); padding: 0.9em 1.6em; }
.btn .icon { width: 1.15em; height: 1.15em; flex: none; }

/* link with arrow */
.link-arrow { font-weight: var(--ff-semibold); display: inline-flex; align-items: center; gap: 0.35em; text-decoration: none; }
.link-arrow .icon { width: 1em; height: 1em; transition: transform var(--transition); }
.link-arrow:hover .icon { transform: translateX(3px); }

/* =============================================================
   Cartes
   ============================================================= */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--sp-5);
}
.card-link { display: block; text-decoration: none; color: inherit; transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); }
.card-link:hover { border-color: var(--c-primary-300); box-shadow: var(--shadow-md); transform: translateY(-2px); color: inherit; }

/* =============================================================
   Badges & chips : signaux de confiance (motif récurrent)
   ============================================================= */
.badge {
  display: inline-flex; align-items: center; gap: 0.4em;
  font-size: var(--fs-xs); font-weight: var(--ff-semibold);
  line-height: 1; padding: 0.42em 0.7em; border-radius: var(--r-pill);
  border: 1px solid transparent; white-space: nowrap;
}
.badge .icon { width: 0.95em; height: 0.95em; flex: none; }
.badge-dot::before { content: ""; width: 0.5em; height: 0.5em; border-radius: 50%; background: currentColor; flex: none; }

/* statut de test */
.badge-tested   { background: var(--c-success-50); color: var(--c-success-700); border-color: var(--c-success-100); }
.badge-sourced  { background: var(--c-primary-50); color: var(--c-primary-700); border-color: var(--c-primary-100); }
.badge-untested { background: var(--c-neutral-100); color: var(--c-neutral-700); border-color: var(--c-neutral-200); }
.badge-verified { background: var(--c-primary-50); color: var(--c-primary-700); border-color: var(--c-primary-100); }
.badge-warning  { background: var(--c-amber-50); color: var(--c-amber-700); border-color: var(--c-amber-100); }

/* chip "vérifié le JJ/MM" */
.chip-verified {
  display: inline-flex; align-items: center; gap: 0.35em;
  font-size: var(--fs-xs); color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}
.chip-verified .icon { width: 0.9em; height: 0.9em; color: var(--c-primary-600); flex: none; }

/* emplacement "à vérifier à la source" */
.placeholder-value {
  display: inline-flex; align-items: center; gap: 0.4em;
  font-family: var(--font-mono); font-size: var(--fs-xs);
  color: var(--c-amber-700); background: var(--c-amber-50);
  border: 1px dashed var(--c-amber-300); border-radius: var(--r-sm);
  padding: 0.25em 0.55em;
}

/* =============================================================
   Encadrés (callouts)
   ============================================================= */
.callout {
  border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: var(--sp-5); display: flex; gap: var(--sp-4);
  background: var(--surface);
}
.callout .callout-icon { width: 1.5rem; height: 1.5rem; flex: none; margin-top: 2px; }
.callout-title { font-weight: var(--ff-bold); font-size: var(--fs-base); margin-bottom: 0.2em; }
.callout p { font-size: var(--fs-sm); color: var(--text-secondary); }
.callout-warning { background: var(--c-amber-50); border-color: var(--c-amber-100); }
.callout-warning .callout-icon { color: var(--c-amber-700); }
.callout-warning .callout-title { color: var(--c-amber-900); }
.callout-info { background: var(--c-primary-50); border-color: var(--c-primary-100); }
.callout-info .callout-icon { color: var(--c-primary-700); }
.callout-legal {
  background: var(--bg-subtle); border-color: var(--border);
  border-left: 3px solid var(--c-neutral-400);
}
.callout-legal .callout-icon { color: var(--c-neutral-600); }

/* =============================================================
   Image placeholders (jamais d'invention de capture)
   ============================================================= */
.media-placeholder {
  display: flex; align-items: center; justify-content: center;
  border: 1px dashed var(--border-strong); border-radius: var(--r-md);
  background-color: var(--bg-subtle);
  background-image: repeating-linear-gradient(135deg, transparent, transparent 9px, rgba(11,125,136,0.045) 9px, rgba(11,125,136,0.045) 18px);
  color: var(--text-muted); font-family: var(--font-mono); font-size: var(--fs-xs);
  text-align: center; padding: var(--sp-5); min-height: 180px;
}

/* =============================================================
   Divulgation d'affiliation
   ============================================================= */
.disclosure {
  font-size: var(--fs-sm); color: var(--text-secondary);
  background: var(--bg-subtle); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: var(--sp-3) var(--sp-4);
  display: flex; gap: var(--sp-3); align-items: flex-start;
}
.disclosure .icon { width: 1.1rem; height: 1.1rem; color: var(--text-muted); flex: none; margin-top: 2px; }

/* =============================================================
   Tables responsives
   ============================================================= */
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--border); border-radius: var(--r-lg); }
table.cmp { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); min-width: 640px; }
table.cmp th, table.cmp td { padding: var(--sp-3) var(--sp-4); text-align: left; border-bottom: 1px solid var(--border); vertical-align: top; }
table.cmp thead th { background: var(--bg-subtle); font-weight: var(--ff-bold); position: sticky; top: 0; }
table.cmp tbody th { font-weight: var(--ff-semibold); color: var(--text-secondary); white-space: nowrap; }

/* =============================================================
   Helpers
   ============================================================= */
.text-muted { color: var(--text-muted); }
.text-sm { font-size: var(--fs-sm); }
.text-center { text-align: center; }
.divider { border: 0; border-top: 1px solid var(--border); margin-block: var(--sp-6); }
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.grid { display: grid; gap: var(--sp-5); }
.flex { display: flex; }
.items-center { align-items: center; }
.gap-2 { gap: var(--sp-2); }
.gap-3 { gap: var(--sp-3); }
.wrap { flex-wrap: wrap; }
