/* base.css — reset + tokens (modifiable) */
*,
*::before,
*::after {
  box-sizing: border-box;
}
html:focus-within {
  scroll-behavior: smooth;
}
body {
  margin: 0;
  min-height: 100vh;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-size: var(--fs-md);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.5;
  width: 100%;
  max-width: 100%;
  position:relative;
}
html, body { overflow-x: clip; } /* plus fiable que hidden pour les débordements dynamiques */

img {
  max-width: 100%;
  height: auto;
  display: block;
  width: 100%;
}
a {
  color: inherit;
  text-decoration: none;
}
:root {
  --brand-500: #0f4c5c;
  --brand-600: #0c3e4b;
  --accent-500: #d97706;
  --bg: #ffffff;
  --ink: #111827;
  --muted: #6b7280;
  --border: #e5e7eb;
  --fs-xs: clamp(12px, 0.78vw, 14px);
  --fs-sm: clamp(14px, 0.9vw, 16px);
  --fs-md: clamp(16px, 1.05vw, 18px);
  --fs-lg: clamp(20px, 1.5vw, 24px);
  --fs-xl: clamp(28px, 2.2vw, 36px);
  --fs-2xl: clamp(36px, 3vw, 48px);
  --space-0: 0;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --radius: 16px;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  --font-sans: "Open Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

h1 {
  font-size: var(--fs-2xl);
  line-height: 1.1;
  margin: var(--space-8) 0 var(--space-4);
}
h2 {
  font-size: var(--fs-xl);
  line-height: 1.15;
  margin: var(--space-6) 0 var(--space-3);
}
h3 {
  font-size: var(--fs-lg);
  line-height: 1.2;
  margin: var(--space-4) 0 var(--space-2);
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

button {
  background: none;         /* retire le fond par défaut */
  border: 0;             /* supprime la bordure native */
  padding: 0;               /* réinitialise les marges internes */
  margin: 0;                /* réinitialise les marges externes */          /* hérite de la police et de sa taille */
  color: inherit;           /* hérite de la couleur du texte */
  cursor: pointer;          /* montre un curseur de type pointeur */
  -webkit-appearance: none; /* retire le style par défaut sur WebKit (Safari, Chrome) */
  -moz-appearance: none;    /* retire le style par défaut sur Firefox */
  appearance: none;   
  transition: all .3s;  
  outline: 0px;   
  outline-offset: 0px; /* retire le style par défaut sur les navigateurs modernes */
}

/* Pour conserver l'accessibilité, personnalisez le focus plutôt que de l'enlever complètement. */
button:focus {
  outline: 2px solid #000;
  outline-offset: 4px;
}