:root{
  /* alternating-fields : 3 fonds pleins qui séparent les sections */
  --field-light:#fbf8f3;   /* ivoire chaud (airy) */
  --field-tint:#f4ece0;    /* sable orangé désaturé */
  --field-dark:#221b13;    /* brou de noix */
  --ink:#26201a;
  --ink-soft:#5f574c;
  --paper:#ffffff;
  --line:#e7ddcd;
  --line-soft:#efe7d8;
  /* hue secteur = orange sécurité INRS, sobre */
  --signal:#c5571a;        /* accents décoratifs (filets, eyebrows, puces) — PAS de texte blanc dessus */
  --signal-cta:#b04d12;    /* SURFACE des boutons primaires : ratio 5.36 avec #fff (≥ AA 4.5) */
  --signal-dark:#9d4310;   /* hover boutons + texte/liens orange : ratio 6.47 avec #fff */
  --signal-ink:#fff6ee;
  --danger:#a6321f;        /* réservé états de gravité, jamais le CTA */
  --pill:999px;            /* pill-mixed : boutons très ronds */
  --card-radius:14px;      /* cartes rectilignes (contraste de formes) */
  --maxw:1140px;
  --readw:720px;
  --shadow:0 10px 34px -18px rgba(50,34,16,.30);
  --shadow-lg:0 26px 60px -26px rgba(40,26,10,.40);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:"Schibsted Grotesk",system-ui,-apple-system,"Segoe UI",sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.68;font-size:17.5px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Besley",Georgia,"Times New Roman",serif;line-height:1.2;color:var(--ink);font-weight:600;text-wrap:balance}
h1{font-size:clamp(2.1rem,1.4rem + 2.7vw,3.2rem);letter-spacing:-.015em;margin:0 0 .45em}
h2{font-size:clamp(1.5rem,1.15rem + 1.3vw,2.1rem);margin:0 0 .5em}
h3{font-size:1.22rem;margin:0 0 .4em}
p{margin:0 0 1.1em;text-wrap:pretty}
a{color:var(--signal-dark);text-underline-offset:3px;text-decoration-thickness:1px}
a:hover{color:var(--signal)}
img{max-width:100%;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip{position:absolute;left:-999px;top:0;background:var(--signal-cta);color:#fff;padding:11px 18px;border-radius:0 0 12px 0;z-index:60}
.skip:focus{left:0}

/* ---- Header ---- */
header.site{background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:66px}
.brand{font-family:"Besley",serif;font-weight:600;font-size:1.16rem;color:var(--ink);text-decoration:none;letter-spacing:-.01em;display:flex;align-items:center;gap:10px}
.brand:hover{color:var(--ink)}
.brand .mk{display:inline-block;width:26px;height:26px;flex:0 0 auto;border-radius:7px;background:var(--field-dark);position:relative}
.brand .mk::before{content:"";position:absolute;inset:6px;border:2px solid var(--signal);border-radius:50%}
.brand .mk::after{content:"";position:absolute;left:50%;top:50%;width:7px;height:7px;background:var(--signal);border-radius:50%;transform:translate(-50%,-50%)}
.brand small{display:block;font-family:"Schibsted Grotesk",sans-serif;font-weight:500;font-size:.62rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);margin-top:1px}
nav.menu{display:flex;gap:2px;align-items:center;flex-wrap:wrap}
nav.menu a{color:var(--ink-soft);text-decoration:none;padding:9px 13px;border-radius:var(--pill);font-size:.95rem;line-height:1.2;font-weight:500}
nav.menu a:hover{background:var(--field-tint);color:var(--ink)}
nav.menu a[aria-current="page"]{color:var(--signal-dark);background:var(--field-tint)}
nav.menu a.cta{background:var(--signal-cta);color:#fff;font-weight:600;padding:9px 18px}
nav.menu a.cta:hover{background:var(--signal-dark);color:#fff}
.burger{display:none;background:none;border:1px solid var(--line);color:var(--ink);border-radius:12px;min-width:44px;min-height:44px;font-size:1.4rem;line-height:1;cursor:pointer}
@media(max-width:840px){
  .burger{display:inline-flex;align-items:center;justify-content:center}
  nav.menu{display:none;position:absolute;left:0;right:0;top:66px;flex-direction:column;align-items:stretch;background:var(--paper);padding:10px 18px 18px;gap:2px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  nav.menu.open{display:flex}
  nav.menu a{padding:14px 14px;min-height:44px;display:flex;align-items:center;border-radius:12px}
}

/* ---- geometric-pattern (trame discrète, dérivée du métier : grille d'évaluation) ---- */
.geo{position:relative}
.geo::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(120,90,50,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(120,90,50,.05) 1px,transparent 1px);
  background-size:46px 46px,46px 46px;
}
.geo > *{position:relative;z-index:1}

/* ---- Hero split-form-right (airy) ---- */
.hero{background:var(--field-light);padding:62px 0 70px}
.heroflow{display:grid;grid-template-columns:1fr 420px;column-gap:56px;row-gap:22px;align-items:start;grid-template-areas:"head form" "lede form" "more form"}
.hf-head{grid-area:head}.hf-form{grid-area:form;align-self:start}.hf-lede{grid-area:lede}.hf-more{grid-area:more}
@media(max-width:920px){.heroflow{grid-template-columns:1fr;column-gap:0;row-gap:14px;grid-template-areas:"head" "form" "more" "lede"}.hero{padding:24px 0 42px}}
.hero .eyebrow,.phead .eyebrow{color:var(--signal-dark);font-weight:700;letter-spacing:.09em;text-transform:uppercase;font-size:.76rem;margin:0 0 14px}
.hero h1{max-width:15ch}
@media(max-width:920px){.hero h1{font-size:1.6rem;line-height:1.1;max-width:none;margin:0}.hf-head .eyebrow{margin:0 0 7px;font-size:.7rem}.hf-lede .dek{margin:2px 0 0}.hf-more{margin-top:0}}
.hero .dek{color:var(--ink-soft);font-size:1.15rem;max-width:54ch;margin:0 0 22px}
.hero ul.bullets{list-style:none;margin:0 0 22px;padding:0;display:grid;gap:11px}
.hero ul.bullets li{position:relative;padding-left:32px;color:var(--ink);font-size:1.02rem}
.hero ul.bullets li::before{content:"";position:absolute;left:0;top:6px;width:18px;height:18px;border-radius:5px;background:var(--field-tint);border:1.5px solid var(--signal)}
.hero ul.bullets li::after{content:"";position:absolute;left:6px;top:9px;width:5px;height:9px;border:solid var(--signal-dark);border-width:0 2px 2px 0;transform:rotate(40deg)}
.trust{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.trust span{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--ink-soft);background:var(--paper);border:1px solid var(--line);border-radius:var(--pill);padding:6px 13px}
.trust span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--signal);flex:0 0 auto}

/* form card (colonne droite) — carte rectiligne, pill-mixed avec boutons ronds */
.formcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--card-radius);box-shadow:var(--shadow-lg);overflow:hidden}
.formcard .fc-top{background:var(--field-dark);color:#f3ead9;padding:18px 22px}
.formcard .fc-top h2{color:#fff;font-size:1.24rem;margin:0 0 5px}
.formcard .fc-top p{color:#d9cab0;font-size:.92rem;margin:0}
.formcard .fc-body{padding:20px 22px 24px}
@media(max-width:920px){.formcard .fc-top{padding:12px 18px}.formcard .fc-top h2{font-size:1.1rem;margin:0 0 2px}.formcard .fc-top p{font-size:.82rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.formcard .fc-body{padding:13px 16px 15px}.hf-form .field{margin:0 0 9px}.hf-form #hc_msg{min-height:46px!important}.hf-form .consent{margin:5px 0 11px;font-size:.78rem}.hf-form .btn{padding:11px 22px;min-height:46px}}

/* ---- Forms ---- */
.field{margin:0 0 13px}
.field label{display:block;font-size:.85rem;font-weight:600;color:var(--ink-soft);margin:0 0 5px}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:1rem;padding:12px 13px;border:1px solid var(--line);border-radius:11px;background:#fff;color:var(--ink);min-height:44px}
.field textarea{min-height:104px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--signal);outline-offset:1px;border-color:var(--signal)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:11px}
@media(max-width:480px){.frow{grid-template-columns:1fr}}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.83rem;color:var(--ink-soft);margin:8px 0 16px}
.consent input{margin-top:3px;width:18px;height:18px;flex:0 0 auto}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--signal-cta);color:#fff;border:0;border-radius:var(--pill);font:inherit;font-weight:700;font-size:1.02rem;padding:13px 26px;min-height:48px;cursor:pointer;text-decoration:none;transition:background .15s}
.btn:hover{background:var(--signal-dark);color:#fff}
.btn-block{width:100%}
.btn-ghost{background:transparent;color:var(--signal-dark);border:1.5px solid var(--signal);font-weight:600}
.btn-ghost:hover{background:var(--field-tint);color:var(--signal-dark)}
.fc-alt{font-size:.82rem;color:var(--ink-soft);margin:13px 0 0;text-align:center}

/* ---- contrat de prise de contact (gratuité / délai / qui répond / livrable) ---- */
.contract{list-style:none;margin:14px 0 0;padding:14px 0 0;border-top:1px solid var(--line);display:grid;gap:9px}
.contract li{position:relative;padding-left:26px;font-size:.84rem;color:var(--ink-soft);line-height:1.45}
.contract li::before{content:"";position:absolute;left:0;top:4px;width:14px;height:14px;border-radius:4px;background:var(--field-tint);border:1.5px solid var(--signal)}
.contract li::after{content:"";position:absolute;left:4px;top:6px;width:4px;height:7px;border:solid var(--signal-dark);border-width:0 2px 2px 0;transform:rotate(40deg)}
.contract li strong{color:var(--ink);font-weight:600}
.contract.on-dark{border-top-color:rgba(255,255,255,.13)}
.contract.on-dark li{color:#cbbda5}
.contract.on-dark li strong{color:#f1e7d6}

/* ---- alternating-bands : fonds pleins par section (la structure se voit au scroll) ---- */
section.band{padding:58px 0}
section.f-light{background:var(--field-light)}
section.f-tint{background:var(--field-tint)}
section.f-paper{background:var(--paper)}
section.f-dark{background:var(--field-dark);color:#ece1ce}
section.f-dark h2,section.f-dark h3{color:#fff}
section.f-dark a{color:#f0bd8c}
section.f-dark .ink-soft{color:#cbbda5}
.sechead{max-width:62ch;margin:0 0 26px}
.sechead .eyebrow{color:var(--signal-dark);font-weight:700;letter-spacing:.09em;text-transform:uppercase;font-size:.74rem;margin:0 0 10px}
section.f-dark .sechead .eyebrow{color:#f0bd8c}

/* ---- article editorial row (offset spine léger, airy) ---- */
.art-row{display:grid;grid-template-columns:236px 1fr;gap:42px;padding:30px 0;border-top:1px solid var(--line)}
section.f-dark .art-row{border-top-color:rgba(255,255,255,.13)}
.art-row:first-of-type{border-top:0}
.art-row .spine{font-family:"Besley",serif;font-size:1.18rem;font-weight:600;color:var(--signal-dark);position:relative;padding-left:16px;text-wrap:balance}
section.f-dark .art-row .spine{color:#f0bd8c}
.art-row .spine::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:4px;border-radius:3px;background:var(--signal)}
.art-row .cell{max-width:var(--readw)}
.art-row .cell p:last-child,.art-row .cell ul:last-child{margin-bottom:0}
.art-row .cell ul{margin:0 0 1.1em;padding-left:1.2em}
.art-row .cell li{margin:0 0 .5em}
.art-row .cell .sig{font-style:italic;color:var(--signal-dark);border-left:3px solid var(--signal);padding-left:14px;margin:.3em 0 0}
section.f-dark .art-row .cell .sig{color:#f0bd8c;border-left-color:#f0bd8c}
@media(max-width:780px){
  .art-row{grid-template-columns:1fr;gap:12px;padding:24px 0}
  .art-row .spine{padding-left:14px}
}

/* ---- home : grille d'articles (média éditorial) ---- */
.artgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:720px){.artgrid{grid-template-columns:1fr}}
.card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--card-radius);padding:24px 24px 22px;box-shadow:var(--shadow);text-decoration:none;color:var(--ink);transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);color:var(--ink)}
.card .ctag{font-size:.72rem;letter-spacing:.07em;text-transform:uppercase;font-weight:700;color:var(--signal-dark);margin:0 0 10px}
.card h3{font-size:1.28rem;margin:0 0 8px}
.card p{color:var(--ink-soft);font-size:.96rem;margin:0 0 14px}
.card .more{margin-top:auto;font-weight:600;color:var(--signal-dark);font-size:.94rem}
.card .more::after{content:" \2192"}

/* ---- about blocks ---- */
.about-blocks{display:grid;gap:24px;max-width:var(--readw)}
.about-blocks .ab{background:var(--paper);border:1px solid var(--line);border-radius:var(--card-radius);padding:24px 26px;box-shadow:var(--shadow)}
section.f-tint .about-blocks .ab{background:var(--paper)}
.about-blocks .ab h3{margin:0 0 8px;color:var(--signal-dark)}
.about-blocks .ab p:last-child{margin-bottom:0}

/* ---- FAQ ---- */
.faq{max-width:var(--readw)}
.faq h2{margin-bottom:18px}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:12px;margin:0 0 11px;overflow:hidden}
section.f-dark .faq details{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.16)}
.faq summary{cursor:pointer;padding:15px 18px;font-weight:600;font-family:"Besley",serif;font-size:1.06rem;list-style:none;display:flex;justify-content:space-between;gap:12px;min-height:44px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--signal);font-weight:700;font-size:1.35rem;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq .ans{padding:0 18px 16px;color:var(--ink-soft)}
.faq .ans p:last-child{margin-bottom:0}
section.f-dark .faq .ans{color:#d8cbb4}

/* ---- CTA band ---- */
.ctaband{text-align:center;max-width:60ch;margin:0 auto}
.ctaband h2{margin:0 auto .5em}
.ctaband p{color:var(--ink-soft);margin:0 auto 22px;max-width:50ch}
section.f-dark .ctaband p{color:#cbbda5}
.ctaband .actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---- inner page head (no form) ---- */
.phead{background:var(--field-light);padding:54px 0 46px}
.phead h1{max-width:20ch}
.phead .dek{color:var(--ink-soft);max-width:60ch;font-size:1.12rem;margin:0}
.crumbs{font-size:.8rem;color:var(--ink-soft);margin:0 0 16px}
.crumbs a{color:var(--signal-dark);text-decoration:none}
.crumbs a:hover{text-decoration:underline}

/* ---- footer ---- */
footer.site{background:var(--field-dark);color:#bcab90;padding:44px 0 32px;font-size:.92rem}
footer.site .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:34px}
@media(max-width:680px){footer.site .cols{grid-template-columns:1fr;gap:24px}}
footer.site h3{color:#f1e7d6;font-size:1.02rem;margin:0 0 11px;font-family:"Besley",serif}
footer.site a{color:#cdbfa6;text-decoration:none;display:block;padding:3px 0}
footer.site a:hover{color:#fff;text-decoration:underline}
footer.site p{color:#b3a386;margin:0 0 .7em}
footer.site .legal{border-top:1px solid rgba(255,255,255,.1);margin-top:28px;padding-top:18px;font-size:.8rem;color:#8d8068;display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between}
footer.site .legal a{display:inline}

/* ---- utility / prose ---- */
.util{padding:56px 0;min-height:52vh}
.prose-util{max-width:var(--readw)}
.prose-util h2{font-size:1.32rem;margin-top:1.5em}
.prose-util ul{padding-left:1.25em}
.merci-box{background:var(--field-light);border:1px solid var(--line);border-radius:var(--card-radius);padding:24px;margin:18px 0}
.merci-box h3{margin-top:0}

/* consent banner */
.cbanner{position:fixed;left:14px;right:14px;bottom:14px;max-width:540px;margin:0 auto;background:var(--paper);border:1px solid var(--line);border-radius:var(--card-radius);box-shadow:var(--shadow-lg);padding:16px 18px;z-index:70;font-size:.86rem;color:var(--ink-soft)}
.cbanner .cact{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.cbanner button{font:inherit;cursor:pointer;border-radius:var(--pill);padding:9px 18px;min-height:42px;border:1.5px solid var(--signal)}
.cbanner .cyes{background:var(--signal-cta);color:#fff;border-color:var(--signal-cta);font-weight:600}
.cbanner .cno{background:#fff;color:var(--ink-soft)}
@media(prefers-reduced-motion:no-preference){.cbanner{animation:cup .3s ease}}
@keyframes cup{from{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}
