/* base.css — reset + typo de base */
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{
  font-size:16px;
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--header-h-mobile) + 12px);
}
@media (min-width:900px){
  html{scroll-padding-top:calc(var(--header-h) + 16px);}
}
/* PIEGE PROD #11 : overflow-x:clip sur body (jamais overscroll:none) */
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--ff-body);
  font-size:17px;
  line-height:1.55;
  overflow-x:clip;
  max-width:100vw;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,picture,video,iframe,svg{display:block;max-width:100%;}
img{height:auto;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}
a{color:inherit;text-decoration:none;}
a:hover{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px;text-decoration-color:color-mix(in srgb,var(--accent) 70%,transparent);}
/* PIEGE PROD #5 : figure margin reset */
figure{margin:0;}
ul,ol{margin:0;padding:0;list-style:none;}
p{margin:0 0 1em;}
blockquote{margin:0;}
input,select,textarea{font:inherit;color:inherit;}
/* PIEGE PROD #8 : hidden force */
[hidden]{display:none !important;}

/* Typo headings */
h1,h2,h3,h4{
  font-family:var(--ff-display);
  font-weight:500;
  line-height:1.1;
  margin:0 0 .6em;
  color:var(--text);
  letter-spacing:-0.005em;
}
h1{font-size:clamp(2.4rem,5.4vw,4.2rem);font-weight:500;}
h2{font-size:clamp(1.9rem,3.6vw,2.8rem);}
h3{font-size:clamp(1.2rem,1.8vw,1.5rem);font-weight:500;}
h4{font-size:1.1rem;font-weight:500;}
em,i{font-style:italic;}

/* Micro-details signes */
::selection{background:color-mix(in srgb,var(--accent) 35%,transparent);color:var(--text);}
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--accent) 36%,transparent);border-radius:4px;}
::-webkit-scrollbar-thumb:hover{background:var(--accent);}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px;}
::placeholder{color:color-mix(in srgb,var(--text) 50%,transparent);opacity:1;}

/* Container */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}
@media (min-width:900px){.container{padding:0 32px;}}

/* Sections spacing (mobile-first) */
section{padding:48px 0;}
@media (min-width:900px){section{padding:80px 0;}}

/* Utilities */
.eyebrow{
  font-family:var(--ff-ui);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  color:var(--accent);
  font-weight:500;
  margin-bottom:14px;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--accent);}
.lede{font-size:clamp(1.05rem,1.5vw,1.18rem);color:var(--text-2);max-width:60ch;}
